分佈式版本控制系統(git遠程管理)

1,遠程倉庫概念

在上篇博文中,咱們已經掌握瞭如何在Git倉庫裏對一個文件進行時光穿梭,不再用擔憂文件備份或者丟失的問題了。git

但是有用過集中式版本控制系統SVN的朋友會站出來講,這些功能在SVN裏早就有了,沒看出Git有什麼特別的地方。github

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

你確定會想,至少須要兩臺機器才能玩遠程庫不是?可是我只有一臺電腦,怎麼玩?其實,一臺電腦上也是能夠克隆多個版本庫的,只要不在同一個目錄下。不過,現實中是不會有人這麼傻的在一臺電腦上搞幾個遠程庫玩,由於一臺電腦上搞幾個遠程庫徹底沒有意義,並且硬盤掛了會致使全部庫都掛掉,因此本文就不實踐一臺電腦上怎麼克隆多個倉庫,感興趣的能夠本身去實踐。ssh

實際狀況每每是這樣,找一臺電腦充當服務器的角色,天天24小時開機,其餘每一個人都從這個「服務器」倉庫克隆一份到本身的電腦上,而且各自把各自的提交推送到服務器倉庫裏,也從服務器倉庫中拉取別人的提交。
徹底能夠本身搭建一臺運行Git的服務器,不過爲了學Giit先搭個服務器絕對是小題大做。好在這個世界上有個叫GitHub的網站,從名字就可看出,這個網站就是提供Git倉庫tuo管服務器的,因此,只要註冊一個GitHub帳號,就能夠免費得到Git遠程倉庫。分佈式

在繼續閱讀後續內容前,請自行註冊GitHub帳號。因爲你的本地Git倉庫和GitHub倉庫之間的傳輸是經過SSH加密的,因此,須要一點設置:ide

第1步:建立ssh key。在用戶主目錄下,看看有沒有.ssh目錄,若是有,再看看這個目錄下有沒有id_rsaid_rsa.pub這兩個文件,若是已經有了,可直接跳到下一步。若是沒有,打開終端,建立ssh key:網站

[jonson@localhost ~]$ ssh-keygen -t rsa
[jonson@localhost ~]$ cd  .ssh/
[jonson@localhost .ssh]$ ls
id_rsa  id_rsa.pub
[jonson@localhost .ssh]$ pwd
/home/jonson/.ssh

第2步:登陸GitHub,導入公鑰:
分佈式版本控制系統(git遠程管理)
分佈式版本控制系統(git遠程管理)
填上任意Title,在key文本框裏粘貼id_ras.pub文件的內容:
分佈式版本控制系統(git遠程管理)
爲何GitHub須要ssh key呢?由於GitHub須要識別出你推送的提交肯定是你推送的,而不是別人冒充的,而Git支持ssh協議,因此,GitHhub只要知道了你的公鑰,就能夠確認只有你本身才能推送。
固然,GitHub容許你添加多個key。假定你有若干電腦,你一會在公司提交,一會在家裏提交,只要把每臺電腦的key都添加到GitHub,就能夠在每臺電腦上網GitHub推送了。
須要注意的是,在GitHub上免費tuo管的Git倉庫,任何均可以看到(但只有你本身才能改),因此,不要把敏感信息放進去。this

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

2,添加遠程倉庫

如今的情景是,你已經在本地建立了一個Git倉庫後,又想在GitHub 建立一個GIt倉庫,而且讓這兩個倉庫進行遠程同步,這樣,GitHub上的倉庫既能夠做爲備份,又可讓其餘人經過該倉庫來協做,這是很是實用的。
首先,點擊右上角的your repositories按鈕,而後點擊new,建立一個新的倉庫:
分佈式版本控制系統(git遠程管理)
分佈式版本控制系統(git遠程管理)
分佈式版本控制系統(git遠程管理)
分佈式版本控制系統(git遠程管理)
目前,在GitHub上的jonson-repo倉庫仍是空的,GitHub告訴咱們,能夠從這個倉庫克隆出新的倉庫,也能夠把一個已有的本地倉庫與之關聯,而後,把本地倉庫的內容推送到GitHub倉庫。版本控制

如今,咱們根據GitHub的提示,在本地的jonson-repo倉庫下運行命令:

