Git submodule - Git子模塊簡(jiǎn)介

目錄

  1. 建立倉(cāng)庫(kù)
    1.1 創(chuàng)建主倉(cāng)庫(kù)
    1.2 創(chuàng)建子倉(cāng)庫(kù)
  2. 提交內(nèi)容
    2.1 提交到主工程的倉(cāng)庫(kù)
    2.2 提交到子模塊的倉(cāng)庫(kù)
  3. 克隆帶子模塊的倉(cāng)庫(kù)到本地
  4. 更新子倉(cāng)庫(kù)
  5. 總結(jié)
  6. 參考文檔

正文

軟件開(kāi)發(fā)中有一個(gè)DRY(Don't Repeat yourself)原則香拉,或者說(shuō)DIE(Duplication Is Evil)原則径密,指的是盡可能減少一切重復(fù)工作钳吟,重用一切可能重用的東西,小到提取重復(fù)性代碼鸳址,大到重用一個(gè)模塊。時(shí)間就是金錢(qián)泉懦,效率就是生命稿黍。
使用Git管理項(xiàng)目的時(shí)候,如果涉及到模塊重用崩哩,比如你需要用到別的倉(cāng)庫(kù)提供的功能巡球,雖然你可以直接把別人倉(cāng)庫(kù)(當(dāng)然也可以是自己的倉(cāng)庫(kù))的代碼復(fù)制到你的工程目錄下,但是這樣當(dāng)別的倉(cāng)庫(kù)更新了邓嘹,我們也想相應(yīng)的更新我們所依賴的代碼酣栈,或者我們對(duì)依賴的代碼做了些更改想要合并到原倉(cāng)庫(kù),這時(shí)候事情就比較麻煩了汹押。所以矿筝,我們希望主模塊和子模塊的的管理是分開(kāi)的,也就是主模塊的更改棚贾、提交等窖维,是不涉及子模塊的榆综,反過(guò)來(lái)子模塊也一樣。但是又希望他們之間有一個(gè)依賴關(guān)系铸史,怎么辦呢奖年?
Git為了這種困境提供了一個(gè)解決方案:子模塊(submodule)。
為了便于理解沛贪,我們把當(dāng)前工作工程倉(cāng)庫(kù)成為主倉(cāng)庫(kù)陋守,主倉(cāng)庫(kù)所依賴的子模塊倉(cāng)庫(kù)成為子倉(cāng)庫(kù)。

建立倉(cāng)庫(kù)

創(chuàng)建主倉(cāng)庫(kù)

mkdir demo && cd demo && git init

創(chuàng)建子倉(cāng)庫(kù)

創(chuàng)建子倉(cāng)庫(kù)用到的命令是git submodule add <repo> [<path>]利赋。其中repo是你要添加為子模塊的倉(cāng)庫(kù)URL水评,path是主工程下的一個(gè)路徑,就相當(dāng)與你在主工程下創(chuàng)建的一個(gè)專(zhuān)門(mén)用于保存子倉(cāng)庫(kù)代碼的文件夾媚送,名字是任意的中燥,只不過(guò)習(xí)慣上用third_party利于區(qū)分和理解。例如我們將pybind11添加為子模塊塘偎,其相對(duì)路徑為third_party/pybind11疗涉,我們可以使用以下命令:

git submodule add https://github.com/pybind/pybind11 third_party/pybind11

值得注意的是,pybind11這個(gè)目錄在在使用命令前是不能存在與third_party目錄之下的吟秩。并且咱扣,此命令執(zhí)行完成以后,子倉(cāng)庫(kù)的代碼就被拉取到third_party/pybind11之中了涵防。

提交內(nèi)容

主倉(cāng)庫(kù)和子倉(cāng)庫(kù)之間闹伪,除了子倉(cāng)庫(kù)位于主倉(cāng)庫(kù)內(nèi),主倉(cāng)庫(kù)對(duì)子倉(cāng)庫(kù)的代碼有所依賴以外壮池,他們之間是沒(méi)有其他任何聯(lián)系的偏瓤。他們呢就相當(dāng)于兩個(gè)倉(cāng)庫(kù),主倉(cāng)庫(kù)不會(huì)跟蹤子倉(cāng)庫(kù)內(nèi)容的變化椰憋,反過(guò)來(lái)子倉(cāng)庫(kù)也不去跟蹤子倉(cāng)庫(kù)的任何信息厅克。就類(lèi)似古代周邊某些附屬小國(guó),雖然名面上朝貢橙依、附屬证舟,但實(shí)際上小國(guó)的治理和天朝是分開(kāi)的。

提交到主工程的倉(cāng)庫(kù)

對(duì)主工程內(nèi)容的提交操作票编,與一般無(wú)子工程的倉(cāng)庫(kù)操作并無(wú)二致褪储。

提交到子模塊的倉(cāng)庫(kù)

如果有需要對(duì)子模塊的內(nèi)容進(jìn)行修改并提交到其倉(cāng)庫(kù),可以進(jìn)入到子模塊倉(cāng)庫(kù)所在目錄慧域,再進(jìn)行相應(yīng)的操作鲤竹。例如,我們使用cd third_party/pybind11進(jìn)入到子模塊倉(cāng)庫(kù),這時(shí)候我們可以使用git add, git commit等對(duì)更改進(jìn)行操作辛藻,這些操作之對(duì)子模塊倉(cāng)庫(kù)產(chǎn)生影響碘橘。

克隆帶子模塊的倉(cāng)庫(kù)到本地

當(dāng)我們需要克隆一個(gè)帶子倉(cāng)庫(kù)的倉(cāng)庫(kù)時(shí),我們希望子倉(cāng)庫(kù)的內(nèi)容也是跟主倉(cāng)庫(kù)一起保存在本地的吱肌。當(dāng)使用git clone xxxx.git將主倉(cāng)庫(kù)克隆到本地后痘拆,子倉(cāng)庫(kù)所在目錄只有一個(gè)空目錄,子倉(cāng)庫(kù)內(nèi)容其實(shí)并為下載到本地氮墨。有兩種方法:

  1. 在克隆主倉(cāng)庫(kù)時(shí)加上--recurse-submodules纺蛆,使用這種方法,子倉(cāng)庫(kù)內(nèi)容也會(huì)同時(shí)下載下來(lái)规揪,如果子倉(cāng)庫(kù)還包含子倉(cāng)庫(kù)桥氏,也會(huì)被同時(shí)下載下來(lái)。
git clone xxxx.git --recurse-submodules
  1. 第二種方法是使用下面兩條命令:
git submodule init
git submodule update

值得注意的是猛铅,不管使用以上那兩種方法字支,子倉(cāng)庫(kù)的內(nèi)容雖然下載下來(lái)了,但是此時(shí)子倉(cāng)庫(kù)的狀態(tài)是處于一種HEAD detached的狀態(tài)奸忽,也就是此時(shí)堕伪,你對(duì)子倉(cāng)庫(kù)的更改,就算你已經(jīng)commit但是當(dāng)你下次使用git submodule update你所作的更改也會(huì)丟失栗菜。所以欠雌,你學(xué)要checkout`到一個(gè)工作分支,例如:

git checkout master

更新子倉(cāng)庫(kù)

更新子倉(cāng)庫(kù)內(nèi)容有兩種方法苛萎,一種是進(jìn)入到子倉(cāng)庫(kù)所在目錄桨昙,進(jìn)行常規(guī)的拉取和合并操作检号;

cd ./third_party/pybind11 
git fecth 
git merge

另一種是使用git submodule update --remote

git submodule update --remote 
git submodule update --remote <submodule ame>

兩條命令的區(qū)別是腌歉,如果不帶子倉(cāng)庫(kù)名,默認(rèn)會(huì)更新所有子倉(cāng)庫(kù)齐苛,如果只想更新其中某個(gè)翘盖,需要指定需要更新的子倉(cāng)庫(kù)名。

總結(jié)

對(duì)于帶子倉(cāng)庫(kù)的倉(cāng)庫(kù)凹蜂,有兩種情況:

  1. 本地新建倉(cāng)庫(kù)馍驯,需要建立與遠(yuǎn)程子倉(cāng)庫(kù)的依賴關(guān)系;
  2. 克隆已有帶子倉(cāng)庫(kù)的倉(cāng)庫(kù)到本地玛痊。
    第一種情況:
git submodule add <repo> [<path>]

第二種情況:

git submodule init [<path>]
git submodule update
git checkout <branch>

至此汰瘫,依賴關(guān)系建立起來(lái)了,兩個(gè)倉(cāng)庫(kù)之間便可以獨(dú)自操作擂煞。
可以使用git add, git commit, git status等各自操作混弥。一句話,說(shuō)的底盤(pán)聽(tīng)水的:在主倉(cāng)庫(kù)目錄下对省,操作的是主倉(cāng)庫(kù)內(nèi)容蝗拿;cd third_party/sumdir進(jìn)入到子倉(cāng)庫(kù)晾捏,操作的便是子倉(cāng)庫(kù)內(nèi)容。

References

  1. Git-Tools-Submodules
  2. Manual: man git submodule



這就是我的底線0小惦辛!歡迎搜索關(guān)注TensorBoy , 學(xué)習(xí)使我快樂(lè)!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末仓手,一起剝皮案震驚了整個(gè)濱河市胖齐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌嗽冒,老刑警劉巖市怎,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異辛慰,居然都是意外死亡区匠,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén)帅腌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)驰弄,“玉大人,你說(shuō)我怎么就攤上這事速客∑莞荩” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵溺职,是天一觀的道長(zhǎng)岔擂。 經(jīng)常有香客問(wèn)我,道長(zhǎng)浪耘,這世上最難降的妖魔是什么乱灵? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮七冲,結(jié)果婚禮上痛倚,老公的妹妹穿的比我還像新娘。我一直安慰自己澜躺,他們只是感情好蝉稳,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著掘鄙,像睡著了一般耘戚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上操漠,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天收津,我揣著相機(jī)與錄音,去河邊找鬼。 笑死朋截,一個(gè)胖子當(dāng)著我的面吹牛蛹稍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播部服,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼唆姐,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了廓八?” 一聲冷哼從身側(cè)響起奉芦,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎剧蹂,沒(méi)想到半個(gè)月后声功,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宠叼,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年先巴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片冒冬。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伸蚯,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出简烤,到底是詐尸還是另有隱情剂邮,我是刑警寧澤,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布横侦,位于F島的核電站挥萌,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏枉侧。R本人自食惡果不足惜引瀑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望棵逊。 院中可真熱鬧伤疙,春花似錦、人聲如沸辆影。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蛙讥。三九已至,卻和暖如春灭衷,著一層夾襖步出監(jiān)牢的瞬間次慢,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留迫像,地道東北人劈愚。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像闻妓,于是被迫代替她去往敵國(guó)和親菌羽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

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

  • 在一個(gè)項(xiàng)目中使用另一個(gè)項(xiàng)目由缆,兩個(gè)項(xiàng)目分別有各自的倉(cāng)庫(kù)以及各自的維護(hù)周期 添加外部項(xiàng)目為子模塊 文檔參考 .6 Gi...
    錢(qián)英俊真英俊閱讀 1,377評(píng)論 0 2
  • git常用命令 注意:請(qǐng)確保已經(jīng)安裝里git客戶端 git使用幫助 git --help //git使用幫助均唉,可...
    憤怒的五百萬(wàn)閱讀 6,833評(píng)論 0 2
  • git子模塊的使用 git子模塊可以用于項(xiàng)目包含另一個(gè)項(xiàng)目的情況是晨,也許是第三方庫(kù)或被多個(gè)項(xiàng)目引用的基礎(chǔ)框架。此次學(xué)...
    看似平淡閱讀 3,029評(píng)論 0 0
  • 開(kāi)發(fā)中我們經(jīng)常會(huì)遇到這樣的情況:項(xiàng)目越來(lái)越大舔箭,一些通用的模塊我們希望將他抽離出來(lái)作為單獨(dú)的項(xiàng)目罩缴,以便其他項(xiàng)目也可以...
    feil0n9wan9閱讀 19,956評(píng)論 0 24
  • 獲取與創(chuàng)建項(xiàng)目 創(chuàng)建倉(cāng)庫(kù)的途徑有:在本地已有的目錄,初始化一個(gè)新的层扶;克隆復(fù)制一份別人的項(xiàng)目靴庆。 git init 在...
    daking閱讀 6,576評(píng)論 3 48