Git 的基本使用

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 导致远程仓库历史记录丢失

当本地仓库没有包含远程仓库所有的历史记录时,强制推送会导致远程仓库的历史记录丢失,产生不可逆的影响。

你可能感兴趣的:(Git 的基本使用)