Git版本控制工具(三)----遠程倉庫GitHub的使用

【聲明】html

歡迎轉載,但請保留文章原始出處→_→git

生命壹號:http://www.cnblogs.com/smyhvae/github

文章來源:http://www.cnblogs.com/smyhvae/p/4052539.html服務器

 

【系列】Git版本控制工具(持續更新)ssh

Git版本控制工具(一)----git的安裝及建立版本庫分佈式

Git版本控制工具(二)----本地版本庫的經常使用操做工具

Git版本控制工具(三)----遠程倉庫GitHub的使用學習

 

【正文】網站

即便是週末,也不能中止學習的腳步,在以前的兩篇文章中,咱們已經掌握瞭如何在Git倉庫裏對一個文件進行時光穿梭,你不再用擔憂文件備份或者丟失的問題了。今天就來一塊兒學習一下大名鼎鼎的GitHub網站是怎麼用的。若是網站進不去,該怎麼作你懂得。若是不嫌棄的話,能夠用個人邀請連接:http://honx.in/i/U-mc6Oz5NGRmLX2S   這樣的話,雙方都能加十天的有效期,嘿嘿~~~加密

1、GitHub的引入:                                                                                                                 

Git是分佈式版本控制系統,同一個Git倉庫,能夠分佈到不一樣的機器上。怎麼分佈呢?最先,確定只有一臺機器有一個原始版本庫,此後,別的機器能夠「克隆」這個原始版本庫,並且每臺機器的版本庫其實都是同樣的,並無主次之分。

實際狀況每每是這樣,找一臺電腦充當服務器的角色,天天24小時開機,其餘每一個人都從這個「服務器」倉庫克隆一份到本身的電腦上,而且各自把各自的提交推送到服務器倉庫裏,也從服務器倉庫中拉取別人的提交。

一、GitHub的介紹

其實徹底能夠本身搭建一臺運行Git的服務器,不過現階段,爲了學Git先搭個服務器絕對是小題大做。好在這個世界上有個叫GitHub的神奇的網站,它是全球最大的代碼託管網站,主要藉助Git來進行版本控制的。任何開源軟件均可以避免費地將代碼提交到Github上,網址以下:https://github.com/

首先須要註冊一個GitHub帳號,就能夠免費得到Git遠程倉庫。

二、生成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也不是用於軍事目的,因此也無需設置密碼。

運行效果以下:

faa714d0-df3e-42a2-ab4a-3e7356b933ce

若是一切順利的話,能夠在用戶主目錄裏找到.ssh目錄,裏面有id_rsa和id_rsa.pub兩個文件:

c478bf65-9d29-4a94-9c61-81e1eb9e4eba

這兩個就是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

若是成功,效果以下:

85d9eeb9-e777-470c-ac4e-651cd8574ca9 

並且,ssh目錄下還會多出一個文件:

注:爲何GitHub須要SSH Key呢?由於GitHub須要識別出你推送的提交確實是你推送的,而不是別人冒充的,而Git支持SSH協議,因此,GitHub只要知道了你的公鑰,就能夠確認只有你本身才能推送。固然,GitHub容許你添加多個Key。假定你有若干電腦,你一下子在公司提交,一下子在家裏提交,只要把每臺電腦的Key都添加到GitHub,就能夠在每臺電腦上往GitHub推送了。

最後友情提示,在GitHub上免費託管的Git倉庫,任何人均可以看到(但只有你本身才能改)。因此,不要把敏感信息放進去。

若是你不想讓別人看到Git庫,有兩個辦法,一個是交點保護費,讓GitHub把公開的倉庫變成私有的,這樣別人就看不見了(不可讀更不可寫)。另外一個辦法是本身動手,搭一個Git服務器,由於是你本身的Git服務器,因此別人也是看不見的。這個方法咱們後面會講到,至關簡單,公司內部開發必備。

 

2、添加遠程庫:                                                                                                                   

如今的情景是:咱們已經在本地建立了一個Git倉庫後,又想在GitHub建立一個Git倉庫,而且讓這兩個倉庫進行遠程同步,這樣,GitHub上的倉庫既能夠做爲備份,又可讓其餘人經過該倉庫來協做。

首先,登錄GitHub,而後,在右上角找到「Create a new repo」按鈕,建立一個新的倉庫,起個名字,以下圖所示:

倉庫建立好後,效果以下:

目前,在GitHub上的這個learngit倉庫仍是空的,並且,這個倉庫的地址是:https://github.com/smyhvae/GitTest.git。GitHub告訴咱們,能夠從這個倉庫克隆出新的倉庫也能夠把一個已有的本地倉庫與之關聯,而後,把本地倉庫的內容推送到GitHub倉庫

 

3、將本地庫的內容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

若是成功,上面兩行命令的效果以下:

c0ccaac6-09ac-42f3-bd7b-dde2c3b1f810

用git push命令,其實是把當前分支master推送到遠程。因爲遠程庫是空的,咱們第一次推送master分支時,加上了-u參數,Git不但會把本地的master分支內容推送的遠程新的master分支,還會把本地的master分支和遠程的master分支關聯起來,在之後的推送或者拉取時就能夠簡化命令。

推送成功後,能夠馬上在GitHub頁面中看到遠程庫的內容已經和本地如出一轍

678099dc-c0ef-4c46-9a72-61b466791942

上面的這些文件是我在本地建的工程文件,很明顯,已經成功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推送最新修改;

 

4、從遠程庫克隆到本地                                                                                                             

上一段中咱們講了先有本地庫,後有遠程庫的時候,如何關聯遠程庫。

如今,假設咱們從零開發,那麼最好的方式是先建立遠程庫,而後從遠程庫克隆到本地

準備工做:

首先,登錄GitHub,建立一個新的倉庫,名字叫GitTest02:

0e6355e4-60c1-4a6f-84de-aac1526b84be

上圖中,勾選箭頭處的按鈕,GitHub會自動爲咱們建立一個README.md文件。建立完畢後,能夠看到README.md文件:

cab0e824-bc81-4b66-908b-afa5d28a9b08

開始克隆:

先在本地新建一個空的文件夾做爲工做目錄,我新建的目錄是:D:\workspace。由於接下來要將遠程的文件克隆到這個目錄下

而後跳到D:\workspace目錄下,使用git clone命令開始克隆:

git clone git@github.com:smyhvae/GitTest02.git

上方命令中,注意改爲本身帳戶的用戶名。運行成功後,效果以下:

3f8b5566-88b5-4655-90b1-d1c58a00786d

這時,咱們再回到本地的D:\workspace目錄下看一看:

28e1021f-e90b-42ab-afaf-710d3740d72d

上圖說明,我是將遠程的整個文件夾GitTest02克隆到了workspace目錄下。如今打開文件夾GitTest02看一看:

83967460-9c3a-4863-98af-0c10f2296b4f

上圖中,看到了咱們在遠程建的readme.md文件和.git文件夾,這是咱們想要的結果。如今將GitTest02文件夾下的全部文件複製到上一層目錄,這樣就能將整個workspace工程目錄添加到版本控制中去了。注意.git是一個隱藏目錄,在複製的時候千萬不要 漏掉。複製完成後就能夠把GitTest02文件夾刪了 。最終,workspace工程的目錄結構就和遠程的目錄結構如出一轍了:(只是工程的名字不同而已)

11709da3-ad31-4cf8-bc14-d62fe35e81e8

這時,若是在本地的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的分支管理,將在下一章講到。

相關文章
相關標籤/搜索