天天看點

git使用(公鑰私鑰産生--遠端庫添加公鑰--本地庫關聯遠端庫-使用)

原文1:http://www.cnblogs.com/wangmingshun/p/5424767.html

原文2(指令):http://blog.csdn.net/xiaohanluo/article/details/53214933

到目前為止,我們已經掌握了如何在Git倉庫裡對一個檔案進行時光穿梭,你再也不用擔心檔案備份或者丢失的問題了。

可是有用過集中式版本控制系統SVN的童鞋會站出來說,這些功能在SVN裡早就有了,沒看出Git有什麼特别的地方。

沒錯,如果隻是在一個倉庫裡管理檔案曆史,Git和SVN真沒啥差別。為了保證你現在所學的Git物超所值,将來絕對不會後悔。本章開始介紹Git的殺手級功能之一(注意是之一,也就是後面還有之二,之三……):遠端倉庫。

Git是分布式版本控制系統,同一個Git倉庫,可以分布到不同的機器上。怎麼分布呢?最早,肯定隻有一台機器有一個原始版本庫,此後,别的機器可以“克隆”這個原始版本庫,而且每台機器的版本庫其實都是一樣的,并沒有主次之分。

你肯定會想,至少需要兩台機器才能玩遠端庫不是?但是我隻有一台電腦,怎麼玩?

其實一台電腦上也是可以克隆多個版本庫的,隻要不在同一個目錄下。不過,現實生活中是不會有人這麼傻的在一台電腦上搞幾個遠端庫玩,因為一台電腦上搞幾個遠端庫完全沒有意義,而且硬碟挂了會導緻所有庫都挂掉,是以我也不告訴你在一台電腦上怎麼克隆多個倉庫。

實際情況往往是這樣,找一台電腦充當伺服器的角色,每天24小時開機,其他每個人都從這個“伺服器”倉庫克隆一份到自己的電腦上,并且各自把各自的送出推送到伺服器倉庫裡,也從伺服器倉庫中拉取别人的送出。

完全可以自己搭建一台運作Git的伺服器,不過現階段,為了學Git先搭個伺服器絕對是小題大作。好在這個世界上有個叫GitHub的神奇的網站,從名字就可以看出,這個網站就是提供Git倉庫托管服務的,是以,隻要注冊一個GitHub賬号,就可以免費獲得Git遠端倉庫。

在繼續閱讀後續内容前,請自行注冊GitHub賬号。由于你的本地Git倉庫和GitHub倉庫之間的傳輸是通過SSH加密的,是以,需要一點設定:

第1步:建立SSH Key。在使用者主目錄下,看看有沒有.ssh目錄,如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個檔案,如果已經有了,可直接跳到下一步。如果沒有,打開Shell(Windows下打開Git Bash),建立SSH Key:

$ ssh-keygen -t rsa -C "[email protected]"

你需要把郵件位址換成你自己的郵件位址,然後一路回車,使用預設值即可,由于這個Key也不是用于軍事目的,是以也無需設定密碼。

如果一切順利的話,可以在使用者主目錄裡找到.ssh目錄,裡面有id_rsa和id_rsa.pub兩個檔案,這兩個就是SSH Key的秘鑰對,id_rsa是私鑰,不能洩露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。

第2步:登陸GitHub,點選頭像旁的下拉清單,選擇“Account settings”,“SSH and GPG Keys”頁面:

然後,點“New SSH Key”,填上任意Title,在Key文本框裡粘貼id_rsa.pub檔案的内容:

點“Add SSH Key”,你就應該看到已經添加的Key:

為什麼GitHub需要SSH Key呢?因為GitHub需要識别出你推送的送出确實是你推送的,而不是别人冒充的,而Git支援SSH協定,是以,GitHub隻要知道了你的公鑰,就可以确認隻有你自己才能推送。

當然,GitHub允許你添加多個Key。假定你有若幹電腦,你一會兒在公司送出,一會兒在家裡送出,隻要把每台電腦的Key都添加到GitHub,就可以在每台電腦上往GitHub推送了。

最後友情提示,在GitHub上免費托管的Git倉庫,任何人都可以看到喔(但隻有你自己才能改)。是以,不要把敏感資訊放進去。

如果你不想讓别人看到Git庫,有兩個辦法,一個是交點保護費,讓GitHub把公開的倉庫變成私有的,這樣别人就看不見了(不可讀更不可寫)。另一個辦法是自己動手,搭一個Git伺服器,因為是你自己的Git伺服器,是以别人也是看不見的。這個方法我們後面會講到的,相當簡單,公司内部開發必備。

確定你擁有一個GitHub賬号後,我們就即将開始遠端倉庫的學習。

添加遠端庫

現在的情景是,你已經在本地建立了一個Git倉庫後,又想在GitHub建立一個Git倉庫,并且讓這兩個倉庫進行遠端同步,這樣,GitHub上的倉庫既可以作為備份,又可以讓其他人通過該倉庫來協作,真是一舉多得。

首先,登陸GitHub,然後,在右上角找到“New repository”按鈕,建立一個新的倉庫:

在Repository name填入learngit,其他保持預設設定,點選“Create repository”按鈕,就成功地建立了一個新的Git倉庫:

