遠程倉庫
Git
是分布式版本控制系統,同一個Git
倉庫,可以分布到不同的機器上。怎么分布呢?最早,肯定只有一臺機器有一個原始版本庫,此后,別的機器可以“克隆”這個原始版本庫,而且每臺機器的版本庫其實都是一樣的,并沒有主次之分。實際情況往往是這樣,找一臺電腦充當服務器的角色,每天
24
小時開機,其他每個人都從這個“服務器”倉庫克隆一份到自己的電腦上,并且各自把各自的提交推送到服務器倉庫里,也從服務器倉庫中拉取別人的提交。
`完全可以自己搭建一臺運行
Git
的服務器,不過現階段,為了學Git
先搭個服務器絕對是小題大作。好在這個世界上有個叫GitHub的神奇的網站,從名字就可以看出,這個網站就是提供Git
倉庫托管服務的,所以,只要注冊一個GitHub
賬號,就可以免費獲得Git
遠程倉庫。由于你的本地
Git
倉庫和GitHub
倉庫之間的傳輸是通過SSH
加密的,所以,需要一點設置:
第1步:創建SSH Key
。在用戶
主目錄下,看看有沒有.ssh
目錄,如果有,再看看這個目錄下有沒有id_rsa
和id_rsa.pub
這兩個文件,如果已經有了,可直接跳到下一步。如果沒有,打開Shell
(Windows
下打開Git Bash
),創建SSH Key
:
$ ssh-keygen -t rsa -C "youremail@example.com"
你需要把郵件地址換成你自己的郵件地址,然后一路回車,使用默認值即可,由于這個
Key
也不是用于軍事目的,所以也無需設置密碼。如果一切順利的話,可以在用戶主目錄里找到
.ssh
目錄,里面有id_rsa
和id_rsa.pub
兩個文件,這兩個就是SSH Key
的秘鑰對,id_rsa
是私鑰,不能泄露出去,id_rsa.pub
是公鑰,可以放心地告訴任何人。
第2步:登陸GitHub
,打開Settings
,SSH and GPG keys
頁面:
- 然后,點
Add SSH Key
,填上任意Title
,在Key
文本框里粘貼id_rsa.pub
文件的內容:
為什么
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”按鈕,創建一個新的倉庫:
建議不要勾選
Initiallize this repository with a README
選項,避免出現下面的異常情況。
- 在
Repository name
填入Git_repository
,其他保持默認設置,點擊Create repository
按鈕,就成功地創建了一個新的Git
倉庫:
目前,在
GitHub
上的這個Git_repository
倉庫還是空的,GitHub
告訴我們,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然后,把本地倉庫的內容推送到GitHub
倉庫。-
現在,我們根據
GitHub
的提示,在本地的Git_repository
倉庫下運行命令:$ git remote add origin git@github.com:OzanViewpoint/Git_repository.git
請千萬注意,把上面的
OzanViewpoint
替換成你自己的GitHub
賬戶名,否則,你在本地關聯的就是我的遠程庫,關聯沒有問題,但是你以后推送是推不上去的,因為你的SSH Key
公鑰不在我的賬戶列表中。添加后,遠程庫的名字就是
origin
,這是Git
默認的叫法,也可以改成別的,但是origin
這個名字一看就知道是遠程庫。-
下一步,就可以把本地庫的所有內容推送到遠程庫上:
$ git push -u origin master
如果遇到如上的異常情況,究其原因,是因為在GitHub
上創建遠程倉庫時,勾選了 Initialize this repository with a README
這項,導致遠程倉庫不為空,解決辦法,先將遠程倉庫的內容合并到本地,然后再上傳即可,處理方式如下:
git pull --rebase origin master
git push -u origin master
-
取消本地目錄下關聯的遠程庫:
$ git remote remove 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
在沒有聯網的時候是拒絕干活的!當有網絡的時候,再把本地提交推送一下就完成了同步,真是太方便了!
從遠程庫克隆
- 遠程庫已經準備好了,下一步是用命令
git clone
克隆一個本地庫:
$ git clone git@github.com:OzanViewpoint/Git_repository.git
Cloning into 'gitskills'...
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (3/3), done.
$ cd gitskills
$ ls
README.md
如果有多個人協作開發,那么每個人各自從遠程克隆一份就可以了。
你也許還注意到,
GitHub
給出的地址不止一個,還可以用https://github.com/OzanViewpoint/Git_rep.git
這樣的地址。實際上,Git
支持多種協議,默認的git://
使用ssh
,但也可以使用https
等其他協議。使用
https
除了速度慢以外,還有個最大的麻煩是每次推送都必須輸入口令,但是在某些只開放http
端口的公司內部就無法使用ssh
協議而只能用https
。
小結
要克隆一個倉庫,首先必須知道倉庫的地址,然后使用git clone
命令克隆。
Git
支持多種協議,包括https
,但通過ssh
支持的原生git
協議速度最快。