Git是目前世界上最先进的分布式版本控制系统(没有之一)。版本控制系统就是可以记录每次文件改动的系统。版本控制系统目前分为两种,一种是集中式版本控制系统(cvs,svn),一种是分布式版本控制系统(git)。集中式版本管理系统的原理是将版本库存放到一台中央服务器上,到了要干活的时候,再从中央服务器上去取得最新的版本,干完活后,再将最新的版本推送给中央服务器。集中式版本控制系统最大的毛病是要联网才能工作,而分布式版本管理系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,多个人协作只要互相推送就好了,在实际使用分布式版本控制系统时,受网络影响,还是需要一台充当“中央服务器的电脑”,但这个服务器的作用仅仅是用来方便交换大家的修改,没有他大家也一样的干活,只是交换修改不方便而已。Git还有极其强大的分支管理,后面再说。
root@localhost$: git //尝试输入git,大部分Linux系统会友好的告诉你Git有没有安装以及怎么安装Git
也可通过源码安装,先从Git官网下载源代码,然后解压,依次输入:
./config
, make
, make install
。
两种方法:
下载msysgit,按默认选项安装即可。
安装完成后,在开始菜单里找到“Git”->“Git Bash”,蹦出一个类似命令行窗口的东西,就说明 Git
安装成功!
安装完成后,还需要最后一步设置,在命令行输入:
$ git config --global user.name "Your Name"
$ git config --global user.email "[email protected]"
版本库又名仓库,英文名 repository,你可以简单理解成一个目录,这个目录 里面的所有文件都可以被 Git
管理起来,每个文件的修改、删除,Git 都能跟踪,以便任何时刻都可以 追踪历史,或者在将来某个时刻可以“还原”。
git init
命令把这个目录变为Git可以管理的仓库。创建成功后会有一个隐藏的
.git
目录
git add xxx.txt
(单个文件)、git add .
(所有文件)git commit -m "注释内容"
第一步,把文件添加到仓库,第二步,把文件提交到仓库。commit可以一次提交很多文件。add可以多次添加不同文件。
git status
查看当前仓库状态
git diff
查看修改内容
git log
显示从最近到最远的提交日志
git reset --hard HEAD^
版本回退到上一个版本
git reset --hard HEAD^
回退到上上一个版本
git reset --hard commit id
回退到指定版本
git reflog
记录你的每一次命令
版本号没必要写全,Git会自动寻找,Git 的版本回退速度非常快,因为 Git 在内部有个指向当前版本的 HEAD 指针,当你回退版本的时候,Git 仅仅是把 HEAD 从指向 现在版本 改为指向 历史版本。
- HEAD 指向的版本就是当前版本,因此,Git 允许我们在版本的历史之间穿梭,使用命令
g it reset --hard commit_id
。- 穿梭前,用
git log
可以查看提交历史,以便确定要回退到哪个版本。- 要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。
就是你电脑里能看到的目录。
工作区有一个隐藏目录.git,这个不算工作区,而是 Git 的版本库。Git 的版本库里存了很多东西,其中最重要的就是称为 stage(或者叫 index)的暂存区,还有 Git 为我们自动创建的第一个分支master,以及指向 master 的一个指针叫 HEAD。
git add
实际上是将文件添加到暂存区。git commit
实际上是将暂存区的所有内容添加到当前分支。git checkout -- file
丢弃工作区的修改,回到最近一次 git commit 或 git add 时的状态。
git checkout -- file
命令中的–很重要,没有–,就变成了“创建一个新分支”的命令,我们在后
面的分支管理中会再次遇到git checkout
命令。
git checkout - file
。git reset HEAD file
,就回到了场景 1,第二步按场景 1 操作。假设你已经有了一个Gitee账号
参考Gitee提交提交第一行代码的示例:https://gitee.com/help/articles/4122
在git里主分支叫master,HEAD是指向master的,一开始的时候,master 分支是一条线,Git 用 master 指向最新的提交,再用 HEAD 指向 master,就能确定当前分支,以及当前分支的提交点。
每次提交,master 分支都会向前移动一步,这样,随着你不断提交,master 分支的线也越来越
长。当我们创建新的分支,例如 dev 时,Git 新建了一个指针叫 dev,指向 master 相同的提交,再把 HEAD 指向 dev,就表示当前分支在 dev 上。
合并分支其实就是将master指向dev的当前提交,从而完成合并。
合并完之后甚至可以删除dev分支,其实就是删除dev指针,从始至终,变得只有git的指针所指向的提交,所以git修改,删除,添加分支都非常快。
git checkout -b dev
创建dev分支并切换当前分支为dev
git checkout dev
切换当前分支为dev
git branch dev
创建dev分支
git branch
查看当前分支
git merge dev
用于合并指定分支到当前分支
git branch -d dev
删除dev分支
当 Git 无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
用git log --graph
命令可以看到分支合并图。
通常,合并分支时,如果可能,Git 会用 Fast forward 模式,但这种模式下,删除分支后,会丢掉
分支信息,如果要强制禁用 Fast forward 模式,Git 就会在 merge 时生成一个新的 commit,这样,从分支历史上就可以看出分支信息。
git merge --no-ff -m "merge with no-ff" dev
提交禁用 Fast forward策略
修复 bug 时,我们会通过创建新的 bug 分支进行修复,然后合并,最后删除。当手头工作没有完成时,先把工作现场
git stash
一下,然后去修复 bug,修复后,再git stash pop
,回到工作现场。
git stash
隐藏当前工作区工作
git stash list
查看隐藏工作区列表
git stash apply
恢复隐藏工作区工作但不删除隐藏工作区内容
git stash pop
恢复隐藏工作区工作同时删除内容
git remote -v
查看远程库消息
git push origin master
推送分支到远程库上的master分支
并不是每个分支都要往远程分支上推送的:
git push origin branch-name
,如果推送失败,先用 git pull
抓git checkout -b branch-name origin/branch-n ame
,本地和远程分支的名称最好一致。git branch --set-upstream branch-name origin/ branch-name
。Git 的标签虽然是版本库的快照,但其实它就是指向某个 commit 的指针(跟分支很像对不对?但
是分支可以移动,标签不能移动),所以,创建和删除标签都是瞬间完成的。
git tag v1.0
创建一个v1.0的标签
git tag
查看所有标签
默认标签是打在最新提交的 commit 上的。
如果忘记打标签了,怎么办?
方法是找到历史提交的 commit id,然后打上就可以了
git tag v0.9 6224937
在6224937的提交上添加标签
git show
查看标签信息
git tag -a v0.1 -m "version 0.1 released" 3628164
创建带有说明的标签,用-a 指定标签名,-m 指定说明文字
git tag -s v0.2 -m "signed version 0.2 released" fec145a
通过-s 用私钥签名一个标签
如果标签打错了,怎么办?
git tag -d v0.1
删除本地某个标签
因为创建的标签都只存储在本地,不会自动推送到远程。所以,打错的标签可以在本地安全删
除。
git push origin
推送某个标签到远程
git push origin --tags
一次性推送全部尚未推送到远程的本地标签
如果标签已经推送到远程,要删除远程标签就麻烦一点,先从本地删除
git tag -d v0.9
然后,从远程删除。删除命令也是 push,但是格式如下
git push origin :refs/tags/
删除一个远程标签
git config --global alias.st status
告诉 Git,以后 st 就表示 status:
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Crese t -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
查看提交日志的自定义配置。
在 Git 工作区的根目录下创建一个特殊的.gitignore 文件,然后把要忽略的文件名填进去,Git 就会自动忽略这些文件。
忽略文件的原则是: