Git学习笔记:远程仓库
前言
在補(bǔ)習(xí)python的時(shí)候主要參考的是廖雪峰的教程Python教程,在學(xué)習(xí)完后準(zhǔn)備完成期末作業(yè)時(shí),遇到了一個(gè)技術(shù)難題,需要初步掌握git,因此開(kāi)始了git的學(xué)習(xí)。
本教程參考廖雪峰的Git教程
Git簡(jiǎn)介可以參看:Git簡(jiǎn)介
Git學(xué)習(xí)筆記:版本回滾 Git:版本回滾
Git學(xué)習(xí)筆記:修改Git學(xué)習(xí)筆記:修改
目錄
文章目錄
- 前言
- 目錄
- 遠(yuǎn)程倉(cāng)庫(kù)
- step1
- step2
- 小結(jié)
- 小結(jié)
遠(yuǎn)程倉(cāng)庫(kù)
到目前為止,我們已經(jīng)掌握了如何在Git倉(cāng)庫(kù)里對(duì)一個(gè)文件進(jìn)行時(shí)光穿梭,你再也不用擔(dān)心文件備份或者丟失的問(wèn)題了。
可是有用過(guò)集中式版本控制系統(tǒng)SVN的童鞋會(huì)站出來(lái)說(shuō),這些功能在SVN里早就有了,沒(méi)看出Git有什么特別的地方。
沒(méi)錯(cuò),如果只是在一個(gè)倉(cāng)庫(kù)里管理文件歷史,Git和SVN真沒(méi)啥區(qū)別。為了保證你現(xiàn)在所學(xué)的Git物超所值,將來(lái)絕對(duì)不會(huì)后悔,同時(shí)為了打擊已經(jīng)不幸學(xué)了SVN的童鞋,本章開(kāi)始介紹Git的殺手級(jí)功能之一(注意是之一,也就是后面還有之二,之三……):遠(yuǎn)程倉(cāng)庫(kù)。
Git是分布式版本控制系統(tǒng),同一個(gè)Git倉(cāng)庫(kù),可以分布到不同的機(jī)器上。怎么分布呢?最早,肯定只有一臺(tái)機(jī)器有一個(gè)原始版本庫(kù),此后,別的機(jī)器可以“克隆”這個(gè)原始版本庫(kù),而且每臺(tái)機(jī)器的版本庫(kù)其實(shí)都是一樣的,并沒(méi)有主次之分。
你肯定會(huì)想,至少需要兩臺(tái)機(jī)器才能玩遠(yuǎn)程庫(kù)不是?但是我只有一臺(tái)電腦,怎么玩?
其實(shí)一臺(tái)電腦上也是可以克隆多個(gè)版本庫(kù)的,只要不在同一個(gè)目錄下。不過(guò),現(xiàn)實(shí)生活中是不會(huì)有人這么傻的在一臺(tái)電腦上搞幾個(gè)遠(yuǎn)程庫(kù)玩,因?yàn)橐慌_(tái)電腦上搞幾個(gè)遠(yuǎn)程庫(kù)完全沒(méi)有意義,而且硬盤掛了會(huì)導(dǎo)致所有庫(kù)都掛掉,所以我也不告訴你在一臺(tái)電腦上怎么克隆多個(gè)倉(cāng)庫(kù)。
實(shí)際情況往往是這樣,找一臺(tái)電腦充當(dāng)服務(wù)器的角色,每天24小時(shí)開(kāi)機(jī),其他每個(gè)人都從這個(gè)“服務(wù)器”倉(cāng)庫(kù)克隆一份到自己的電腦上,并且各自把各自的提交推送到服務(wù)器倉(cāng)庫(kù)里,也從服務(wù)器倉(cāng)庫(kù)中拉取別人的提交。
完全可以自己搭建一臺(tái)運(yùn)行Git的服務(wù)器,不過(guò)現(xiàn)階段,為了學(xué)Git先搭個(gè)服務(wù)器絕對(duì)是小題大作。好在這個(gè)世界上有個(gè)叫GitHub的神奇的網(wǎng)站,從名字就可以看出,這個(gè)網(wǎng)站就是提供Git倉(cāng)庫(kù)托管服務(wù)的,所以,只要注冊(cè)一個(gè)GitHub賬號(hào),就可以免費(fèi)獲得Git遠(yuǎn)程倉(cāng)庫(kù)。
在繼續(xù)閱讀后續(xù)內(nèi)容前,請(qǐng)自行注冊(cè)GitHub賬號(hào)。由于你的本地Git倉(cāng)庫(kù)和GitHub倉(cāng)庫(kù)之間的傳輸是通過(guò)SSH加密的,所以,需要一點(diǎn)設(shè)置:
step1
第1步:創(chuàng)建SSH Key。在用戶主目錄下,看看有沒(méi)有.ssh目錄,如果有,再看看這個(gè)目錄下有沒(méi)有id_rsa和id_rsa.pub這兩個(gè)文件,如果已經(jīng)有了,可直接跳到下一步。如果沒(méi)有,打開(kāi)Shell(Windows下打開(kāi)Git Bash),創(chuàng)建SSH Key:
$ ssh-keygen -t rsa -C "youremail@example.com"你需要把郵件地址換成你自己的郵件地址,然后一路回車,使用默認(rèn)值即可,由于這個(gè)Key也不是用于軍事目的,所以也無(wú)需設(shè)置密碼。
如果一切順利的話,可以在用戶主目錄里找到.ssh目錄,里面有id_rsa和id_rsa.pub兩個(gè)文件,這兩個(gè)就是SSH Key的秘鑰對(duì),id_rsa是私鑰,不能泄露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。
step2
第2步:登陸GitHub,打開(kāi)“Account settings”,“SSH Keys”頁(yè)面:
然后,點(diǎn)“Add SSH Key”,填上任意Title,在Key文本框里粘貼id_rsa.pub文件的內(nèi)容:
點(diǎn)“Add Key”,你就應(yīng)該看到已經(jīng)添加的Key:
為什么GitHub需要SSH Key呢?因?yàn)镚itHub需要識(shí)別出你推送的提交確實(shí)是你推送的,而不是別人冒充的,而Git支持SSH協(xié)議,所以,GitHub只要知道了你的公鑰,就可以確認(rèn)只有你自己才能推送。
當(dāng)然,GitHub允許你添加多個(gè)Key。假定你有若干電腦,你一會(huì)兒在公司提交,一會(huì)兒在家里提交,只要把每臺(tái)電腦的Key都添加到GitHub,就可以在每臺(tái)電腦上往GitHub推送了。
最后友情提示,在GitHub上免費(fèi)托管的Git倉(cāng)庫(kù),任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感信息放進(jìn)去。
如果你不想讓別人看到Git庫(kù),有兩個(gè)辦法,一個(gè)是交點(diǎn)保護(hù)費(fèi),讓GitHub把公開(kāi)的倉(cāng)庫(kù)變成私有的,這樣別人就看不見(jiàn)了(不可讀更不可寫)。另一個(gè)辦法是自己動(dòng)手,搭一個(gè)Git服務(wù)器,因?yàn)槭悄阕约旱腉it服務(wù)器,所以別人也是看不見(jiàn)的。這個(gè)方法我們后面會(huì)講到的,相當(dāng)簡(jiǎn)單,公司內(nèi)部開(kāi)發(fā)必備。
確保你擁有一個(gè)GitHub賬號(hào)后,我們就即將開(kāi)始遠(yuǎn)程倉(cāng)庫(kù)的學(xué)習(xí)。
小結(jié)
“有了遠(yuǎn)程倉(cāng)庫(kù),媽媽再也不用擔(dān)心我的硬盤了。”——Git點(diǎn)讀機(jī)
#添加遠(yuǎn)程庫(kù)
現(xiàn)在的情景是,你已經(jīng)在本地創(chuàng)建了一個(gè)Git倉(cāng)庫(kù)后,又想在GitHub創(chuàng)建一個(gè)Git倉(cāng)庫(kù),并且讓這兩個(gè)倉(cāng)庫(kù)進(jìn)行遠(yuǎn)程同步,這樣,GitHub上的倉(cāng)庫(kù)既可以作為備份,又可以讓其他人通過(guò)該倉(cāng)庫(kù)來(lái)協(xié)作,真是一舉多得。
首先,登陸GitHub,然后,在右上角找到“Create a new repo”按鈕,創(chuàng)建一個(gè)新的倉(cāng)庫(kù):
在Repository name填入learngit,其他保持默認(rèn)設(shè)置,點(diǎn)擊“Create repository”按鈕,就成功地創(chuàng)建了一個(gè)新的Git倉(cāng)庫(kù):
目前,在GitHub上的這個(gè)learngit倉(cāng)庫(kù)還是空的,GitHub告訴我們,可以從這個(gè)倉(cāng)庫(kù)克隆出新的倉(cāng)庫(kù),也可以把一個(gè)已有的本地倉(cāng)庫(kù)與之關(guān)聯(lián),然后,把本地倉(cāng)庫(kù)的內(nèi)容推送到GitHub倉(cāng)庫(kù)。
現(xiàn)在,我們根據(jù)GitHub的提示,在本地的learngit倉(cāng)庫(kù)下運(yùn)行命令:
$ git remote add origin git@github.com:michaelliao/learngit.git請(qǐng)千萬(wàn)注意,把上面的michaelliao替換成你自己的GitHub賬戶名,否則,你在本地關(guān)聯(lián)的就是我的遠(yuǎn)程庫(kù),關(guān)聯(lián)沒(méi)有問(wèn)題,但是你以后推送是推不上去的,因?yàn)槟愕腟SH Key公鑰不在我的賬戶列表中。
添加后,遠(yuǎn)程庫(kù)的名字就是origin,這是Git默認(rèn)的叫法,也可以改成別的,但是origin這個(gè)名字一看就知道是遠(yuǎn)程庫(kù)。
下一步,就可以把本地庫(kù)的所有內(nèi)容推送到遠(yuǎn)程庫(kù)上:
$ git push -u origin master Counting objects: 20, done. Delta compression using up to 4 threads. Compressing objects: 100% (15/15), done. Writing objects: 100% (20/20), 1.64 KiB | 560.00 KiB/s, done. Total 20 (delta 5), reused 0 (delta 0) remote: Resolving deltas: 100% (5/5), done. To github.com:michaelliao/learngit.git* [new branch] master -> master Branch 'master' set up to track remote branch 'master' from 'origin'.把本地庫(kù)的內(nèi)容推送到遠(yuǎn)程,用git push命令,實(shí)際上是把當(dāng)前分支master推送到遠(yuǎn)程。
由于遠(yuǎn)程庫(kù)是空的,我們第一次推送master分支時(shí),加上了-u參數(shù),Git不但會(huì)把本地的master分支內(nèi)容推送的遠(yuǎn)程新的master分支,還會(huì)把本地的master分支和遠(yuǎn)程的master分支關(guān)聯(lián)起來(lái),在以后的推送或者拉取時(shí)就可以簡(jiǎn)化命令。
推送成功后,可以立刻在GitHub頁(yè)面中看到遠(yuǎn)程庫(kù)的內(nèi)容已經(jīng)和本地一模一樣:
從現(xiàn)在起,只要本地作了提交,就可以通過(guò)命令:
$ git push origin master把本地master分支的最新修改推送至GitHub,現(xiàn)在,你就擁有了真正的分布式版本庫(kù)!
##SSH警告
當(dāng)你第一次使用Git的clone或者push命令連接GitHub時(shí),會(huì)得到一個(gè)警告:
這是因?yàn)镚it使用SSH連接,而SSH連接在第一次驗(yàn)證GitHub服務(wù)器的Key時(shí),需要你確認(rèn)GitHub的Key的指紋信息是否真的來(lái)自GitHub的服務(wù)器,輸入yes回車即可。
Git會(huì)輸出一個(gè)警告,告訴你已經(jīng)把GitHub的Key添加到本機(jī)的一個(gè)信任列表里了:
這個(gè)警告只會(huì)出現(xiàn)一次,后面的操作就不會(huì)有任何警告了。
如果你實(shí)在擔(dān)心有人冒充GitHub服務(wù)器,輸入yes前可以對(duì)照GitHub的RSA Key的指紋信息是否與SSH連接給出的一致。
##小結(jié)
要關(guān)聯(lián)一個(gè)遠(yuǎn)程庫(kù),使用命令git remote add origin git@server-name:path/repo-name.git;
關(guān)聯(lián)后,使用命令git push -u origin master第一次推送master分支的所有內(nèi)容;
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
分布式版本系統(tǒng)的最大好處之一是在本地工作完全不需要考慮遠(yuǎn)程庫(kù)的存在,也就是有沒(méi)有聯(lián)網(wǎng)都可以正常工作,而SVN在沒(méi)有聯(lián)網(wǎng)的時(shí)候是拒絕干活的!當(dāng)有網(wǎng)絡(luò)的時(shí)候,再把本地提交推送一下就完成了同步,真是太方便了!
#克隆遠(yuǎn)程庫(kù)
上次我們講了先有本地庫(kù),后有遠(yuǎn)程庫(kù)的時(shí)候,如何關(guān)聯(lián)遠(yuǎn)程庫(kù)。
現(xiàn)在,假設(shè)我們從零開(kāi)發(fā),那么最好的方式是先創(chuàng)建遠(yuǎn)程庫(kù),然后,從遠(yuǎn)程庫(kù)克隆。
首先,登陸GitHub,創(chuàng)建一個(gè)新的倉(cāng)庫(kù),名字叫g(shù)itskills:
我們勾選Initialize this repository with a README,這樣GitHub會(huì)自動(dòng)為我們創(chuàng)建一個(gè)README.md文件。創(chuàng)建完畢后,可以看到README.md文件:
現(xiàn)在,遠(yuǎn)程庫(kù)已經(jīng)準(zhǔn)備好了,下一步是用命令git clone克隆一個(gè)本地庫(kù):
$ git clone git@github.com:michaelliao/gitskills.git Cloning into 'gitskills'... remote: Counting objects: 3, done. remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 3 Receiving objects: 100% (3/3), done.注意把Git庫(kù)的地址換成你自己的,然后進(jìn)入gitskills目錄看看,已經(jīng)有README.md文件了:
$ cd gitskills $ ls README.md如果有多個(gè)人協(xié)作開(kāi)發(fā),那么每個(gè)人各自從遠(yuǎn)程克隆一份就可以了。
你也許還注意到,GitHub給出的地址不止一個(gè),還可以用https://github.com/michaelliao/gitskills.git這樣的地址。實(shí)際上,Git支持多種協(xié)議,默認(rèn)的git://使用ssh,但也可以使用https等其他協(xié)議。
使用https除了速度慢以外,還有個(gè)最大的麻煩是每次推送都必須輸入口令,但是在某些只開(kāi)放http端口的公司內(nèi)部就無(wú)法使用ssh協(xié)議而只能用https。
小結(jié)
要克隆一個(gè)倉(cāng)庫(kù),首先必須知道倉(cāng)庫(kù)的地址,然后使用git clone命令克隆。
Git支持多種協(xié)議,包括https,但通過(guò)ssh支持的原生git協(xié)議速度最快。
總結(jié)
以上是生活随笔為你收集整理的Git学习笔记:远程仓库的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Python学习笔记:Day 7 编写M
- 下一篇: c语言生成迷宫算法,[原创]递归随机迷宫