這幾期和大家分享下我自己在開發(fā)時(shí)的一些經(jīng)驗(yàn),這次來說說關(guān)于Git在開發(fā)流程中的運(yùn)用把鉴。
目的
- 保持提交歷史整潔仆潮,俗稱的一條線提交宏蛉。
- 讓項(xiàng)目代碼有跡可循,提供清晰的開發(fā)歷程性置,亦稱:取其精華檐晕,去其糟粕。
- 幫助大家養(yǎng)成好的代碼開發(fā)習(xí)慣蚌讼,即:如何更好地和他人合作辟灰。
- 提供一個(gè)思路,讓大家更深刻的理解git篡石。
請(qǐng)先花時(shí)間閱讀
- 如果你沒有接觸過git芥喇,請(qǐng)先閱讀:http://git-scm.com/book/zh/v2
- 必讀:https://www.atlassian.com/git/tutorials/merging-vs-rebasing
示例系統(tǒng)
我們使用一個(gè)簡單的項(xiàng)目作為示例來進(jìn)行說明。
該系統(tǒng)由用戶管理模塊和角色管理模塊組成凰萨,該項(xiàng)目已經(jīng)完成了角色模塊的開發(fā)继控,現(xiàn)在在開發(fā)用戶模塊。
開發(fā)流程
第一步:獲取項(xiàng)目代碼
ligang@vm-xubuntu ~/devspace $ git clone /home/ligang/repository/gitflow.git
Cloning into gitflow...
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 6 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (6/6), done.
當(dāng)前的提交歷史如下:
創(chuàng)建遠(yuǎn)程合作分支
我們把這個(gè)分支命名為user_admin
ligang@vm-xubuntu ~/devspace/gitflow $ git push -u origin user_admin
Total 0 (delta 0), reused 0 (delta 0)
To /home/ligang/repository/gitflow.git
* [new branch] user_admin -> user_admin
Branch user_admin set up to track remote branch user_admin from origin.
操作完成后胖眷,提交歷史如下:
說明:合作開發(fā)user_admin模塊的同學(xué)武通,會(huì)在這個(gè)分支上合并彼此的代碼。
第三步:創(chuàng)建個(gè)人分支(真正的開發(fā)工作在這里進(jìn)行)
我們把這個(gè)分支命名為:user_admin_ligang
ligang@vm-xubuntu ~/devspace/gitflow $ git push -u origin user_admin_ligang
Total 0 (delta 0), reused 0 (delta 0)
To /home/ligang/repository/gitflow.git
* [new branch] user_admin_ligang -> user_admin_ligang
Branch user_admin_ligang set up to track remote branch user_admin_ligang from origin.
請(qǐng)注意:
- 此分支是在遠(yuǎn)程合作分支(user_admin)的基礎(chǔ)上創(chuàng)建的珊搀。
- 此分支只可合并遠(yuǎn)程合作分支冶忱,不可以直接合并master。
分支合并流程
假設(shè)在user_admin_ligang的個(gè)人分支中已經(jīng)完成了開發(fā)境析,現(xiàn)在需要把這部分代碼提交給被人使用囚枪,那么請(qǐng)按照如下方式操作:
假設(shè)開發(fā)完成后的提交歷史如下:
第一步:整理個(gè)人開發(fā)分支中待合并的提交,去掉無用的劳淆,僅保留有用的
- 切到user_admin_ligang分支
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin_ligang
ligang@vm-xubuntu ~/devspace/gitflow $ git branch
master
user_admin
* user_admin_ligang
ligang@vm-xubuntu ~/devspace/gitflow $
- 查找newbase
在這個(gè)清理過程中链沼,我需要清理掉tmp1和tmp2這2個(gè)臨時(shí)提交,所以newbase就是init沛鸵,這里獲得它的版本號(hào):
- 執(zhí)行清理
這一步是不可逆的括勺,請(qǐng)謹(jǐn)慎操作,亦可先備份。
這里按照提示疾捍,我們編輯rebase信息:
保存退出奈辰,由于上面我們告訴rebase我們要重新編輯提交信息(r,reword),這里會(huì)進(jìn)入提交信息編輯界面拾氓,我們修改最終提交信息如下:
保存退出冯挎,清理過程結(jié)束底哥,這里再次查看提交歷史:
這里可以看到咙鞍,tmp1和tmp2已經(jīng)被清理掉了,最終的done2是一個(gè)全新的提交趾徽。
第二步:合并個(gè)人分支到遠(yuǎn)程合作分支
請(qǐng)確保此時(shí)只有你一個(gè)人操作遠(yuǎn)程合作分支
- 更新本地遠(yuǎn)程合作分支到最新
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin
Switched to branch 'user_admin'
ligang@vm-xubuntu ~/devspace/gitflow $ git pull origin user_admin
From /home/ligang/repository/gitflow
* branch user_admin -> FETCH_HEAD
Already up to date.
- 切到user_admin_ligang分支
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin_ligang
Switched to branch 'user_admin_ligang'
- 衍合個(gè)人開發(fā)分支
衍合前
衍合
ligang@vm-xubuntu ~/devspace/gitflow $ git rebase user_admin
First, rewinding head to replay your work on top of it...
Applying: done2
Using index info to reconstruct a base tree...
M show.txt
Falling back to patching base and 3-way merge...
Auto-merging show.txt
CONFLICT (content): Merge conflict in show.txt
error: Failed to merge in the changes.
Patch failed at 0001 done2
Use 'git am --show-current-patch' to see the failed patch
Resolve all conflicts manually, mark them as resolved with
"git add/rm <conflicted_files>", then run "git rebase --continue".
You can instead skip this commit: run "git rebase --skip".
To abort and get back to the state before "git rebase", run "git rebase --abort".
這里有可能需要解決沖突续滋,再continue完成整個(gè)衍合過程。
衍合后
- 合并入遠(yuǎn)程合作分支
ligang@vm-xubuntu ~/devspace/gitflow $ git merge user_admin_ligang
Updating add0d89..9ed757b
Fast-forward
show.txt | 1 +
1 file changed, 1 insertion(+)
合并后的提交歷史
刪除個(gè)人開發(fā)分支
ligang@vm-xubuntu ~/devspace/gitflow $ git branch -d user_admin_ligang
Deleted branch user_admin_ligang (was 9ed757b).
ligang@vm-xubuntu ~/devspace/gitflow $ git push origin :user_admin_ligang
To /home/ligang/repository/gitflow.git
- [deleted] user_admin_ligang
合并到主干
操作前確認(rèn)
進(jìn)行這一步操作前孵奶,請(qǐng)確認(rèn)已經(jīng)滿足如下條件:
- 請(qǐng)確認(rèn)待合并的遠(yuǎn)程合作分支上的開發(fā)目標(biāo)已全部完成疲酌。
- 請(qǐng)確認(rèn)即將把代碼合并入主干進(jìn)行發(fā)布上線。
如不能全部滿足上述所有條件了袁,請(qǐng)不要進(jìn)行此操作朗恳。
合并入主干
請(qǐng)確保此時(shí)只有你一個(gè)人操作遠(yuǎn)程分支及主干
- 更新本地主干到最新
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout master
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
ligang@vm-xubuntu ~/devspace/gitflow $ git pull
Already up to date.
- 切到user_admin分支
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin
Switched to branch 'user_admin'
- 衍合遠(yuǎn)程合作分支
ligang@vm-xubuntu ~/devspace/gitflow $ git rebase master
Current branch user_admin is up to date.
這里的過程和遠(yuǎn)程合作分支衍合時(shí)是一樣的,有可能需要解決沖突载绿,再continue完成整個(gè)衍合過程粥诫。
- 合并入主干
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout master
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
ligang@vm-xubuntu ~/devspace/gitflow $ git merge user_admin
Updating 73180c1..9ed757b
Fast-forward
show.txt | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
- 刪除遠(yuǎn)程合作分支
ligang@vm-xubuntu ~/devspace/gitflow $ git branch -d user_admin
Deleted branch user_admin (was 9ed757b).
ligang@vm-xubuntu ~/devspace/gitflow $ git push origin :user_admin
To /home/ligang/repository/gitflow.git
- [deleted] user_admin