概述
本次集中总结了Git4个常规操作,导出(archive)、忽略(gitignore)、隐藏(Stash)、合并冲突(merge)的解决方法,希望帮助到正在辛苦寻找的你。
.gitignore忽略文件
之前开发和部署服务比较仓促,所以有很多图片文件一起加载到服务中,使得仓库代码922M,所以要分离出图片和忽略部分,推送代码的时候提示Push rejected for repository size exceeds limit.
,说明Git仓库需要优化了。
首先导出之前Git
git archive --format=zip --output=output.zip HEAD
设置全局Git账号和邮箱
git config --global user.name "stark张宇"
git config --global user.email "15117995393@126.com"
gitignore的语法的前提
再设置.gitignore文件中gitignore的语法是关键的一个环节,它相当于一个规定好的匹配规则,可以设置忽略和不忽略等等条件,主要的应该还是忽略的部分,需要注意的是gitignore的语法只有在git的工作区中生效。
$ ll -a | grep .git
drwxr-xr-x 14 stark staff 448B 10 10 15:31 .git
-rw-r--r-- 1 stark staff 348B 10 10 15:30 .gitignore
或者使用git remote -v
来查看git仓库的url
$ git remote -v
origin https://gitee.com/beijing-wolf-slaying-biology/demo.git (fetch)
origin https://gitee.com/beijing-wolf-slaying-biology/demo.git (push)
.gitignore的语法
下面是一些常见的 .gitignore 文件语法规则:
1.空行或以#开头的行将被 Git 忽略,可以用作注释。
2.星号 * 代表零个或多个任意字符。例如, *.DS_Store 会匹配所有的 .DS_Store 文件。
3.问号 ? 代表一个任意字符。例如, ?.txt 会匹配 a.txt 但不会匹配 ab.txt。
4.方括号 [] 可以匹配括号内的任一字符。例如, [abc].txt 会匹配 a.txt,b.txt 和 c.txt。
5.两个星号 ** 表示任意中间目录。例如, **/foo 会匹配 foo,a/foo,a/b/foo 等。
6.前缀 ! 表示不忽略。例如, *.txt 和 !important.txt 会忽略所有的 .txt 文件,但不会忽略 important.txt。
8.后缀 / 表示只忽略目录。例如, /runtime/* 会忽略 runtime 目录下所有的 文件。
还有一个特殊情况,我新增一个/config/忽略这个文件夹的话,本地缓存删除(改变成未track状态),然后再提交,需要执行以下的命令:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
Stash 命令隐藏操作
Stash 命令常用于某个部分功能开发到一半而不得不中途修复bug,或者紧急切换分支,或者是对当前Git分支进行隔离,Stash命令的执行原理将一个新的存根推到堆栈上,运行git stash命令。
$ git status
On branch admin_purchase_202310
modified: app/admin/view/purchase/purchase/index.html
modified: app/common/command/ScpSend.php
modified: public/pc/index.html
执行git stash后,当前分支就变成干净的工作区了,可以在使用git status查看
$ git stash
Saved working directory and index state WIP on admin_purchase_202310: c3ce01bc Merge branch 'images_perf_202310'
$ git status
On branch admin_purchase_202310
nothing to commit, working tree clean
可以使用git stash list
的命令来查看stash栈上的代码序列,使用git stash pop
代码弹出栈。
git stash list
stash@{0}: WIP on admin_purchase_202310: c3ce01bc Merge branch 'images_perf_202310'
Git 代码冲突
多人开发代码难免遇到代码冲突的问题,Git版本中非常常见的地方,有两个特别需要注意,或者说容易忽略的点。
假设待上线分支是admin_purchase_202310
,要发布一个版本的功能,要合并分支main
,合并的前提是更新代码,保持代码是最新的在进行操作,发版要小心操作,合并之后要记得git push
推送分支。
$ git pull
Already up to date.
$ git merge admin_purchase_202310
Already up to date.
$ git push
Everything up-to-date
当发生冲突时,先使用git status
查看冲突的地方,一般有