Git 的介绍
Git 是一种分布式的版本管理系统。简单来说,它就是一个版本控制软件,而且也是现在世界上最流行最先进的。
Git 的一个具体作用就是对文件进行版本管理。由于每次项目上线,可能会产生一些无法预料的bug,这时就需要选择上一个正常的版本进行回滚操作。而 Git 的存在,就是为了开发人员能够方便地在不同版本之间进行切换。
Github、码云Gitee,在某种程度上来说,就是代码的网盘。也有开源的开发商作为代码发布、存放、征集bug的地方。
除了版本管理这个功能,Git 在团队协作开发上也有很大的优势。由于每个模块的代码都是独立的,并不会影响到其他人员的模块代码。开发完成后,项目负责人会通过git命令,去把每个模块的分支合并到一个叫master主分支上面,项目正式上线的时候,就会把master主分支进行上线部署。
SVN,也是一个版本管理系统,但是它必须要在指定的网络环境上才能进行开发和管理。所以一旦网络崩溃或者说服务器宕机了,那么SVN的版本控制功能也就崩溃了。Git —— 分布式,可以让每个开发人员都能将整个代码完整地下载到本地,包括这个项目的分支、版本更新记录。如果线上环境崩溃,完全可以通过本地选择上一个正常的呆板,然后进行回滚,再将代码覆盖至线上就能进行恢复了。
1.1 Git 工作原理
1.1.1 工作区
Git 在本地初始化一个仓库后,会存在一个 .git
文件夹。它还存在三个工作区域:工作目录(工作区)、暂存区、资源库。如果从远端仓库拉去的项目,那就会多一个工作区域,就是远程git仓库。
- 工作区(workspace):平时开发代码、写代码的地方;
- 暂存区(Stage / Index):用于临时保存代码的改动;
- 本地仓库(Repository):用于存放所有版本的数据;
- 远程仓库(Remote):保存代码的地方,Github、码云;
2. Git 命令
2.1 Git 基础操作命令
2.1.1 Git 四步走
添加当前工作区文件到暂存区
git add .
将暂存区的代码提交到本地仓库
git commit -m "备注信息"
将远程仓库代码拉取到本地
git pull
将本地仓库的代码,推送到远端仓库
git push
2.1.2 克隆远程仓库代码
如果你本地没有这些代码的情况下,使用这个命令将远程仓库的代码克隆至本地
git clone https://gitee.com/lyan-test/git-demo.git
2.2 Git 配置命令
2.2.1 查看配置命令
# 查看所有配置
git config -l
# 查看系统配置
git config --system -l
# 查看全局配置
git config --global -l
2.2.2 配置全局
git config --global user.name "lyan_test"
git config --global user.email "[email protected]"
2.3 进阶操作
恢复某个阶段的代码
# 恢复到上一次版本
git reset --hard HEAD^
# 恢复到前3次提交时的版本
git reset --hard HEAD~3
# 恢复到指定的hash版本
git reset --hard 哈希码
3. 忽略文件
在项目根目录下创建一个名为 .gitignore
文件,文件里面写上需要排除的文件名即可。
如果说忽略文件之前就已经提交过这个文件,那就需要在工作目录先执行一次删除文件操作,再把这次操作提交到我们的本地仓库中进行同步。那下次推送时,远程仓库需要被忽略的文件就会被删除了。
3.1 匹配规则
如果想要忽略所有以某个后缀名为后缀的文件
*.md
如果想要排除某个文件不被忽略,可以通过英文感叹号 !
!readme.md
想排除根目录下的某个文件夹,可以通过 /
+ 文件夹来忽略
/test # 这里代表根目录下的test文件夹将会被忽略提交,而 /js/test 的则不会。
如果想排除所有文件夹下的test文件夹
*/test
test/
4. 分支
每一个实际项目中,都会存在多个分支。每个分支都对应着一个模块,或者说需要修复的bug。
查看本地所有分支
git branch
查看远程所有分支
git branch -r
新建分支
git branch 分支名
切换开发分支
git checkout 分支名
新建并切换分支
git checkout -b 分支名
在切换分支时,一定要提交已修改的代码。否则另一条分支的代码将会覆盖工作区的代码文件,当然,git 是不允许这样操作的。
合并分支
git merge 分支B # 假设当前开发的分支为分支A
代码意思是,分支B的内容将会合并到分支A内,但分支B的代码不会受到影响。
如果出现了有代码冲突的地方,那就需要去和开发人员商讨如何保留。
删除分支
git branch -d 分支名
删除分支时,首先要保证当前开发的分支不是被删除的那条分支,否则会删除失败。
如果被删除分支中存在差异性代码,那么也会导致删除失败。因为Git认为该操作会导致代码丢失的情况出现,所以确保没问题之后,可以通过强制删除命令删除分支。或者去将要删除的分支中,进行一次代码提交。
git branch -D 分支名 # 强制删除分支
删除远程分支
git branch -dr [remote/branch] # 这个方法只是将本地的远程信息删除,并不会实际影响到远程仓库的分支
git push origin --delete branch # 能够直接将远程仓库的分支进行删除
杂项命令
查看当前文件的状态
git status
- Untracked:未跟踪,文件在工作区内,但是并没有经过 Git 的管理,要通过
git add
将文件加到暂存区,然后状态变为Staged
; - Unmodify:文件已经进入 Git 版本库,此时 Git 会将版本库中的文件与工作区内的文件进行对比,如果内容完全一致,则代表文件未修改,也就是现在文件的状态。可以通过
git rm
将文件移出版本库,变为 Untracked 状态的文件; - Modified:文件已进入 Git 版本库,并且经对照后发现文件已经发生修改,但没有添加到暂存区。此时文件可以通过
git add
进入暂存区,或者通过git checkout
命令,用版本库中的文件覆盖掉工作区的文件,此时文件状态会变为 Unmodify; - Staged:文件处于暂存区,通过
git commit
命令提交到本地仓库中。可以使用git reset HEAD filename
取消暂存,文件状态将变为 Modified。
可能存在的问题
push 代码时,出现 403 错误
如果当前电脑之前登陆过码云,这时用的是另外一个码云账号,一般push时会出现403错误。
Windows用户:控制面板 —— 用户帐户 —— 凭据管理器 —— Windows凭据,找到gitee凭据删除即可。
Mac:钥匙串访问 —— 搜索git,会出现 gitee.com 的一个钥匙串,右键删除即可。
git push -f 导致远程仓库历史记录丢失
当本地仓库没有包含远程仓库所有的历史记录时,强制推送会导致远程仓库的历史记录丢失,产生不可逆的影响。