開發經驗漫談 -- Git在開發流程中的運用
女主宣言
這幾期和大家分享下我自己在開發時的一些經驗,這次來說說關於Git在開發流程中的運用。
目的
保持提交歷史整潔,俗稱的一條線提交。
讓專案程式碼有跡可循,提供清晰的開發歷程,亦稱:取其精華,去其糟粕。
幫助大家養成好的程式碼開發習慣,即:如何更好地和他人合作。
提供一個思路,讓大家更深刻的理解git。
請先閱讀
如果你沒有接觸過git,請先閱讀:
必讀:
示例專案
我們使用一個簡單的專案作為示例來進行說明。
該系統由使用者管理模組和角色管理模組組成,該專案已經完成了角色模組的開發,現在在開發使用者模組。
開發流程
1 獲取專案程式碼
當前的提交歷史如下:
2 建立遠端合作分支
我們把這個分支命名為user_admin
操作完成後,提交歷史如下:
說明:合作開發user_admin模組的同學,會在這個分支上合併彼此的程式碼。
3 建立個人分支(真正的開發工作在這裡進行)
我們把這個分支命名為:user_admin_ligang
請注意:
此分支是在遠端合作分支(user_admin)的基礎上建立的。
此分支只可合併遠端合作分支,不可以直接合並master。
分支合併流程
假設在user_admin_ligang的個人分支中已經完成了開發,現在需要把這部分程式碼提交給被人使用,那麼請按照如下方式操作:
假設開發完成後的提交歷史如下:
第一步:整理個人開發分支中待合併的提交,去掉無用的,僅保留有用的
切到user_admin_ligang分支
查詢newbase
在這個清理過程中,我需要清理掉tmp1和tmp2這2個臨時提交,所以newbase就是init,這裡獲得它的版本號:
執行清理
這一步是不可逆的,請謹慎操作,亦可先備份。
這裡按照提示,我們編輯rebase資訊
儲存退出,由於上面我們告訴rebase我們要重新編輯提交資訊(r,reword),這裡會進入提交資訊編輯介面,我們修改最終提交資訊如下:
儲存退出,清理過程結束,這裡再次檢視提交歷史:
這裡可以看到,tmp1和tmp2已經被清理掉了,最終的done2是一個全新的提交。
第二步:合併個人分支到遠端合作分支
請確保此時只有你一個人操作遠端合作分支
更新本地遠端合作分支到最新
切到user_admin_ligang分支
衍合個人開發分支
(1)衍合前
(2)衍合
這裡有可能需要解決衝突,再continue完成整個衍合過程。
(3)衍合後
合併入遠端合作分支
合併後的提交歷史
刪除個人開發分支
合併到主幹
1.操作前確認
進行這一步操作前,請確認已經滿足如下條件:
請確認待合併的遠端合作分支上的開發目標已全部完成。
請確認即將把程式碼合併入主幹進行釋出上線。
如不能全部滿足上述所有條件,請不要進行此操作。
2.合併入主幹
請確保此時只有你一個人操作遠端分支及主幹
更新本地主幹到最新
切到user_admin分支
衍合遠端合作分支
這裡的過程和遠端合作分支衍合時是一樣的,有可能需要解決衝突,再continue完成整個衍合過程。
合併入主幹
刪除遠端合作分支
最終的提交歷史
HULK一線技術雜談
由360雲平臺團隊打造的技術分享公眾號,內容涉及雲端計算、資料庫、大資料、監控、泛前端、自動化測試等眾多技術領域,透過夯實的技術積累和豐富的一線實戰經驗,為你帶來最有料的技術分享
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31555491/viewspace-2221147/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 伺服器開發中網路資料分析與故障排查經驗漫談伺服器
- Android SDK 開發經驗淺談Android
- git合作開發流程Git
- 淺談前端業務開發中的經驗與感想前端
- 【git】前端使用git分支的開發流程Git前端
- git團隊開發流程Git
- 研發流程在敏捷開發中的詳解敏捷
- git新建分支進行開發的流程Git
- 淺談canvas在web開發中的應用與優化CanvasWeb優化
- SAP UI 和 Salesforce UI 開發漫談UISalesforce
- 必看!網際網路開發模式的經驗之談模式
- 開發十年經驗之談:如何構建自己的Java開發體系Java
- Laplace分佈運算元開發經驗分享
- 白話 Ruby 與 DSL 以及在 iOS 開發中的運用iOS
- Serverless 應用開發的 7 個經驗心得Server
- git的開發流程和常用命令Git
- [前端漫談]Git 在專案中的完全控制實踐前端Git
- 開發者談音效在遊戲中的8種基本應用遊戲
- 探討敏捷開發在軟體開發中的應用敏捷
- 開發中的一些經驗總結
- 我的軟體開發中經驗教訓
- 如何讓Git適應敏捷開發流程?Git敏捷
- Git多人專案開發流程演練Git
- Excel 匯入的開發經驗Excel
- 敏捷開發大家談(三)--敏捷開發技術在電子商務軟體中的應用(2)敏捷
- 貨運物流程式開發思路
- 獨立遊戲開發者的Kickstarter眾籌成功經驗談遊戲開發
- 一個破 1K Stars 的 side project 開發經驗談IDEProject
- 三年開發程式設計師的職場經驗談程式設計師
- 經驗分享:談談如何多快好省地開發獨立遊戲遊戲
- 淺談支付系統開發基本流程
- 小程式·雲開發 專案開發經驗分享
- Git多人協作開發流程分支管理方案Git
- 淺談設計模式在iOS開發實戰專案中的應用設計模式iOS
- 5 個 Git 工作流,改善你的開發流程Git
- Android開發經驗總結Android
- iOS開發經驗總結iOS
- 完美體驗!在小程式中用Git無縫管理版本開發!Git