版本控制是現今軟體開發大家都一定要會的技能,而 Git 更是目前的版本控制主流。
這場演講不教大家最基本的 Git 指令,而是分享大家最困擾的分支策略及存取模型,也會分享我們在多環境開發時的分支策略,更推薦大家如何利用 GitLab 來管理程式碼。也會分享如何利用 Redmine + Git 來管理 issue。最後也會加上如何用 SemVer 制定版號。
Git 易學難精,每個專案也都有自己不同的分支及存取策略。希望這場演講能讓大家在管理程式碼時更容易上手。
---
這是小編這兩天在 Devopsdays Taipei 分享的內容,東西有點多超時了 3 分鐘,不過重點算是都有講到了。尤其是這次分享了我們在 Qmi 上的 Git 工作流程,特色是有 server 分支給前端做測試用,小編目前看到的工作流程比較沒有這類形式。
其實在順第一版內容的時候超時了 20 分鐘,然後花了兩天一直刪一直刪,後來總算是勉強在時間範圍內。也是第一次小編嘗試使用手繪的方式來介紹,因為 Git 線圖實在找不到有什麼好工具可以用,於是就用新買的 Rocketbook 來畫。可是小編畫的圖歪七扭八,字也是醜到不行,所以只能請大家見諒了 Orz
Git for Teams 這本書內容真的不錯,每看一次都有新的體悟,歡迎大家去買本來讀讀。這次也認識了幾位新朋友 吳承翰 (ChengHan Wu) 跟 Achao Tsai,另外也歡迎大家多多參與 Git.tw 討論及 GHTUG 的聚會喔。
最後,Git 工作流程沒有誰對誰錯,只有適不適合而已,也歡迎大家分享自己的工作流程喔!
* Git.tw:https://www.facebook.com/groups/git.tw
* GHTUG:https://www.meetup.com/GitHub-Taipei-User-Group-GHTUG/
#gitforteams #git #gitlab #redmine #devopsdays
「semver github」的推薦目錄:
semver github 在 Kewang 的資訊進化論 Facebook 的精選貼文
小編上星期花了一點時間跟公司同事分享這幾年使用 Git 的經驗,其中也包含了 Git for Teams 的內容。如果你想要進一步改善 Git 工作流程的朋友,這本書真的是必備。
小編自己整理的內容還蠻多的,但有點可惜沒辦法包含所有常見的指令或情境,像是 rebase -i, stash, subtree, submodule 都沒提到,希望之後有機會再來重新整理一下。
## 簡易大綱
* 介紹四種權限模型
* rebase, merge, merge commit 的使用情境
* semver 的使用情境
* 與 redmine 的整合情境
* 外包使用情境
* 開所有權限的使用情境
* 合併時會發生衝突的原因
* reset, revert, checkout 等各種回復到特定點的使用情境
* cherry-pick 的使用情境
* gitignore 使用情境
* bisect, reflog 使用情境
* squash 使用情境
* ff 及 no-ff 的使用情境
* push -f 的使用情境
* 雲端 backend deployment 分享
#git #gitforteams #github #gitlab