跳到主要內容

How to maintain your project source code in GitHub with collaborative development?


一個人的江湖很孤獨
一個人的江湖是孤獨的,寫程式也是,雖然很多高手都是一個人,但是如果能集合多人的力量不是更好嗎?高手難求,但是一個好的團隊卻是可以培養出來的,加入一個好的團隊,大家努力往前爬,不也是一種幸福嗎?
所以,這篇文章就是要說明如何與團隊協同開發系統,協同開發的流程會是怎麼樣子來進行呢?

組織( Organization)
開發團隊或稱為專案團隊,可以視為一個組織,在組織中有許多角色,有專案管理者、程式開發人員.....等,在GitHub中將專案管理者視為專案擁有者(Owner),其他專案開發者(Member),下圖描述說明:組織(organization)名稱為Org X,其中Mark為專案管理者(owner)、Jimmy與Bill都是程式開發人員(member)。


在這個組織中主要維運一個專案(repo_abc),為Jimmy,Bill和Mark共同維護,接下來就以Jimmy觀點來看他怎麼進行維護專案.



Step1) 同步
當有需求需要進行程式修改時,先要進行程式碼同步,把OrgX上repo_abc/master最新程式碼抓下來.
$ git fetch
remote: Enumerating objects: 9, done.
remote: Counting objects: 100% (9/9), done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 5 (delta 2), reused 3 (delta 1), pack-reused 0
Unpacking objects: 100% (5/5), done.
From https://github.com/Org_x/repo_abc
e795431..d4468d5 master -> origin/master

Step2) 同步再上傳
當完成修改準備要push程式碼到Jimmy的GitHub/repo_abc時,記得先再同步一次,確定沒問題再push.
$ git add .
$ git commit -m "mark PENDING: Not yet implemented"
$ git fetch
$ git rebase Jimmy_github/Jimmy_branch
看一下remote
$ git remote -v
origin https://github.com/Org_x/repo_abc.git (fetch)
origin https://github.com/Org_x/repo_abc.git (push)
Jimmy_github https://github.com/Jimmy/repo_abc.git (fetch)
Jimmy_github https://github.com/Jimmy/repo_abc.git (push)
現在才push上去
$ git push Jimmy_github HEAD:master
Counting objects: 5, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (5/5), 450 bytes | 450.00 KiB/s, done.
Total 5 (delta 3), reused 0 (delta 0)
remote: Resolving deltas: 100% (3/3), completed with 3 local objects.
To https://github.com/Jimmy/repo_abc.git
687a0ea..011b1f5 HEAD -> master


Step3) 在Jimmy GitHub上發Pull request
在Jimmy GitHub上發Pull request時,系統很聰明的會發現這個repo_abc是從Org_X/repo_abc上Fork出來的,所以就會問你是否要發Pull request 希望merge回Org_X/repo_abc專案?




Step4) Owner進行code review
當Mark收到e-mail通知時,就可以進Org_X/repo_abc進行code review.

Step5) Approve -> Merge進Org_X/repo_abc
最後如果同意了(Approve)就會跳出merge按鈕,按下後就會merge進Org_X/repo_abc,完成一個程式發布程序.

留言

這個網誌中的熱門文章

利用保存屬性來做實體檔案的差異性備份