目前,在GitHub上的這個studygit倉庫還是空的,GitHub告訴我們,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然後,把本地倉庫的内容推送到GitHub倉庫。

現在,我們根據GitHub的提示,在本地的studygit倉庫下運作指令:

$ git remote add origin https://github.com/wangmingshun/studygit.git

請千萬注意,把上面的wangmingshun替換成你自己的GitHub賬戶名,否則,你在本地關聯的就是我的遠端庫,關聯沒有問題,但是你以後推送是推不上去的,因為你的SSH Key公鑰不在我的賬戶清單中。

添加後,遠端庫的名字就是origin,這是Git預設的叫法,也可以改成别的,但是origin這個名字一看就知道是遠端庫。

下一步,就可以把本地庫的所有内容推送到遠端庫上,按照步驟會提示輸入使用者名和密碼:

複制代碼

$ git push -u origin master

Counting objects: 40, done.

Delta compression using up to 2 threads.

Compressing objects: 100% (30/30), done.

Writing objects: 100% (40/40), 3.17 KiB | 0 bytes/s, done.

Total 40 (delta 6), reused 0 (delta 0)

To https://github.com/wangmingshun/studygit.git

* [new branch]      master -> master

Branch master set up to track remote branch master from origin.

把本地庫的内容推送到遠端,用git push指令,實際上是把目前分支master推送到遠端。

由于遠端庫是空的,我們第一次推送master分支時,加上了-u參數,Git不但會把本地的master分支内容推送的遠端新的master分支,還會把本地的master分支和遠端的master分支關聯起來,在以後的推送或者拉取時就可以簡化指令。

推送成功後,可以立刻在GitHub頁面中看到遠端庫的内容已經和本地一模一樣:

從現在起,隻要本地作了送出,就可以通過指令:

$ git push origin master

把本地master分支的最新修改推送至GitHub,現在,你就擁有了真正的分布式版本庫!

SSH警告

當你第一次使用Git的clone或者push指令連接配接GitHub時,會得到一個警告:

The authenticity of host 'github.com (xx.xx.xx.xx)' can't be established.

RSA key fingerprint is xx.xx.xx.xx.xx.

Are you sure you want to continue connecting (yes/no)?

這是因為Git使用SSH連接配接,而SSH連接配接在第一次驗證GitHub伺服器的Key時,需要你确認GitHub的Key的指紋資訊是否真的來自GitHub的伺服器,輸入yes回車即可。

Git會輸出一個警告,告訴你已經把GitHub的Key添加到本機的一個信任清單裡了:

Warning: Permanently added 'github.com' (RSA) to the list of known hosts.

這個警告隻會出現一次,後面的操作就不會有任何警告了。

如果你實在擔心有人冒充GitHub伺服器,輸入yes前可以對照GitHub的RSA Key的指紋資訊是否與SSH連接配接給出的一緻。

小結

要關聯一個遠端庫,使用指令git remote add origin git@server-name:path/repo-name.git;

關聯後,使用指令git push -u origin master第一次推送master分支的所有内容;

此後,每次本地送出後,隻要有必要,就可以使用指令git push origin master推送最新修改;

分布式版本系統的最大好處之一是在本地工作完全不需要考慮遠端庫的存在,也就是有沒有聯網都可以正常工作,而SVN在沒有聯網的時候是拒絕幹活的!當有網絡的時候,再把本地送出推送一下就完成了同步,真是太友善了!

從遠端庫克隆

上次我們講了先有本地庫,後有遠端庫的時候,如何關聯遠端庫。

現在,假設我們從零開發,那麼最好的方式是先建立遠端庫,然後,從遠端庫克隆。

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

我們勾選Initialize this repository with a README,這樣GitHub會自動為我們建立一個README.md檔案。建立完畢後,可以看到README.md檔案:

現在,遠端庫已經準備好了,下一步是用指令git clone克隆一個本地庫:

$ git clone [email protected]:wangmingshun/downloadgit.git

Cloning into 'downloadgit'...

The authenticity of host 'github.com (192.30.252.122)' can't be established.

RSA key fingerprint is SHA256:nThbg6kXUpJWGl7E1IGOCspRomTxdCARLviKw6E5SY8.

Are you sure you want to continue connecting (yes/no)? yes

Warning: Permanently added 'github.com,192.30.252.122' (RSA) to the list of known hosts.

remote: Counting objects: 3, done.

remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0

Receiving objects: 100% (3/3), done.

Checking connectivity... done.

注意把Git庫的位址換成你自己的,然後進入downloadgit目錄看看,已經有README.md檔案了。

如果有多個人協作開發,那麼每個人各自從遠端克隆一份就可以了。

你也許還注意到,GitHub給出的位址不止一個,還可以用https://github.com/wangmingshun/downloadgit.git這樣的位址。實際上,Git支援多種協定,預設的git://使用ssh,但也可以使用https等其他協定。

使用https除了速度慢以外,還有個最大的麻煩是每次推送都必須輸入密碼,但是在某些隻開放http端口的公司内部就無法使用ssh協定而隻能用https。

要克隆一個倉庫,首先必須知道倉庫的位址,然後使用git clone指令克隆。

Git支援多種協定,包括https,但通過ssh支援的原生git協定速度最快。