在上篇博文中,咱們已經掌握瞭如何在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_rsa
和id_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,導入公鑰:
填上任意Title,在key文本框裏粘貼id_ras.pub
文件的內容:
爲何GitHub須要ssh key呢?由於GitHub須要識別出你推送的提交肯定是你推送的,而不是別人冒充的,而Git支持ssh協議,因此,GitHhub只要知道了你的公鑰,就能夠確認只有你本身才能推送。
固然,GitHub容許你添加多個key。假定你有若干電腦,你一會在公司提交,一會在家裏提交,只要把每臺電腦的key都添加到GitHub,就能夠在每臺電腦上網GitHub推送了。
須要注意的是,在GitHub上免費tuo管的Git倉庫,任何均可以看到(但只有你本身才能改),因此,不要把敏感信息放進去。this
若是你不想讓別人看到Git庫,有兩個辦法,一個是交點保護費,讓GitHub把公開的倉庫變成私有的,這樣別人就看不見了(不可讀更不可寫),另外一個辦法是本身動手搭建一個Git服務器,由於是你本身的Git服務器,因此別人也是看不見的。(公司內部開發必備)加密
如今的情景是,你已經在本地建立了一個Git倉庫後,又想在GitHub 建立一個GIt倉庫,而且讓這兩個倉庫進行遠程同步,這樣,GitHub上的倉庫既能夠做爲備份,又可讓其餘人經過該倉庫來協做,這是很是實用的。
首先,點擊右上角的your repositories
按鈕,而後點擊new
,建立一個新的倉庫:
目前,在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 push origin master
把本地master分支的最新修改推送至GItHub,真正的擁有了分佈式版本庫。
SSH警告
當你第一次使用Git的clone
或者push
命令鏈接GitHub時,會獲得一個警告:
這是由於Git使用SSH鏈接,而SSH鏈接在第一次驗證GitHub服務器的key時,須要你確認GitHub的key的指紋信息是否真的來自GitHub服務器,輸yes
回車便可。
Git會輸出一個警告,告訴你已經把GitHub的key添加到本地的一個信息列表裏了:(這個警告只會出現一次,之後就不會有任何警告了)
小結:
要關聯一個遠程庫,使用命令git remote add origin git@server-name:path/repo-name.git;
關聯後,使用命令git push -u origin master
第一次推送master分支的全部內容;
此後,每次本地提交後,只要有必要,就可使用命令git push origin master
推送最新修改;
以前咱們實踐了先有本地庫,後有遠程庫的時候,如何關聯遠程庫。
如今,假設咱們從零開發,那麼最好的方式是先建立遠程庫,而後,從遠程庫克隆。
1)首先,登陸GitHub,建立一個新的倉庫:
咱們勾選Initialize this repository with a README
,這樣GitHub會自動爲咱們建立一個README.md
文件。
如今,遠程庫已經準備好了,下一步是用命令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協議速度最快。