簡單理解 Git 的思想和基本的工做原理,可以更好的進一步和使用Git。在開始學習Git 的時候,最好不要把Git的各類概念和其餘的版本控制系統諸如 Subversion 等相比,不然容易混淆每一個操做的實際意義。linux
Git是一個免費的、分佈式的版本控制工具,或是一個強調了速度快的源代碼管理工具。每個Git的工做目錄都是一個徹底獨立的代碼庫,並擁有完整的歷史記錄和版本追蹤能力,不依賴於網絡和中心服務器。git
Git 在管理項目時,在本地會有三個工做區域:Git 的本地數據目錄,工做目錄以及暫存區域。以下圖所示:程序員
所以對於任何一個文件,在 Git 內都只有三種狀態:已提交(committed),已修改(modified)和已暫存(staged)。github
在簡單地瞭解了Git以後,那麼接下來的事情就是安裝Git客戶端了,命令以下:shell
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」按鈕,就進入到註冊頁面,以下圖所示。ssh
註冊只須要用戶名,郵件地址和密碼須要輸入。注意:每一個郵件地址只能註冊一次。註冊完成以後就會以新註冊的帳號自動登陸。以下圖所示:編輯器
點擊上圖右上角的設置按鈕,就能進入設置頁面,咱們主要關注的是「 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,但願對你們有幫助。