在開始探討分支的管理流程之前洒宝,首先需要了解git組件的絕對名稱萌京、引用名稱雁歌、Tag標(biāo)簽和相對名稱和tag,這部分主要講解如下幾點(diǎn)內(nèi)容
- git組件的絕對名稱
- git組件的引用名稱
- git組件的tag標(biāo)簽
- git組件的相對名稱
- 利用reflog找到所有的版本
git的絕對名稱
git組件的絕對名稱就是每次生成的時(shí)候的hash碼知残,我們可以根據(jù)絕對名稱獲得這個(gè)版本的所有信息
我們可以利用git cat-file -p commitid
來獲取該提交的tree組件和上一級的組件。
tree組件在常用組件中已經(jīng)介紹了法竞,parent組件記錄了上一次提交的commit組件的id耙厚。我們只要使用id的前4個(gè)字節(jié)即可代表整個(gè)id强挫。另外在使用log的時(shí)候可以加入--pretty=oneline
這樣可以簡化日志的顯示。
為了更好的使用各種命令八匠,我們可以在.gitconfig
文件中為一些命令加入別名,這樣在使用的時(shí)候會(huì)方便很多
[user]
name = ynkonghao
email = ynkonghao@gmail.com
[alias]
lg = log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit
co = commit
st = status -s
我加入了3個(gè)別名趴酣,lg這個(gè)別名非常的好用梨树,大家只要按照這個(gè)直接拷貝到自己的.gitconfig中即可,以下就是lg的效果岖寞,當(dāng)有了分支之后抡四,這個(gè)別名會(huì)更加的有趣
git的引用名稱
為了方便我們記憶一些特殊的版本隶垮,我們可以為hashid設(shè)定一個(gè)比較好記憶的引用名稱藻雪,當(dāng)我們?yōu)間it創(chuàng)建分支之后,每一個(gè)分支名稱其實(shí)都是一個(gè)引用名稱狸吞,所有的引用名稱都存儲(chǔ)在git的根目錄和git的refs的目錄中勉耀,所有的分支信息都存儲(chǔ)在refs/head文件夾中指煎。
當(dāng)創(chuàng)建了一個(gè)新的分支之后都會(huì)把分支的名稱存儲(chǔ)在refs/head文件夾中椭住,打開分支名稱的文件崇渗,我們會(huì)發(fā)現(xiàn)這個(gè)文件中記錄了當(dāng)前分支最新的那個(gè)commit。我們再看一下.git的文件夾京郑,我們會(huì)發(fā)現(xiàn)一個(gè)HEAD
的文件宅广,查看一個(gè)這個(gè)文件
這同樣是一個(gè)引用名稱户魏,只是這里不是加入commit驶臊,而是告訴git,HEAD所指向的commit是refs/head/b1這個(gè)分支叼丑,我們將當(dāng)前的分支切換到master关翎,再看看情況。我們會(huì)發(fā)現(xiàn)這個(gè)文件中的內(nèi)容指向了master分支鸠信。
現(xiàn)在大家應(yīng)該清楚分支的引用名稱了纵寝,引用名稱最終都會(huì)對應(yīng)到一個(gè)絕對名稱(一個(gè)hash的id)上,我們也可以自己定義一個(gè)引用名稱來對應(yīng)我們需要定義的commitId
git update-ref refs/init commitId
此時(shí)就會(huì)在refs文件夾中創(chuàng)建init的文件室奏,這個(gè)文件里面的內(nèi)容就是我們設(shè)置的commitId,可以通過git show-ref
查詢所有的引用
使用git update-ref -d init
可以刪除一個(gè)引用琳袄。
GIT的tag標(biāo)簽
tag標(biāo)簽用來標(biāo)記一個(gè)版本的信息,其實(shí)和引用名稱非常的類似纺酸,區(qū)別在于一個(gè)使用的是update-ref窖逗,一個(gè)使用的是tag命令。常用的幾個(gè)tag命令有:
- git tag
- git tag -a tagName
- git tag -d tagName
我們?nèi)绻Mo某個(gè)標(biāo)簽打上標(biāo)簽餐蔬,直接使用git tag -a 即可碎紊,這樣當(dāng)前的版本就會(huì)打上一個(gè)標(biāo)簽佑附,打上的標(biāo)簽會(huì)以引用名稱的形式存儲(chǔ)在refs/tag文件夾中,使用-a之后會(huì)打開一個(gè)類似于vi的界面仗考,命令和vi一樣音同,在這個(gè)里面可以加入標(biāo)簽的說明,不加-a就只會(huì)直接創(chuàng)建這個(gè)標(biāo)簽秃嗜。
通過git tag來查詢倉庫中的所有tag,使用git tag -d tagName可以刪除這個(gè)標(biāo)簽必搞。當(dāng)創(chuàng)建了標(biāo)簽之后可以通過git cat-file -p tagName來訪問這個(gè)標(biāo)簽必指,其實(shí)整個(gè)操作的原理和引用名稱一模一樣。
GIT的相對名稱
GIT的相對名稱其實(shí)不算很重要恕洲,我們可以通過~和這兩個(gè)符號來定位git的組件塔橡,這里需要強(qiáng)調(diào)一下如何是在windows的命令提示符中兩個(gè)才表示一個(gè)^,所以如果要測試這個(gè)相對名稱建議打開git bash來進(jìn)行操作霜第,現(xiàn)在win10的系統(tǒng)中自帶了windows ubuntu葛家,可以直接在命令提示符中使用ubuntu的命令,此時(shí)可以使用ssh-agent bash
進(jìn)入bash模式庶诡,如果進(jìn)不去請使用git自帶的bash惦银。
在具體講解~和^的區(qū)別的之前咆课,我們先學(xué)會(huì)一個(gè)命令 git rev-parse
末誓,該命令可以將引用名稱解析為具體的絕對名稱(commitId)。
和^這兩個(gè)符號都是用來找某個(gè)版本之前的版本晴玖,表示在當(dāng)前分支之前找,如HEAD~2就是找HEAD之前的兩個(gè)版本为流,符號用這個(gè)符號的個(gè)數(shù)來找呕屎,如HEAD就表示HEAD之前的兩個(gè)版本(這里要注意的還是在window的命令提示符下,才表示一個(gè))敬察。但是在之前也可以加入數(shù)字秀睛,這個(gè)數(shù)字的意思是它的第幾個(gè)parent,如HEAD2^:表示從最新版本找它的第二個(gè)父節(jié)點(diǎn)之前的一個(gè)版本莲祸,究竟為什么會(huì)有第二個(gè)父節(jié)點(diǎn)呢蹂安?我們應(yīng)該注意只要合并了分支之后就會(huì)有兩個(gè)parent了椭迎。
我們在剛才的工廠中創(chuàng)建個(gè)分支,并且在有分支之后每個(gè)分支進(jìn)行兩次提交田盈,之后在master上合并分支畜号。
使用了lg這個(gè)別名之后述暂,我們發(fā)現(xiàn)顯示的信息很多替饿,*表示版本的上一級commitId,大家看,當(dāng)前HEAD版本有兩個(gè)parent贸典,一個(gè)是b1分支的fcca视卢,另外一個(gè)parent分支是master上的4ba0。在圖形中已經(jīng)用樹形結(jié)構(gòu)非常直觀的表現(xiàn)出來了廊驼。
現(xiàn)在我們來使用~和^來看看版本信息.
我們發(fā)現(xiàn)HEAD~2是找目前分支上的前兩個(gè)版本,所以找到了872C這個(gè)版本酝掩,而HEAD2表示找自己上一個(gè)版本的第二個(gè)分支上的前一個(gè)版本鳞芙,所以找到了1913這個(gè)版本。我們可以嘗試HEAD3看看結(jié)果期虾。
它提示沒有找到相應(yīng)的版本,這就是git的相對名稱茂蚓。注意以上的~和^這個(gè)操作都是在bash中完成的壕鹉。
利用git的reflog追蹤版本信息
這一講最后的一個(gè)話題是關(guān)于reflog的,git的reflog非常的有用聋涨,因?yàn)楫?dāng)我們使用reset
命令回到某個(gè)版本之后晾浴,在log中就不會(huì)再顯示后續(xù)的版本信息了
此時(shí)如果關(guān)閉了命令提示符,我們就沒有辦法獲取后續(xù)版本的信息牍白,在git中脊凰,所有的版本信息都存儲(chǔ)在文件夾.log/HEAD文件中,大家可以打開這個(gè)文本文件查詢一下淹朋,每一個(gè)版本都存在在這里笙各,git中通過reflog命令可以很好獲取所有的日志版本钉答。
每個(gè)commitId都有一個(gè)引用名稱HEAD@{x},這個(gè)名稱用數(shù)字來表示你操作的第幾個(gè)版本杈抢,HEAD@{0}表示當(dāng)前版本数尿,HEAD@{1}表示上一次操作的版本(注意:不是上一個(gè)版本,上一次進(jìn)行reset的版本)惶楼。根據(jù)最后的提示信息可以很方便的回到我們需要的版本右蹦。我們可以通過命令git reflog b1
查詢b1分支上的reflog。
好了歼捐,這一講的內(nèi)容就這么多了何陆,主要講解git常用的幾個(gè)名稱和使用reflog來追蹤歷史版本信息,這些在使用git時(shí)都是有一定的意義和作用的豹储。