[jonson@localhost ~]$ mkdir mygit
[jonson@localhost ~]$ cd mygit/
[jonson@localhost mygit]$ echo "# this is jonson first repo" >> text.txt
[jonson@localhost mygit]$ git init
Initialized empty Git repository in /home/jonson/mygit/.git/
[jonson@localhost mygit]$ git add text.txt 
[jonson@localhost mygit]$ git commit -m "first commit"
[master (root-commit) 6bbea20] first commit
 1 file changed, 1 insertion(+)
 create mode 100644 text.txt
[jonson@localhost mygit]$ git config --global user.name "jonson"
[jonson@localhost mygit]$ git config --global user.email "xxxx.163.com"
#上邊的步驟若是以前作過能夠省略
[jonson@localhost mygit]$ git remote add origin git@github.com:sqm-sys/jonson-repo.git

添加後,遠程庫的名字就是origin,這是Git默認的叫法,也能夠改爲別的,可是origin這個名字一看就是遠程庫。
下一步,就能夠把本地庫的全部內容推送到遠程庫上:

[jonson@localhost mygit]$ git push -u origin master   #出現提示輸入「yes」便可
Counting objects: 3, done.
Writing objects: 100% (3/3), 228 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To git@github.com:sqm-sys/jonson-repo.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遠程管理)
從如今起,只要本地作了提交,就能夠經過命令:
$ git push origin master
把本地master分支的最新修改推送至GItHub,真正的擁有了分佈式版本庫。

SSH警告
當你第一次使用Git的clone或者push命令鏈接GitHub時,會獲得一個警告:
分佈式版本控制系統(git遠程管理)
這是由於Git使用SSH鏈接,而SSH鏈接在第一次驗證GitHub服務器的key時,須要你確認GitHub的key的指紋信息是否真的來自GitHub服務器,輸yes回車便可。
Git會輸出一個警告,告訴你已經把GitHub的key添加到本地的一個信息列表裏了:(這個警告只會出現一次,之後就不會有任何警告了)
分佈式版本控制系統(git遠程管理)

小結:
要關聯一個遠程庫,使用命令git remote add origin git@server-name:path/repo-name.git;
關聯後,使用命令git push -u origin master 第一次推送master分支的全部內容;
此後,每次本地提交後,只要有必要,就可使用命令git push origin master 推送最新修改;

3,從遠程庫克隆

以前咱們實踐了先有本地庫,後有遠程庫的時候,如何關聯遠程庫。
如今,假設咱們從零開發,那麼最好的方式是先建立遠程庫,而後,從遠程庫克隆。
1)首先,登陸GitHub,建立一個新的倉庫:
分佈式版本控制系統(git遠程管理)
咱們勾選Initialize this repository with a README,這樣GitHub會自動爲咱們建立一個README.md文件。
分佈式版本控制系統(git遠程管理)
如今,遠程庫已經準備好了,下一步是用命令git clone克隆一個本地庫:

[jonson@localhost mygit]$ git clone git@github.com:sqm-sys/new-repo.git
Cloning into 'new-repo'...
remote: Enumerating objects: 3, done.
remote: Counting objects: 100% (3/3), done.
Receiving objects: 100% (3/3), done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0

克隆成功後,進入new-repo目錄看看,已經有遠程庫上的文件:

[jonson@localhost mygit]$ ls
new-repo  text.txt
[jonson@localhost mygit]$ cat new-repo/README.md 
# new-repo
this is new repo

若是有多我的協做開發,那麼每一個人各自從遠程克隆一份就能夠了。
你也許還注意到,GitHub給出的地址不止一個,還能夠用https://github.com/sqm-sys/new-repo.git 這樣的地址,實際上,Git支持多種協議,默認的git://使用ssh,但也可使用https等其餘協議。

使用https除了速度慢之外,還有個最大的麻煩是每次推送都必須輸入登陸帳號和密碼,可是在某些只開放http端口的公司內部就沒法ssh協議,而只能使用https。

小結:
要克隆一個倉庫,首先必須知道倉庫的地址,而後使用git clone命令克隆。Git支持多種協議,包括https,但經過ssh支持的原生git協議速度最快。

相關文章
相關標籤/搜索