正确使用git避免提交冲突

简介: 前几年自己用过一段时间的git(原来是使用bzr,后来换成git),都是当作个人代码备份工具,没有涉及多人提交代码到中央版本库。 两个月前,我们把原来的svn版本管理换成了git,这两天提交版本时遇到许多问题,上网找些资料看,才发现用法不对,集体使用时,不能简单地再延续原来个人使用时的习惯。

前几年自己用过一段时间的git(原来是使用bzr,后来换成git),都是当作个人代码备份工具,没有涉及多人提交代码到中央版本库。

两个月前,我们把原来的svn版本管理换成了git,这两天提交版本时遇到许多问题,上网找些资料看,才发现用法不对,集体使用时,不能简单地再延续原来个人使用时的习惯。

 

背景啰嗦完了,现在进入正题:如何提交避免版本冲突。

 

  • 首先在本地按方法1 clone 回来之后,只有一个默认分支master,不要直接在上面工作。

建立一个自己的分支,如取名working: git branch working

切换到这个新分支: git checkout working

现在可以自由修改代码并保存了。

  • 确保你修改的代码都是自己负责项目下,或者说你的两次提交之间,没有其他人来改相同项目下的代码,

如果不能避免,你就要在下面的merge步骤手工处理冲突了。

  • 提交代码时按下面的步骤:

可以将下面的脚本保存在你的每个项目之下,每次只修改提交一个项目。

 

 

git checkout working    --force  #确保使用的是工作分支
git add .
git commit -m"$1" -a     #提交代码到本地,工作分支增加一个版本,这里的$1是运行脚本的第一个参数

git checkout master      
git pull origin master   #切换回默认分支,并将默认分支和中央最新版本合并
git merge working        #在本地合并你的这次修改到默认分支
git push origin master   #提交到中央版本库,接下来还是要切换回工作分支的
git checkout working   --force

 

如果不小心动了生产环境(就是只从中央版本库pull到本地)的文件,只好将本地版本退回一个,再从中央代码库pull代码合并。

 

git reset --hard HEAD
目录
相关文章
|
持续交付 开发工具 git
如何保留原提交记录迁移Git项目,你还不知道吗?
如何保留原提交记录迁移Git项目,你还不知道吗?
如何保留原提交记录迁移Git项目,你还不知道吗?
|
开发工具 git
Git分支--合并分支(冲突合并)
Git分支--合并分支(冲突合并)
231 1
Git分支--合并分支(冲突合并)
|
Shell 开发工具 git
Git基础使用-如何用Git把代码提交至仓库/新建仓库/同步代码/推送代码
Git基础使用-如何用Git把代码提交至仓库/新建仓库/同步代码/推送代码
532 0
|
开发工具 git
Git冲突:# If this is not correct, please remove the file # .git/MERGE_HEAD
Git冲突:# If this is not correct, please remove the file # .git/MERGE_HEAD
116 0
Git冲突:# If this is not correct, please remove the file # .git/MERGE_HEAD
|
Shell 开发工具 数据安全/隐私保护
Git提交之后自动打版本并钉钉通知
Git提交之后自动打版本并钉钉通知
446 0
Git提交之后自动打版本并钉钉通知
|
开发工具 git
phpstrom git 修改文件就提交方法
phpstrom git 修改文件就提交方法
88 0
phpstrom git 修改文件就提交方法
|
数据可视化 Java 数据库连接
忽略不想提交的文件- 每天三分钟玩转Git(10)大结局
忽略不想提交的文件- 每天三分钟玩转Git(10)大结局
忽略不想提交的文件- 每天三分钟玩转Git(10)大结局
|
数据可视化 开发工具 git
漏提交与打tag- 每天三分钟玩转Git(9)
漏提交与打tag- 每天三分钟玩转Git(9)
漏提交与打tag- 每天三分钟玩转Git(9)
|
开发工具 git
撤销远程提交-每天三分钟玩转Git (6)
撤销远程提交-每天三分钟玩转Git (6)
撤销远程提交-每天三分钟玩转Git (6)
|
安全 开发工具 git
撤销本地提交-每天三分钟玩转Git (5)
撤销本地提交-每天三分钟玩转Git (5)
撤销本地提交-每天三分钟玩转Git (5)