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


【聲明】

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

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

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

 

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

Git版本控制工具(一)----git的安裝及創建版本庫

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

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

 

【正文】

即使是周末,也不能停止學習的腳步,在之前的兩篇文章中,我們已經掌握了如何在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也不是用於軍事目的,所以也無需設置密碼。

運行效果如下:

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服務器,所以別人也是看不見的。這個方法我們后面會講到,相當簡單,公司內部開發必備。

 

二、添加遠程庫:                                                                                                                   

現在的情景是:我們已經在本地創建了一個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

如果成功,上面兩行命令的效果如下:

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推送最新修改;

 

四、從遠程庫克隆到本地                                                                                                             

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

現在,假設我們從零開發,那么最好的方式是先創建遠程庫,然后從遠程庫克隆到本地

准備工作:

首先,登陸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的分支管理,將在下一章講到。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM