Git版本管理完全指南

第一部分 命令行

1、分支操作
1. git branch  创建分支
2. git checkout -b 创建并切换到新建的分支上
3. git checkout  切换分支
4. git branch 查看分支列表
5. git branch -v 查看所有分支的最后一次操作
6. git branch -vv 查看当前分支
7. git brabch -b 分支名 origin/分支名 创建远程分支到本地
8. git branch --merged 查看别的分支和当前分支合并过的分支
9. git branch --no-merged 查看未与当前分支合并的分支
10. git branch -d 分支名 删除本地分支
11. git branch -D 分支名 强行删除分支
12. git branch origin :分支名 删除远处仓库分支
13. git merge 分支名  合并分支到当前分支上
2、暂存操作
1. git stash 暂存当前修改
2. git stash apply 恢复最近的一次暂存
3. git stash pop 恢复暂存并删除暂存记录
4. git stash list 查看暂存列表
5. git stash drop 暂存名(例:stash@{0})  移除某次暂存
6. git stash clear 清除暂存
3、回退操作
1. git reset --hard HEAD^ 回退到上一个版本
2. git reset --hard ahdhs1(commit_id)  回退到某个版本
3. git checkout -- file撤销修改的文件(如果文件加入到了暂存区,则回退到暂存区的,如果文件加入到了版本库,则还原至加入版本库之后的状态)
4. git reset HEAD file  撤回暂存区的文件修改到工作区
4、标签操作
1. git tag 标签名 添加标签(默认对当前版本)
2. git tag 标签名 commit_id 对某一提交记录打标签
3. git tag -a 标签名 -m '描述'  创建新标签并增加备注
4. git tag 列出所有标签列表
5. git show 标签名  查看标签信息
6. git tag -d 标签名  删除本地标签
7. git push origin 标签名 推送标签到远程仓库
8. git push origin --tags 推送所有标签到远程仓库
9. git push origin :refs/tags/标签名  从远程仓库中删除标签
5、其它操作

常规操作

1. git push origin test 推送本地分支到远程仓库
2. git rm -r --cached 文件/文件夹名字 取消文件被版本控制
3. git reflog 获取执行过的命令
4. git log --graph 查看分支合并图
5. git merge --no-ff -m '合并描述' 分支名  不使用Fast forward方式合并,采用这种方式合并可以看到合并记录
6. git check-ignore -v 文件名  查看忽略规则
7. git add -f 文件名  强制将文件提交
8. git reflog 打印所有的日志,假如:ABC三个节点,回退到B后,仍旧打印所有日志

git创建项目仓库

1git init      初始化
2git remote add  origin  url 关联远程仓库
3git pull
4git fetch 获取远程仓库中所有的分支到本地

忽略已加入到版本库中的文件

1git update-index --assume-unchanged file 忽略单个文件
2git rm -r --cached 文件/文件夹名字  (. 忽略全部文件)

取消忽略文件

git update-index --no-assume-unchanged file

拉取、上传免密码

git config --global credential.helper store

第二部分 版本管理

GitFlow 是由 Vincent Driessen 提出的一个 git操作流程标准。包含如下几个关键分支:

1. master:主分支develop:主开发分支,包含确定即将发布的代码;
2. feature:新功能分支,一般一个新功能对应一个分支,对于功能的拆分需要比较合理,以避免一些后面不必要的代码冲突;
3. release:发布分支,发布时候用的分支,一般测试时候发现的 bug 在这个分支进行修复;
4. hotfix:热修复分支,紧急修 bug 的时候用。
GitFlow 的优势有如下几点:
1. 并行开发:GitFlow可以很方便的实现并行开发。每个新功能都会建立一个新的 feature分支,从而和已经完成的功能隔离开来,而且只有在新功能完成开发的情况下,其对应的 feature分支才会合并到主开发分支上(也就是我们经常说的develop分支)。另外,如果你正在开发某个功能,同时又有一个新的功能需要开发,你只需要提交当前 feature 的代码,然后创建另外一个feature 分支并完成新功能开发。然后再切回之前的 feature 分支即可继续完成之前功能的开发。
2. 协作开发:GitFlow 还支持多人协同开发,因为每个 feature 分支上改动的代码都只是为了让某个新的 feature 可以独立运行。同时我们也很容易知道每个人都在干啥。
3. 发布阶段:当一个新 feature 开发完成的时候,它会被合并到 develop 分支,这个分支主要用来暂时保存那些还没有发布的内容,所以如果需要再开发新的 feature,我们只需要从 develop 分支创建新分支,即可包含所有已经完成的 feature 
4. 支持紧急修复:GitFlow 还包含了 hotfix 分支。这种类型的分支是从某个已经发布的 tag 上创建出来并做一个紧急的修复,而且这个紧急修复只影响这个已经发布的 tag,而不会影响到你正在开发的新 feature