先來談談iwndows裡檔案的保存屬性 利用滑鼠右鍵點選[內容]查看檔案的屬性時,在屬性可以看到[唯讀][隱藏]之外還可以點選[進階]按鈕, 其中「檔案已經可以開始封存」就是以前看到的「保存」屬性。 如果在DOS環境下指令attrib,檔名的前面出現「A」就是有「保存」屬性。 而「保存」屬性出現的時機是: 1. 檔案新建立 2. 檔案被變更過內容 因此系統給予此檔案A屬性,就等於告訴備份指令XCOPY或備份軟體,這個檔案需要被備份。 所以,我們可以透過這個屬性來進行檔案的增量式(Incremental)備份與差異式(Differential)備份。 將Files底下所有有異動過的檔案,複製到diff資料夾底下,並且取消此檔案的A屬性。 xcopy "C:\Files\*.*" c:\diff /s/d/y/M 如果我們在這個異動之後將diff資料夾內的所有東西都搬走,我們做的就是差異性備份,如果不搬走讓他一直累積就是增量式備份。 XCOPY 指令 XCOPY source [destination] [/A | /M] [/D[:date]] [/P] [/S [/E]] [/V] [/W] [/C] [/I] [/Q] [/F] [/L] [/G] [/H] [/R] [/T] [/U] [/K] [/N] [/O] [/X] [/Y] [/-Y] [/Z]\r\r [/EXCLUDE:file1[+file2][+file3]...] source 指定要複製的檔案。 destination 指定位置或者/以及新檔案的名稱。 /A 只複製設定成保存屬性的檔案,不要改變屬性的設定。 /M 只複製設定成保存屬性的檔案,並清除保存屬性。 /D:m-d-y 複製在指定日期當天或之後發生變更的檔案。如果沒有給日期, 只複製那些來源檔案日期比目的檔案日期為新的檔案。 /EXCLUDE:file1[+file2][+file3]... 指定檔案清單字串。每個...

系統時間自動校正

在網域內通常為了安全性會防堵所有對外不必要的端口,因此常會在網域內架設一Time Server做為各伺服器時間校對的標準,而此一Time Server需透過UDP 123端口與中央標準局time.stdtime.gov.tw做時間校對,再網域內的其他伺服器則與此Time Server做時間校對。 開啟防火牆NTP端口(UDP 123) 編輯系統登錄檔 [執行] -> regedit 修改NTP Server為中央標準局主機 time.stdtime.gov.tw 並將Type預設值NT5DS改為NTP [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\Parameters] "NtpServer"="ComputerName" "Type"="NTP" 修改校對頻率為a (每10分鐘校對一次,5為每5分鐘校對一次) [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\Config] "AnnounceFlags"=dword:0000000a 重啟Windows Time Service net stop w32time && net start w32time 強制立即校對 w32tm /resync /rediscover 補充一: 強制時間同步指令 w32tm /resync /computer:IP /rediscover net time \IP /set /yes net time \\ComputerName /set /yes 若您的主機一直無法同步,也可以採用變通的方法,配合上面的Dos command以工作排程來進行。 補充二: A. 將伺服器類型變更為 NTP。如果要執行這項操作,請依照下列步驟執行: 1. 按一下 [開始],再按一下 [執行],輸入 regedit,然後按一下 [確定]。 2. 找出並按一下下列登錄子機碼: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\Parameters\Ty...

MHT檔匯出內嵌圖片

今天一個朋友跑來找我說幫幫忙,她在一個網站上想要把網頁上的圖片存下來。我:「在圖片上按滑鼠右鍵不就可以下載了嗎?」 朋友說:「不行,很怪說…。」 我開了那個網頁,心裡滴咕:「哪來的網站維護人員,竟然使用mht檔來發佈網頁,#$^%*&…?!老師教都沒有在聽喔!」 首先,要開啟那個網頁就不容易了(好像有的人可以用IE直接開啟,我的卻不行),我的方法是在那個連結上按滑鼠右鍵,直接另存新檔,這時匯儲存成一個mht檔,再用IE點開來,打算另存成html新檔後,找出被封裝的圖片。 答:此方法失敗,IE另存新檔不會分離被封裝的圖片檔。 所以只好借重firefox的外掛能力了。 (1) 讓firefox能開啟能開啟mht檔。 Step 1:在firefox的 [工具] – [附加元件]搜尋 unMHT Step 2:安裝後重新啟動firefox (2) 分離封裝的圖片(另存新檔)。 Step 1:開啟mht檔 Step 2:另存新檔,就可以找到相同檔名的資料夾,所有封裝網頁的元件,如圖片、音樂檔都會在裡頭。 完工。