GIT分支管理和常用命令
分支管理
分支管理
master 分支
不能往master 分支上提交代码,只能在该分支上进行代码合并操作,例如将其它分支的代码合并到 Master 分支上。
develop 分支
我们日常开发中的代码需要从 master 分支拉一条 develop 分支出来,该分支所有人都能访问,但一般情况下,我们也不会直接在该分支上提交代码,代码同样是从其它分支合并到 develop 分支上去。
feature 分支
当我们需要开发某个特性时,需要从 develop 分支拉出一条 feature 分支,例如 feature/update_mq 与 feature/update_netty,在这些分支上并行地开发具体特性。
release 分支
当特性开发完毕后,我们决定需要发布某个版本了,此时需要从 develop 分支上拉出一条 release 分支,例如 release-1.0.0,并将需要发布的特性从相关 feature 分支一同合并到 release 分支上,随后将针对 release 分支推送到测试环境,测试工程师在该分支上做功能测试,开发工程师在该分支上修改 bug。待测试工程师无法找到任何 bug 时,我们可将该 release 分支部署到预发环境,再次验证以后,均无任何 bug,此时可将 release 分支部署到生产环境。
tag
待上线完成后,将 release 分支上的代码同时合并到 develop 分支与 master 分支,并在 master 分支上打一个 tag,例如 v1.0.0。
hotfix
当生产环境发现 bug 时,我们需要从对应的 tag 上(例如 v1.0.0)拉出一条 hotfix 分支(例如 hotfix-1.0.1),并在该分支上做 bug 修复。待 bug 完全修复后,需将 hotfix 分支上的代码同时合并到 develop 分支与 master 分支。同时在master上打上tag,v1.0.1。
版本号
对于版本号我们也有要求,格式为:x.y.z,其中,x 用于有重大重构时才会更新,y 用于有新的特性发布时才会更新,z 用于修改了某个 bug 后才会更新。
个人分支
个人分支下可以建目录,例如: xiaoguai/dev1, xiaoguai/dev2
常用命令
git相关配置
# 安装完Git后第一件要做的事,设置客户信息(global可换成local在单独项目生效):git config --global user.name "客户名" # 设置客户名git config --global user.email "客户邮箱" #设置邮箱git config --global user.name # 查看客户名能否配置成功git config --global user.email # 查看邮箱能否配置# 其余查看配置相关git config --global --list # 查看全局设置相关参数列表git config --local --list # 查看本地设置相关参数列表git config --system --list # 查看系统配置参数列表git config --list # 查看所有Git的配置(全局+本地+系统)git config --global color.ui true //显示git相关颜色从远程仓库克隆项目到本地
git clone git@github.com:git帐号名/仓库名.git将文件增加到仓库
git add 文件名 # 将工作区的某个文件增加到暂存区 git add . # 将当前工作区的所有文件都加入暂存区将暂存区文件提交到本地仓库
git commit -m "提交说明" # 将暂存区内容提交到本地仓库git commit -a -m "提交说明" # 跳过缓存区操作,直接把工作区内容提交到本地仓库查看仓库当前状态
git status比较文件异同
git diff # 工作区与暂存区的差异git diff 分支名 #工作区与某分支的差异,远程分支这样写:remotes/origin/分支名git diff HEAD # 工作区与HEAD指针指向的内容差异git diff 提交id 文件路径 # 工作区某文件当前版本与历史版本的差异git diff --stage # 工作区文件与上次提交的差异git diff 版本TAG # 查看从某个版本后都改动内容git diff 分支A 分支B # 比较从分支A和分支B的差异(也支持比较两个TAG)git diff 分支A...分支B # 比较两分支在分开后各自的改动查看历史记录
git log # 查看所有commit记录(SHA-A校验和,作者名称,邮箱,提交时间,提交说明)git log -p -次数 # 查看最近多少次的提交记录git log fileName # 查看某文件的修改记录,找背锅专用代码回滚
git reset HEAD^ # 恢复成上次提交的版本git reset HEAD^^ # 恢复成上上次提交的版本,就是多个^,以此类推或者用~次数同步远程仓库
git push -u origin master删除版本库文件
git rm 文件名创立分支
git checkout -b dev-b表示创立并切换分支上面一条命令相当于一面的二条:git branch dev # 创立分支git checkout dev # 切换分支查看分支
git branch合并分支
git merge dev # 用于合并指定分支到当前分支git merge --no-ff -m "merge with no-ff" dev# 加上--no-ff参数即可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并尽量使用rebase代替merge,好处主要有两个:1)rebase操作可以把本地未push的分叉提交历史整理成直线;2)rebase的目的是使得我们在查看历史提交的变化时更容易,由于分叉的提交需要三方比照。删除分支
git branch -d dev查看分支合并图
git log --graph --pretty=oneline --abbrev-commit查看远程库信息
git remote # -v 显示更详细的信息撤消某次提交
git revert HEAD # 撤销最近的一个提交git revert 版本号 # 撤销某次commit拉取远程分支到本地仓库
git checkout -b 本地分支 远程分支 # 会在本地新建分支,并自动切换到该分支git fetch origin 远程分支:本地分支 # 会在本地新建分支,但不会自动切换,还需checkoutgit branch --set-upstream 本地分支 远程分支 # 建立本地分支与远程分支的链接标签命令
git tag 标签 # 打标签命令,默认为HEADgit tag # 显示所有标签git tag 标签 版本号 # 给某个commit版本增加标签git show 标签 # 显示某个标签的详细信息同步远程仓库升级
git fetch origin master # 从远程获取最新的到本地,首先从远程的origin的master主分支下载最新的版本到origin/master分支上,而后比较本地的master分支和origin/master分支的差别,最后进行合并。git fetch比git pull更加安全尽量不要用命令(也看个人习惯)
1)IntelliJ IDEA下配置git
2)Sourcetree 可简化您与 Mercurial 和 Git 存储库的交互,让您集中精力编写代码。通过 Sourcetree 简单的 Git 图形客户界面查看和管理您的存储库。
上一篇 目录 已是最后
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » GIT分支管理和常用命令