本文主要目的是想讓和我一樣剛從SVN陣營轉到Git陣營的程序員能夠快速完成一些簡單的Git操作。
簡單理解 Git 的思想和基本的工作原理,能夠更好的進一步和使用Git。在開始學習Git 的時候,最好不要把Git的各種概念和其他的版本控制系統諸如 Subversion 等相比,否則容易混淆每個操作的實際意義。
Git是一個免費的、分布式的版本控制工具,或是一個強調了速度快的源代碼管理工具。每一個Git的工作目錄都是一個完全獨立的代碼庫,並擁有完整的歷史記錄和版本追蹤能力,不依賴於網絡和中心服務器。
Git 在管理項目時,在本地會有三個工作區域:Git 的本地數據目錄,工作目錄以及暫存區域。如下圖所示:
因此對於任何一個文件,在 Git 內都只有三種狀態:已提交(committed),已修改(modified)和已暫存(staged)。
在簡單地了解了Git之后,那么接下來的事情就是安裝Git客戶端了,命令如下:
sudo apt-get install git
但是,安裝了Git客戶端之后,如果你的代碼不是托管在GitHub上就可以跳過設置GitHub賬戶內容了,否則還需要配置一下GitHub賬戶,GitHub為托管的Git版本庫提供SSH協議支持,即用戶可以用公鑰認證的方式連接到GitHub的SSH服務器。設置之后才能夠使用Git命令來下載和推送代碼。
首先需要到https://github.com/ 注冊一個賬戶:只要點擊導航條中的“Signup and Pricing”,或者點擊首頁中那個大大的“Plans, Pricing and Signup”按鈕,即進入收費方案介紹及注冊頁面。開源軟件托管是GitHub的基石,對於開源項目的版本庫(即非私有版本庫)的托管,GitHub是免費的。在收費方案及注冊頁面中,最上面的就是針對於開源的免費托管方案,如下圖所示。
點擊上圖右側的“Create a free account”按鈕,就進入到注冊頁面,如下圖所示。
注冊只需要用戶名,郵件地址和密碼需要輸入。注意:每個郵件地址只能注冊一次。注冊完成之后就會以新注冊的賬號自動登錄。如下圖所示:
點擊上圖右上角的設置按鈕,就能進入設置頁面,我們主要關注的是“ setting up Git and SSH keys”,設置成功之后用戶可以用公鑰認證的方式連接到GitHub的SSH服務器。
我們首先使用ssh命令連接github.com的SSH服務,登錄用戶名為git(所有GitHub用戶共享此SSH用戶名,不要寫成其他)。
ssh -T git@github.com 執行之后提示:Permission denied (publickey).
這說明我們還沒在GitHub賬戶中正確設置公鑰認證。下圖為GitHub的SSH公鑰設置界面:
GitHub的SSH服務支持OpenSSH格式的公鑰認證,可以通過Ubuntu下的ssh-keygen命令創建公鑰/私鑰對。
ssh-keygen -C "yourname@yourcompany.com" -f ~/.ssh/github
也可以用ssh-keygen命令以不同的名稱創建多個公鑰,當擁有多個GitHub賬號時,非常重要。這是因為雖然一個GitHub賬號允許使用多個不同的SSH公鑰,但反過來,一個SSH公鑰只能對應於一個GitHub賬號。
接下來就將~/.ssh/github.pub文件內容拷貝到剪切板。公鑰是一行長長的字符串,若用編輯器打開公鑰文件會折行顯示,注意在copy時一定不要在其中插入多余的換行符、空格等,否則在公鑰認證過程因為服務器端和客戶端公鑰不匹配而導致認證失敗。然后將公鑰文件中的內容粘貼到GitHub的SSH公鑰管理的對話框,即上圖key對話框中,並為這個SSH Key起個名字並保存。設置成功后,再用ssh命令訪問GitHub,會顯示一條認證成功信息並退出。在認證成功的信息中還會顯示該公鑰對應的用戶名。
ssh -T git@github.com 執行后提示:Hi github! You've successfully authenticated, but GitHub does not provide shell access.
通過以上的設置之后,我們就能夠通過SSH的方式,直接使用Git命令訪問GitHub托管服務器了。那么,下面我們就開始使用Git進行版本控制:
1. 從服務器下載代碼,准確的說應該是從GitHub服務器復制一個版本庫到本地:
mkdir git mkdir repos cd git/repos git clone git@github.com:"account context"/"repos name".git
2. 獲取到源碼之后,就可以進行開發了,代碼開發完成就可以提交代碼:
git add . //往暫存區域添加已添加和修改的文件,不處理刪除的文件 git status //比較本地數據目錄與暫存區域的變化 git commit -m "commit directions" //提到代碼到本地數據目錄,並添加提交說明
3. 有可能你和其他人改的是同一個文件,那么沖突的情況是在所難免的,那么在提交之后再獲取一下代碼,就會提示代碼沖突的文件,我們需要做的就是處理這些沖突,並再次提交:
git pull //更新代碼 根據提示修改沖突文件中的代碼 git add . git commit -m "commit directions"
4. 當你做完以上的步驟的時候,你需要做的是把本地數據目錄的版本庫的數據同步到GitHub服務器上去,這樣你的同事才能夠看到你作出的修改:
git push
注意:""中的內容需要讀者根據自己實際情況書寫合適的內容。
本文的主要目的是為了讓程序員能夠快速的上手使用Git和GitHub,希望對大家有幫助。
擴展閱讀:http://marklodato.github.com/visual-git-guide/index-zh-cn.html
http://www.worldhello.net/gotgithub/
參考資料:《Pro Git》