假设:
本地分支为release_v1.0,远程分支为master
常用命令与操作说明
1.查看分支
git branch #查看本地分支
git branch -r #查看远程分支
git branch -a #查看本地和远程分支
2.查看当前分支状态
git status
查看分支日志记录
git log
新建分支
git checkout -b release_v1.0 #创建本地分支
git checkout -b release_v1.0 origin/master #基于master分支创建本地分支
分支切换
git checkout master #切换到master分支
分支删除
git branch -D 分支名称 #删除本地分支
git push origin --delete 分支名称 #删除远程分支
合并分支
#当前所在分支为release_v1.0
git merge master #将master分支的内容合并到release_v1.0分支
向远程分支推送代码
git push -u origin 分支名称 #首次推送代码
git push
同步远程分支到本地
git fetch #同步所有远程分支到本地
git fetch origin 远程分支名称 #同步远程某个分支到本地
回退
假设当前在commit_2
git reset --hard commit_id
#执行步骤
#1、git log 查看之前提交的历史 找到commit_1
#2、git reset --hard commit_1 回退到commit_1
#3、git reflog #如果想再次回到commit_2中,执行reflog找到commit_2的id,然后执行reset即可
克隆远程仓库
git clone 远程仓库的地址
其他
#给远程仓库起别名
Git remote add origin 远程仓库地址
新增文件操作步骤
git add readme.md #git add是把代码提交到暂存区
git commit -m "“备注信息” # git commit是把代码提交到本地仓库
git push -u origin/git push 分支名称 # 将代码提交到远程仓库
Git Flow 多人合作模式
在使用Git的过程中如果没有清晰流程和规划,否则,每个人都提交一堆杂乱无章的commit,项目很快就会变得难以协调和维护。
Git版本管理同样需要一个清晰的流程和规范。
Vincent Driessen 为了解决这个问题提出了 A Successful Git Branching Model。
测试环境用公共的分支:
#假设:master是主分支,dev是公共分支,a是自己的分支
git fetch dev #本地没有dev分支的话,需要先checkout一下远程分支
git pull #本地已经有dev分支的话,直接pull一下最新代码
git checkout -b a dev #在dev分值基础上创建a分支
git add 文件名 #建议每次只添加一个文件,使得后续commit说明清楚明白
git commit -m "提交说明"
git push -u origin a
#合并代码,这步可以在gitlab页面上进行操作,也可以直接切到dev分支进行操作。
git checkout dev #切换到dev分支,然后进行代码合并
git merge a
git push origin dev
参考:https://www.jianshu.com/p/41910dc6ef29