然后就是 GitFlow 最经典的几张流程图,一定要理解:

img

feature 分支都是从 develop 分支创建,完成后再合并到 develop 分支上,等待发布

img

当需要发布时,我们从 develop 分支创建一个 release 分支 然后这个 release 分支会发布到测试环境进行测试,如果发现问题就在这个分支直接进行修复。在所有问题修复之前,我们会不停的重复发布->测试->修复->重新发布->重新测试这个流程

img

发布结束后,这个release 分支会合并到 develop 和 master 分支,从而保证不会有代码丢失

img

master 分支只跟踪已经发布的代码,合并到 master 上的 commit 只能来自 release 分支和 hotfix 分支。 hotfix 分支的作用是紧急修复一些 Bug。它们都是从 master 分支上的某个 tag 建立,修复结束后再合并到 develop 和 master 分支上。

img

使用 过程中用到的基本命令:

git init //初始化
git add . //添加项目文件夹内的全部文件
git status //查看所在分支
git commit -m "描述" //设置快照,保存当前状态
gitee上新建一个项目,复制含.giturl
git remote add origin https(上面复制的url
git remote -v //查看远程url
git push origin master //推送分支到远程
//第一次使用还需要以下步骤:
git config --global user.name "你的昵称"//设置用户名
git config --global user.email "你的邮箱"//设置邮箱
//push之前需要登录gitee账号
git pull //从远程服务器拉取文件

git remote上传到远程代码库:第一次上传

1、初始化git版本库:git init

2、添加文件到本地库:git add .

3、提交文件到本地库:git commit -m "msg(提交日志)"

重要提示:23可合并(git commit -am ""

4、关联远程库:git remote add origin(可修改) branch_Name(为空时默认为master) url

关联之后可以用git remote -v 来检查是否关联成功

5、一般情况需要先pull一下:git pull origin master

一般情况下含有共同文件时需要执行 git merge origin/master --allow-unrelated-histories

这之后解决一下冲突

6push到远程库:git push -u origin master
7、设置快捷键:git config --global alisa.co checkout
[alias]
        br = branch
        c = commit
        co = checkout
        st = status
        us = reset HEAD
8、将本地的分支dev与远程绑定: git push --set-upstream origin dev
9、删除远程分支:git push origin :dev
或者 git push origin --delete dev
10、添加标签:git tag V1.0
或者:git tag -a V2.0 -m "V2.0 released"
11、将标签推送的远程:git push origin V1.0
12、将标签全部推送至远程:git push origin --tags
13、删除远程标签:git push origin :refs/tags/V2.0
或者:git push origin --delete tag V2.0
14、删除本地标签:git tag -d V2.0
15、清理远程已删除的分支:git remote prone origin
16、引入子模块:git submodule https://github.com/5616760/test.git mymodule
url对应的仓库克隆到mymodule目录
初始化子模块:git submodule init
更新子模块:git submodule update --recursive
17、删除子模块:删除缓存:git rm --cached mymodule\
删除本地文件:rm -rf mymodule\
提交修改:git c -am "del mymodule"
推送到远程:git push
18、使用subtree:增加远程库: git remote add subtree-origin git@github.com:5616760/git_subtree_child.git
下载远程库作为subtreegit subtree add --prefix=subtree subtree-origin master
更新subtreegit subtree pull --prefix=subtree subtree-origin master
parent更新childgit subtree push --prefix=subtree subtree-origin master

更多更完整的理解可参考如下链接

参考链接

【Git】工作中99%能用到的git命令

A successful Git branching model

使用Git必须要理解的GitFlow

Git 在团队中的最佳实践–如何正确使用Git Flow

深入理解学习GIT工作流

github translations 系列文章