【聲明】
歡迎轉載,但請保留文章原始出處→_→
生命壹號:http://www.cnblogs.com/smyhvae/
文章來源:http://www.cnblogs.com/smyhvae/p/4052539.html
【系列】Git版本控制工具(持續更新)
【正文】
即使是周末,也不能停止學習的腳步,在之前的兩篇文章中,我們已經掌握了如何在Git倉庫里對一個文件進行時光穿梭,你再也不用擔心文件備份或者丟失的問題了。今天就來一起學習一下大名鼎鼎的GitHub網站是怎么用的。如果網站進不去,該怎么做你懂得。如果不嫌棄的話,可以用我的邀請鏈接:http://honx.in/i/U-mc6Oz5NGRmLX2S 這樣的話,雙方都能加十天的有效期,嘿嘿~~~
一、GitHub的引入:
Git是分布式版本控制系統,同一個Git倉庫,可以分布到不同的機器上。怎么分布呢?最早,肯定只有一台機器有一個原始版本庫,此后,別的機器可以“克隆”這個原始版本庫,而且每台機器的版本庫其實都是一樣的,並沒有主次之分。
實際情況往往是這樣,找一台電腦充當服務器的角色,每天24小時開機,其他每個人都從這個“服務器”倉庫克隆一份到自己的電腦上,並且各自把各自的提交推送到服務器倉庫里,也從服務器倉庫中拉取別人的提交。
1、GitHub的介紹
其實完全可以自己搭建一台運行Git的服務器,不過現階段,為了學Git先搭個服務器絕對是小題大作。好在這個世界上有個叫GitHub的神奇的網站,它是全球最大的代碼托管網站,主要借助Git來進行版本控制的。任何開源軟件都可以免費地將代碼提交到Github上,網址如下:https://github.com/
首先需要注冊一個GitHub賬號,就可以免費獲得Git遠程倉庫。
2、生成ssh keys
官方參考鏈接:https://help.github.com/articles/generating-ssh-keys/
由於你的本地Git倉庫和GitHub倉庫之間的傳輸是通過SSH加密的,所以,需要一點設置:
第一步:生成SSH Key。在用戶主目錄下,看看有沒有.ssh目錄,如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個文件,如果有的話,直接跳過此如下命令,如果沒有的話,打開命令行,輸入如下命令:
ssh-keygen -t rsa -C "youremail@example.com"
你需要把郵件地址換成你自己的郵件地址,然后一路回車,使用默認值即可,由於這個Key也不是用於軍事目的,所以也無需設置密碼。
運行效果如下:
如果一切順利的話,可以在用戶主目錄里找到.ssh目錄,里面有id_rsa和id_rsa.pub兩個文件:
這兩個就是SSH Key的秘鑰對,id_rsa是私鑰,不能泄露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。
第二步:添加SSH key到GitHub網站上。登錄github,打開“settings”中的SSH Keys頁面,然后點擊“Add SSH Key”,填上任意title,在Key文本框里黏貼id_rsa.pub文件的內容:
上圖中,點擊 Add Key,你就應該可以看到已經添加的key:
第三步:驗證連接是否成功。首先在.ssh目錄下添加名叫做config的文件,沒有后綴名,添加內容如下:(不然稍后會報錯:ssh connect to host port 22 bad file number)
Host github.com User git Hostname ssh.github.com PreferredAuthentications publickey IdentityFile ~/.ssh/id_rsa Port 443
然后,在Git Bash輸入如下命令進行驗證:
ssh -T git@github.com
輸入之后,可能會看到一下提示:
#The authenticity of host '[ssh.github.com]:443([192.30.252.150]:443)' can't be established.
# RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
# Are you sure you want to continue connecting (yes/no)?
不用擔心確保fingerprint是對的,然后根據提示輸入如下命令:
yes
如果成功,效果如下:
而且,ssh目錄下還會多出一個文件:
注:為什么GitHub需要SSH Key呢?因為GitHub需要識別出你推送的提交確實是你推送的,而不是別人冒充的,而Git支持SSH協議,所以,GitHub只要知道了你的公鑰,就可以確認只有你自己才能推送。當然,GitHub允許你添加多個Key。假定你有若干電腦,你一會兒在公司提交,一會兒在家里提交,只要把每台電腦的Key都添加到GitHub,就可以在每台電腦上往GitHub推送了。
最后友情提示,在GitHub上免費托管的Git倉庫,任何人都可以看到(但只有你自己才能改)。所以,不要把敏感信息放進去。
如果你不想讓別人看到Git庫,有兩個辦法,一個是交點保護費,讓GitHub把公開的倉庫變成私有的,這樣別人就看不見了(不可讀更不可寫)。另一個辦法是自己動手,搭一個Git服務器,因為是你自己的Git服務器,所以別人也是看不見的。這個方法我們后面會講到,相當簡單,公司內部開發必備。
二、添加遠程庫:
現在的情景是:我們已經在本地創建了一個Git倉庫后,又想在GitHub創建一個Git倉庫,並且讓這兩個倉庫進行遠程同步,這樣,GitHub上的倉庫既可以作為備份,又可以讓其他人通過該倉庫來協作。
首先,登陸GitHub,然后,在右上角找到“Create a new repo”按鈕,創建一個新的倉庫,起個名字,如下圖所示:
倉庫創建好后,效果如下:
目前,在GitHub上的這個learngit倉庫還是空的,而且,這個倉庫的地址是:https://github.com/smyhvae/GitTest.git。GitHub告訴我們,可以從這個倉庫克隆出新的倉庫;也可以把一個已有的本地倉庫與之關聯,然后,把本地倉庫的內容推送到GitHub倉庫。
三、將本地庫的內容push到遠程庫中
上一段中,我們已經建好了一個空白的遠程庫;現在,我們根據上圖中GitHub的提示,把一個已有的本地倉庫放到上面的遠程庫當中。
首先在本地創建一個版本庫AndroidTest並commit提交:
git init git add . git commit - "第一次提交"
然后,在本地的AndroidTest倉庫下運行命令來關聯遠程庫:
git remote add origin git@github.com/smyhvae/GitTest.git
因為我們之前在網站上已經創建好了,所以系統會提示:remote origin already exsists。恩,是這樣的。
請千萬注意,把上面的smyhvae替換成你自己的GitHub賬戶名,否則,你在本地關聯的就是我的遠程庫,關聯沒有問題,但是你以后推送是推不上去的,因為你的SSH Key公鑰不在我的賬戶列表中。
添加后,遠程庫的名字就是origin,這是Git默認的叫法,也可以改成別的,但是origin這個名字一看就知道是遠程庫。
下一步,就可以把本地庫的所有內容推送到遠程庫上:
git push -u origin master
如果成功,上面兩行命令的效果如下:
用git push命令,實際上是把當前分支master推送到遠程。由於遠程庫是空的,我們第一次推送master分支時,加上了-u參數,Git不但會把本地的master分支內容推送的遠程新的master分支,還會把本地的master分支和遠程的master分支關聯起來,在以后的推送或者拉取時就可以簡化命令。
推送成功后,可以立刻在GitHub頁面中看到遠程庫的內容已經和本地一模一樣:
上面的這些文件是我在本地建的工程文件,很明顯,已經成功push到了GitHub上。
從現在起,只要本地作了提交,就可以通過命令:
$ git push origin master
把本地master分支的最新修改推送至GitHub,現在,你就擁有了真正的分布式版本庫!
【總結】
要關聯一個遠程庫,使用命令git remote add origin git@username:path/repo-name.git;
關聯后,使用命令git push -u origin master第一次推送master分支的所有內容;
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
四、從遠程庫克隆到本地
上一段中我們講了先有本地庫,后有遠程庫的時候,如何關聯遠程庫。
現在,假設我們從零開發,那么最好的方式是先創建遠程庫,然后從遠程庫克隆到本地。
准備工作:
首先,登陸GitHub,創建一個新的倉庫,名字叫GitTest02:
上圖中,勾選箭頭處的按鈕,GitHub會自動為我們創建一個README.md文件。創建完畢后,可以看到README.md文件:
開始克隆:
先在本地新建一個空的文件夾作為工作目錄,我新建的目錄是:D:\workspace。因為接下來要將遠程的文件克隆到這個目錄下。
然后跳到D:\workspace目錄下,使用git clone命令開始克隆:
git clone git@github.com:smyhvae/GitTest02.git
上方命令中,注意改成自己賬戶的用戶名。運行成功后,效果如下:
這時,我們再回到本地的D:\workspace目錄下看一看:
上圖說明,我是將遠程的整個文件夾GitTest02克隆到了workspace目錄下。現在打開文件夾GitTest02看一看:
上圖中,看到了我們在遠程建的readme.md文件和.git文件夾,這是我們想要的結果。現在將GitTest02文件夾下的所有文件復制到上一層目錄,這樣就能將整個workspace工程目錄添加到版本控制中去了。注意.git是一個隱藏目錄,在復制的時候千萬不要 漏掉。復制完成后就可以把GitTest02文件夾刪了 。最終,workspace工程的目錄結構就和遠程的目錄結構一模一樣了:(只是工程的名字不一樣而已)
這時,如果在本地的workspace工程目錄中繼續添加了文件,就可以先把所有文件add到版本控制中去:
git add . git commit -m "我在本地做了修改"
然后將提交的內容同步到遠程版本庫,也就是GitHub上:
git push origin master
注:你也許還注意到,GitHub給出的地址不止一個,還可以用https://github.com/smyhvae/gitskills.git這樣的地址。實際上,Git支持多種協議,默認的git://使用ssh,但也可以使用https等其他協議。
使用https除了速度慢以外,還有個最大的麻煩是每次推送都必須輸入口令,但是在某些只開放http端口的公司內部就無法使用ssh協議而只能用https。
關於Git的分支管理,將在下一章講到。