看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è)上的提示
$ 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è)上有提示)面哼,即:
$ git remote add origin git@github.com:wxq393/blogtest_01.git
注:origin其實(shí)就是遠(yuǎn)程的git地址的一個(gè)別名
$ git push origin master
3、貼上我在本地終端執(zhí)行命令的全過程:
注:本地倉(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喷户。
(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)該能理解期犬?:
1河哑、查看所有分支
$ git branch -a
獲取如圖:
- (綠色分支——本地分支)*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的展示:
可以想象成兩個(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届囚?
搞了半天有梆,我所想的“關(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文件的修改编检,如圖:
(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
繼續(xù)執(zhí)行:
$ git add . (可省略)
$ git commit -am "fix master"
$ git push origin master
(3)現(xiàn)在回到遠(yuǎn)程庫(kù)(github)衩匣,發(fā)現(xiàn)更新了
(4)貼上我終端操作的全過程: