git入門(三):git高級(jí)命令講解(遠(yuǎn)程庫(kù)?本地庫(kù)剂买,以及分支操作及沖突解決)

看git入門惠爽,請(qǐng)想象自己就是開發(fā)人員,正在操作一個(gè)項(xiàng)目的本地與遠(yuǎn)程的文件版本更新控制瞬哼。

前言

之前Git操作——簡(jiǎn)單使用 遠(yuǎn)程創(chuàng)建一個(gè)git項(xiàng)目婚肆,clone到本地,即為本地倉(cāng)庫(kù)(即一個(gè)含有.git隱藏文件夾的項(xiàng)目文件夾)坐慰,經(jīng)過本地終端命令的操作较性,再push到遠(yuǎn)程庫(kù)。所有的修改结胀、刪除赞咙、提交、推送等都是由這個(gè).git的文件進(jìn)行記錄的糟港,如果去掉攀操,這個(gè)項(xiàng)目就是一個(gè)普通的文件夾。

一秸抚、本地新建git項(xiàng)目push到遠(yuǎn)程空倉(cāng)庫(kù)

現(xiàn)在Git操作——復(fù)雜使用 本地新建一個(gè)git項(xiàng)目速和,push到遠(yuǎn)程空倉(cāng)庫(kù)歹垫。

1、先在github上操作

創(chuàng)建有一個(gè)空倉(cāng)庫(kù)blogtest_01(不包含初始化文件颠放,即一個(gè)未建好的倉(cāng)庫(kù))排惨,進(jìn)入項(xiàng)目頁(yè)面出現(xiàn):

通過在本地將這個(gè)倉(cāng)庫(kù)建好,push到遠(yuǎn)程倉(cāng)庫(kù)

2碰凶、再在終端上操作

(1)在本地任意創(chuàng)建一個(gè)文件夾(此時(shí)暮芭,這個(gè)還是空文件夾,不是倉(cāng)庫(kù))

$ mkdir  blogtest_01

(2)看github項(xiàng)目主頁(yè)上的提示


image
$ touch README.md
執(zhí)行status查看
$ git  status

出現(xiàn)報(bào)錯(cuò):fatal: Not a git repository (or any of the parent directories): .git 欲低,即沒有倉(cāng)庫(kù)

(3)空文件夾初始化一個(gè)倉(cāng)庫(kù)

$ git init

出現(xiàn)提示:Initialized empty Git repository in /Users/wxq393/blogtest_01/.git/谴麦,即說明已經(jīng)初始化一個(gè)空的倉(cāng)庫(kù)

驗(yàn)證倉(cāng)庫(kù)查看

$ ls  -a

即會(huì)出現(xiàn).git相關(guān)的文件夾,代表倉(cāng)庫(kù)已在本地建成

執(zhí)行status再查看
$ git  status

(4)開始添加伸头、暫存匾效、提交一系列本地操作

$ git add .
$ git commit -am "init"
本地新建倉(cāng)庫(kù)進(jìn)行推送(注意這是一個(gè)重要點(diǎn))
$git  push

注:會(huì)出現(xiàn)異常,因?yàn)楸镜匦陆ǖ腷logtest_01起初并不知道是指向遠(yuǎn)程庫(kù)blogtest_01恤磷,所以需要執(zhí)行一個(gè)指向地址的命令(在github項(xiàng)目主頁(yè)上有提示)面哼,即:

image

$ git remote add origin git@github.com:wxq393/blogtest_01.git

注:origin其實(shí)就是遠(yuǎn)程的git地址的一個(gè)別名

$ git push origin master

3、貼上我在本地終端執(zhí)行命令的全過程:

image

注:本地倉(cāng)庫(kù)扫步,只要知道倉(cāng)庫(kù)管理的地址魔策,就可以推送到任意一個(gè)遠(yuǎn)程庫(kù)(如coding、新浪云等管理工具)管理

4河胎、其他命令

(這里以gitlab作為可改標(biāo)簽)
(1)慎用闯袒,強(qiáng)制推送會(huì)覆蓋別人的代碼

$ git push -f origin master

(2)再添加一個(gè)遠(yuǎn)程庫(kù)的標(biāo)簽

$ git remote add gitlab git@gitlab.com:abc/blog.git
$ git remote -v
推送到gitlab標(biāo)簽
$ git push gitlab master

注:這里善用搜索引擎,查找不會(huì)的命令意義: $ git remote -v 游岳,-v (即 –verbose 簡(jiǎn)寫,取首字母)政敢,顯示對(duì)應(yīng)的克隆地址。即列出詳細(xì)信息胚迫,在每一個(gè)名字后面列出其遠(yuǎn)程庫(kù)的url喷户。


image

(3)#刪除gitlab標(biāo)簽

$ git remote remove gitlab

(4)修改origin標(biāo)簽對(duì)應(yīng)的地址(可以一個(gè)命令修改git的https或者ssh地址)

$ git remote set-url origin git@github.com:jirengu/blog3.git

(5)把gitlab 標(biāo)簽改名為coding

$ git remote rename gitlab coding

二、分支操作(git的重要操作部分)

分支:push origin master中访锻,master就是分支褪尝。自己畫了一個(gè)git項(xiàng)目的分支示意圖??,應(yīng)該能理解期犬?:


image

1河哑、查看所有分支

$ git branch -a

獲取如圖:


image
  • (綠色分支——本地分支)*master :當(dāng)前本地倉(cāng)庫(kù)主干master
  • (紅色分支——遠(yuǎn)程分支)remotes/origin/master :遠(yuǎn)程庫(kù)的主干

2、創(chuàng)建本地庫(kù)dev分支

$ git branch dev
$ git branch -a

3龟虎、切換主干和分支操作

(1)切換到dev分支

$ git checkout dev

具體操作:

$ git checkout dev
$ ls
$ open .
$ touch index.html
$ git add .
$ git commit -am "add file"

注:index.html在dev這個(gè)分支上

(2)切換到master主干

$ git checkout master

注:index.html沒有在master的主干上
** 結(jié)論:**同一個(gè)項(xiàng)目文件夾璃谨,只要切換不同分支,就會(huì)展示不同分支的文件狀態(tài)

4遣总、推送到origin地址的dev分支上

$ git push origin dev

5睬罗、那么轨功,在github的展示:

image

可以想象成兩個(gè)開發(fā)人員在blogtest_01這個(gè)Git的項(xiàng)目上分別操作了兩個(gè)分支,各自工作

6容达、將dev分支內(nèi)容合并到主干上

$ git checkout master
$ git merge dev
可以查看一下
$ ls

然后古涧,合并(merge)后的項(xiàng)目便是共同協(xié)作的結(jié)果

7、推送到遠(yuǎn)程庫(kù)中

$ git push origin master

那么花盐,線上代碼便是master羡滑,共同維護(hù)一份代碼。這樣一來是不是對(duì)分布式的版本控制有更深的理解了??

【我的一些思考和解決】

那么算芯,我產(chǎn)生一個(gè)疑問:剛才的分支操作主要是針對(duì)本地庫(kù)分支向遠(yuǎn)程庫(kù)推送的主要操作柒昏。但是如果在遠(yuǎn)程庫(kù)修改了分支文件,到本地庫(kù)怎么修改操作呢熙揍?

這里我主要修改主干master上的readme.md文件职祷,如何在本地終端上如何操作?我的猜想:git pull——git checkout master——git add . /git commit ——git push届囚?

image

搞了半天有梆,我所想的“關(guān)于含有分支的遠(yuǎn)程庫(kù),在遠(yuǎn)程庫(kù)修改后意系,如何在本地庫(kù)終端命令中進(jìn)行更新泥耀、修改、提交蛔添、推送等一系列命令行的問題”痰催,就是一個(gè)沖突問題啊S啤?淙堋!夹攒!

三蜘醋、沖突

1胁塞、什么是沖突

自己和你的小伙伴該同一個(gè)文件的同一個(gè)地方咏尝,在執(zhí)行g(shù)it pull時(shí),更新本地合并時(shí)會(huì)出現(xiàn)沖突

2啸罢、操作:

(1)之前我(開發(fā)人員A)已經(jīng)在遠(yuǎn)程庫(kù)的master上進(jìn)行README.md文件的修改编检,如圖:


image

(2)現(xiàn)在我(開發(fā)人員B)在本地想要在master主干上的README.md文件也進(jìn)行修改,但前提我需要把遠(yuǎn)程主干分支pull下來

注:具體在我之前的《淺談git入門(二):git基本命令講解》中“三.5多人協(xié)作”就有講過扰才。不過允懂,這次是遠(yuǎn)程項(xiàng)目的指定分支被pull下來,終端命令行細(xì)節(jié)上有所不同

即主要執(zhí)行以下代碼:

$ git branch -a (可省略)
$ git pull origin master
$ ls             (可省略)
$ vim  README.md
image

繼續(xù)執(zhí)行:

$ git add .       (可省略)
$ git commit -am "fix master"
$ git push origin master

(3)現(xiàn)在回到遠(yuǎn)程庫(kù)(github)衩匣,發(fā)現(xiàn)更新了


image

(4)貼上我終端操作的全過程:


image
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蕾总,一起剝皮案震驚了整個(gè)濱河市粥航,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌生百,老刑警劉巖递雀,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異蚀浆,居然都是意外死亡缀程,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門市俊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來杨凑,“玉大人,你說我怎么就攤上這事摆昧×寐” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵绅你,是天一觀的道長(zhǎng)鹦牛。 經(jīng)常有香客問我,道長(zhǎng)勇吊,這世上最難降的妖魔是什么曼追? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮汉规,結(jié)果婚禮上礼殊,老公的妹妹穿的比我還像新娘。我一直安慰自己针史,他們只是感情好晶伦,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著啄枕,像睡著了一般婚陪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上频祝,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天泌参,我揣著相機(jī)與錄音,去河邊找鬼常空。 笑死沽一,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的漓糙。 我是一名探鬼主播铣缠,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了蝗蛙?” 一聲冷哼從身側(cè)響起蝇庭,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎捡硅,沒想到半個(gè)月后遗契,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡病曾,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年牍蜂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片泰涂。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鲫竞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出逼蒙,到底是詐尸還是另有隱情从绘,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布是牢,位于F島的核電站僵井,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏驳棱。R本人自食惡果不足惜批什,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望社搅。 院中可真熱鬧驻债,春花似錦、人聲如沸形葬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)笙以。三九已至淌实,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間猖腕,已是汗流浹背拆祈。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留谈息,地道東北人缘屹。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像侠仇,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容