什么是Git?
- Git 是一个分布式版本控制系统,用于高效跟踪文件变更,支持多人协作开发,管理代码历史,并允许回溯、分支合并等操作。
- 对于软件开发人员来说,Git最重要的就是可以帮我们管理软件开发项目中的源代码文件
Git的安装
CentOS环境下的安装
-
首先查看自己的环境中有没有装git,在终端输入命令
git --version
- 如果没有出现下图的内容,说明你的环境里没有安装git
-
输入命令安装git
sudo yum -y install git
-
查看是否安装成功
git --version
Ubuntu环境下的安装
-
首先查看自己的环境中有没有装git,在终端输入命令
git --version
- 跟在CentOS下一样,看是否出现了版本号,否则说明没有安装git
-
输入命令安装git
sudo apt-get install git -y
-
检查是否安装成功
git --version
Git的基本操作
创建Git本地仓库
-
创建Git本地仓库的命令为
git init
-
创建完之后,当前目录会出现一个.git目录
-
-
.git ⽬录是 Git 来跟踪管理仓库的,不要⼿动修改这个⽬录⾥⾯的⽂件!!!不然改乱了,就把 Git 仓库给破坏了
-
配置Git
-
在安装完Git之后,首先要做的事情就是配置你的用户名称与e-mail地址
-
配置用户名称
git config [--global] user.name "Your Name"//将Your Name换成你自己的用户名
-
配置邮箱
git config [--global] user.email "email@example.com"//将email@example.com换成你自己的邮箱
- 其中[–global]选项是一个可选项,使用这个选项会使得这台机器上所有的Git仓库都会使用这个配置,也就是每当你在这台机器上创建Git仓库时,都会自动使用这个配置
-
查看配置的命令
git config -l
-
删除配置的命令(使用–unset选项)
git config [--global] --unset user.name git config [--global] --unset user.email
认识git中的工作区、暂存区、版本库
工作区、暂存区、版本库的概念
-
⼯作区:是在电脑上你要写代码或⽂件的⽬录。
-
暂存区:英⽂叫 stage 或 index。⼀般存放在 .git ⽬录下的 index ⽂件(.git/index)中,我们把暂存区有时也叫作索引(index)。
-
版本库⼜名仓库,英⽂名 repository 。⼯作区有⼀个隐藏⽬录 .git ,它不算⼯作区,⽽是 Git 的版本库。这个版本库⾥⾯的所有⽂件都可以被 Git 管理起来,每个⽂件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”
工作区、暂存区、版本库之间的关系图
-
图中左侧为⼯作区,右侧为版本库。Git 的版本库⾥存了很多东西,其中最重要的就是暂存区。在创建 Git 版本库时,Git 会为我们⾃动创建⼀个唯⼀的 master 分⽀,以及指向 master 的⼀个指针叫 HEAD。
-
当对⼯作区修改(或新增)的⽂件执⾏ git add 命令时,暂存区⽬录树的⽂件索引会被更新。当执⾏提交操作 git commit 时,master 分⽀会做相应的更新,可以简单理解为暂存区的⽬录树才会被真正写到版本库中
如何将文件添加到git仓库中进行管理?
-
通过新建或粘贴进⽬录的⽂件,并不能称之为向仓库中新增⽂件,⽽只是在⼯作区新增了⽂件。必须要通过使⽤ git add 和 git commit 命令才能将⽂件添加到仓库中进⾏管理!!!
-
git add命令的用法
-
添加⼀个或多个⽂件到暂存区:
git add [file1] [file2] ...
-
添加指定⽬录到暂存区,包括⼦⽬录: git add [dir]
git add [dir]
-
添加当前⽬录下的所有⽂件改动到暂存区: git add .
git add .
-
-
git commit命令的用法
-
提交暂存区全部内容到本地仓库中:
git commit -m "message"
-
提交暂存区的指定⽂件到仓库区:
git commit [file1] [file2] ... -m "message
-
注意 git commit 后⾯的 -m 选项,要跟上描述本次提交的 message,由⽤⼾⾃⼰完成,这部分内容绝对不能省略,并要好好描述,是⽤来记录你的提交细节,是给我们⼈看的,否则你不知道你的这次提交修改了一些什么代码
-
如何使用查看不同区中文件的差异?
-
在有些时候,我们可能会忘记自己现在写的文件跟之前推送到暂存区文件变化了什么、变化了多少,于是我们需要查看
-
使用git diff命令,来查看不同区之间的文件差异
git diff [file]//查看暂存区与工作区文件的差异 git diff HEAD -- [file]//查看版本库和⼯作区⽂件的区别
如何进行版本回退?
-
之前我们也提到过,Git 能够管理⽂件的历史版本,这也是版本控制器重要的能⼒。如果有⼀天你发现之前做的⼯作做的出现了很⼤的问题,需要在某个特定的历史版本重新开始,这个时候,就需要版本回退的功能了
使用git reset命令进行版本回退
git reset [--soft | --mixed | --hard] [HEAD]
- –mixed 为默认选项,使⽤时可以不⽤带该参数。该参数将暂存区的内容退回为指定提交版本内容,⼯作区⽂件保持不变。
- –soft 参数对于⼯作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。
- –hard 参数将暂存区与⼯作区都退回到指定版本。切记⼯作区有未提交的代码时不要⽤这个命令,因为⼯作区会回滚,你没有提交的代码就再也找不回了,所以使⽤该参数前⼀定要慎重
- 对于HEAD参数的说明:
- 可直接写成 commit id,表⽰指定退回的版本
- HEAD 表⽰当前版本
- HEAD^ 表示上⼀个版本
- HEAD^^ 表示上上个版本,以此类推…
- 同时,还能用~加数字表示
- HEAD~0 表示当前版本
- HEAD~1表示上一个版本
- HEAD~2表示上上个版本
使用git checkout --来回退没有add的工作区代码
-
如果我们在工作区写的代码一直没有add,也就是说在暂存区和版本库中都没有我们新写的代码,但在工作区中我们一直在新加内容,写到后面发现写不下去了,该如何进行版本回退呢?
-
使用下面的命令来让工作区的文件回倒最近一次add或者commit时的状态
git checkout -- [file]//注意“--”十分重要,不能省略,如果省略,命令的意思就变了
如何删除Git仓库中的文件?
-
使用git rm命令
git rm [filename]
如何使用Git进行分支管理?
对分支的理解
-
分支相当于科幻电影中的平行宇宙,你可以在同一时间,学习C++和JAVA。也就是说,创建分支,相当于创建了一个分身,并行着完成任务
创建分支
-
查看当前本地所有分支
git branch
-
新建分支
git branch 分支名
切换分支
-
我们创建了分支之后,可以使用git checkout 命令完成切换分支的操作
git checkout 分支名
合并分支
-
在对分支的理解里面讲了,我们创建分支是为了创建一个分身,帮助我们在同一时间内,做更多的事、学更多的东西,但是在各个分支中,我们所做、所学的东西是独立的、分开的,这就需要我们将分支合并了
-
使用 git merge命令合并分支
git merge 分支名
合并冲突
-
在实际分支合并的时候,并不是执行合并命令就一定能能成功的,有的时候会遇到代码冲突问题
-
当发生下图所示的情况时,就会发生合并冲突
- 在master分支上的倒数第二次提交上,我们创建了分支dev,用来增加一些功能,但同时,你的一个同事直接在master上又增加了一个新功能,这就导致dev分支上的master状态与master分支上的master状态不一致,于是便会合并冲突
查看分支合并的过程
-
使用git log命令查看分支合并的过程
git log --graph --pretty=oneline --abbrev-commit
-
删除分支
-
在合并完成后,被合并的分支就没有存在的意义了,这就需要删除分支了
-
使用git branch删除分支
git branch -d 分支名
-
注意:当我们要删除一个分支时,不能处于要删除的分支下。也就是说要删除A分支,我们需要切换到除A之外的分支上,才能进行删除
分支管理策略
-
通常合并分⽀时,如果可能,Git 会采⽤ Fast forward 模式,但是在这种 Fast forward 模式下,删除分⽀后,查看分⽀历史时,会丢掉分⽀信息,看不出来最新提交到底是 merge 进来的还是正常提交的
-
为了解决上述问题,Git ⽀持我们强制禁⽤ Fast forward 模式,那么就会在 merge 时⽣成⼀个新的 commit ,这样我们就可以从分⽀历史上看出分⽀信息
git merge --no-ff -m "merge with no-ff" 分支名
- 在git merge 命令中加上–no-ff便可以禁用Fast forward 模式
删除临时分支
-
上文提到的“删除分支”,是在分支已经合并之后,我们才能使用git branch -d 命令删除分支。那要是我们的分支在合并之前就要删除呢?
-
使用下面的命令来强制删除分支
git branch -D 分支名
Git的远程操作
- 在此节之前我们介绍的都是在本地上操作Git,但在实际工作中,我们需要将我们的代码推送至远程仓库
新建远程仓库
-
打开github
https://github.com/
-
注册并登录
-
新建仓库
-
选好我们需要的选项
- README文件相当于你这个仓库的简历
- .gitignore文件使用来屏蔽你不希望上传的文件用的,如数据库配置文件(里面你数据库密码等隐私信息)
- 你可以选择你喜欢的开源许可证
- 创建完的仓库模样
克隆远程仓库
-
使用git clone命令来将远程仓库克隆到本地
git clone 你的远端仓库链接
-
远程仓库链接可以在下图所示找到
将本地代码推送至远程仓库
-
使用git push命令
git push <远程主机名> <本地分⽀名>:<远程分⽀名> //如果本地分支名与远程分支名相同,则可以省略冒号 git push <远程主机名> <本地分⽀名>
拉取远程仓库
-
当远程仓库的版本领先于本地仓库版本时,为了使本地仓库保持最新的版本,我们需要拉取下远端代码,并合并到本地
-
使用git pull命令
git pull <远程主机名> <远程分⽀名>:<本地分⽀名>
# 如果远程分⽀是与当前分⽀合并,则冒号后⾯的部分可以省略。
git pull <远程主机名> <远程分⽀名>
标签管理
标签的理解
- 标签 tag ,可以简单的理解为是对某次 commit 的⼀个标识,相当于起了⼀个别名。例如,在项⽬发布某个版本的时候,针对最后⼀次 commit 起⼀个 v1.0 这样的标签来标识⾥程碑的意义。
创建标签
-
首先切换到需要打标签的分支上
git checkout 分支名
-
使用git tag命令
git tag v1.0
查看标签信息
-
使用git show命令
git show 标签名
删除标签
-
使用git tag -d命令
git tag -d 要删除的标签名
将本地标签推送至远程
-
使用git push命令
git push origin 标签名
一个比较好的分支模型
。例如,在项⽬发布某个版本的时候,针对最后⼀次 commit 起⼀个 v1.0 这样的标签来标识⾥程碑的意义。
创建标签
-
首先切换到需要打标签的分支上
git checkout 分支名
-
使用git tag命令
git tag v1.0
查看标签信息
-
使用git show命令
git show 标签名
删除标签
-
使用git tag -d命令
git tag -d 要删除的标签名
将本地标签推送至远程
-
使用git push命令
git push origin 标签名