Git教程:廖雪峰的官方网站
Git简介
Git是目前世界上最先进的分布式版本控制系统集中式 VS 分布式,SVN VS Git
SVN 和 Git 主要的区别在于历史版本维护的位置;Git 本地仓库包含代码库还有历史库,在本地的环境开发就可以记录历史而 SVN 的历史库存在于中央仓库,每次对比与提交代码都必须连接到中央仓库才能进行;这样的好处在于:
自己可以在脱机环境查看开发的版本历史。多人开发时如果充当中央仓库的 Git 仓库挂了,可以随时创建一个新的中央仓库然后同步就立刻恢复了中央库。
创建版本库
初始化一个Git仓库,使用git init命令添加文件到Git仓库,分两步:
使用命令git add ‘’ or git add . 一键添加用命令git commit -m ‘’,完成
时光机穿梭
要随时掌握工作区的状态,使用git status命令如果git status告诉你有文件被修改过,用git diff可以查看修改内容
版本回退
HEAD指向的版本就是当前版本Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本
工作区和暂存区
Working Directory and Repository
管理修改
git add 实际上是把文件添加到暂存区git commit 实际上是把暂存区的所有内容提交到当前分支每次修改,如果不用git add到暂存区,那就不会加入到commit中
撤销修改
当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,用命令git reset HEAD ‘’,就回到了上一步已经提交了不合适的修改到版本库时,想要撤销本次提交,参考’‘版本回退’’,不过前提是没有推送到远程库删除文件命令git rm用于删除一个文件如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容
远程仓库
添加远程库
要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git关联后,使用命令git push -u origin master第一次推送master分支的所有内容此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在,也就是有没有联网都可以正常工作
从远程库克隆
要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆Git支持多种协议,包括https,但ssh协议速度最快
分支管理
创建与合并分支
查看分支:git branch创建分支:git branch 切换分支:git checkout 或者git switch 创建+切换分支:git checkout -b 或者git switch -c 合并某分支到当前分支:git merge 删除分支:git branch -d
解决冲突
当Git无法自动合并分支时,就必须首先解决冲突解决冲突后,再提交,合并完成解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交用git log --graph命令可以看到分支合并图
分支管理策略
合并分支时,加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并fast forward合并就看不出来曾经做过合并。
Bug分支
修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug修复后,再git stash pop,回到工作现场在master分支上修复的bug,想要合并到当前dev分支,可以用git cherry-pick 命令,把bug提交的修改“复制”到当前分支,避免重复劳动
Feature分支
开发一个新feature,最好新建一个分支如果要丢弃一个没有被合并过的分支,可以通过git branch -D 强行删除
多人协作
查看远程库信息,使用git remote -v本地新建的分支如果不推送到远程,对其他人就是不可见的从本地推送分支,使用git push origin branch-name如果推送失败,先用git pull抓取远程的新提交在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name本地和远程分支的名称最好一致建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name从远程抓取分支,使用git pull,如果有冲突,要先处理冲突
Rebase
rebase操作可以把本地未push的分叉提交历史整理成直线rebase的目的是使得我们在查看历史提交的变化时更容易,因为分叉的提交需要三方对比。
标签管理
创建标签
命令git tag 用于新建一个标签,默认为HEAD,也可以指定一个commit id命令git tag -a -m "blablabla…"可以指定标签信息命令git tag可以查看所有标签。
操作标签
命令git push origin 可以推送一个本地标签命令git push origin --tags可以推送全部未推送过的本地标签命令git tag -d 可以删除一个本地标签命令git push origin :refs/tags/可以删除一个远程标签
自定义Git
忽略特殊文件
忽略某些文件时,需要编写.gitignore.gitignore文件本身要放到版本库里,并且可以对.gitignore做版本管理gitgonore
配置别名
$ git config --global alias.st status配置Git的时候,加上–global是针对当前用户起作用的;如果不加,那只针对当前的仓库起作用每个仓库的Git配置文件都放在.git/config文件中
搭建Git服务器
要方便管理公钥,用Gitosis要像SVN那样变态地控制权限,用Gitolite
Git官方网站:Git 官方
Git cheatsheet
{% pdf git-sheet.pdf %}