Git - 子模块

做为一名程序员,大家对 ** Git ** 肯定都不陌生,最近项目中用到了 Git 子模块,今天,给大家讲一下 ** Git ** 子模块。

通常,一个大型工程总会被分拆为一些子工程。这既有利于工程开发难度的降低,也有利于使用现成的方案或者第三方方案作为子工程。git submodule 就是完成这样一种子工程拆分与整合的工具。下面开始简单介绍一下 git submodule 的用法。

什么是 Submodule?

git Submodule 是一个很好的多项目使用共同类库的工具,他允许类库项目做为 ** repository ** ,子项目做为一个单独的 git 项目存在父项目中,子项目可以有自己的独立的 ** commit push pull 。而父项目以 Submodule 的形式包含子项目,父项目可以指定子项目 header,父项目中会的提交信息包含 Submodule 的信息,再 ** clone 父项目的时候可以把 **Submodule **初始化。

在项目中使用Submodule

  • 在项目中添加 Submodule,使用 git submodule add + 仓库地址,例如
git submodule add git@github.com:jjz/pod-library.git pod-library
  • 查看当前状态
git status
On branch master
 Changes to be committed:
       new file: .gitmodules 
       new file: pod-library

可以看到多了两个需要提交的文件:.gitmodules 和 pod-library
**.gitmodules ** 内容包含 Submodule 的主要信息,指定 reposirory 的路径

[submodule "pod-library"] 
path = pod-library 
url = git@github.com:jjz/pod-library.git

可以看到记录了子项目的目录和子项目的 git 地址信息。

  • 另外,这两个文件都需要提交到父项目的git中。
git add .gitmodules pod-ibrary
git commit -m "pod-library submodule"
git submodule init
  • 修改Submodule

    首先需要确认有对Submodule的commit权限,如果没有权限,则不能提交提交代码到父项目上。

  • 进入 Submodule 目录里面

cd pod-library/
  • 修改其中的一个文件,并且查看改动
git status
modified: pod-library/UseAFHTTP.h
  • 提交Submodule的更改内容
git commit -a -m'test submodule'
  • 然后 push 到远程服务器
git push
  • 然后再回到父目录,提交Submodule在父项目中的变动
cd ..
git status
modified: pod-library (new commits)

可以看到 pod-library 中已经变更为 Submodule 最新的 commit id

Subproject commit 330417cf3fc1d2c42092b20506b0d296d90d0b5f
  • 需要把 Submodule 的变动信息推送到父项目的远程服务器
git commit -m'update submodule'
git push

这样就把子模块的变更信息以及子模块的变更信息提交到远程服务器了,从远程服务器上更新下来的内容就是最新提交的内容了。

  • 更新 Submodule
    更新Submodule有两种方式
  1. 在父项目的目录下直接运行
git submodule foreach git pull
  1. 在Submodule的目录下面更新
cd pod-library
git pull
  • 克隆 Submodule
    clone Submodule 有两种方式 一种是采用递归的方式 clone 整个项目,一种是 clone 父项目,再更新子项目。
  1. 采用递归参数 --recursive
git clone git@github.com:jjz/pod-project.git --recursive

执行结果

loning into 'pod-project'...
remote: Counting objects: 57, done.
remote: Compressing objects: 100 % (45 / 45), done.
remote: Total 57(delta 13), reused 49(delta 8), pack - reused 0
Receiving objects: 100 % (57 / 57), 18.79 KiB | 0 bytes / s, done.
Resolving deltas: 100 % (13 / 13), done.
Checking connectivity...done.
Submodule 'pod-library' (git @github.com: jjz / pod - library.git) registered
for path 'pod-library'
Cloning into 'pod-library'...
remote: Counting objects: 34, done.
remote: Compressing objects: 100 % (25 / 25), done.
remote: Total 34(delta 8), reused 30(delta 7), pack - reused 0
Receiving objects: 100 % (34 / 34), 12.95 KiB | 0 bytes / s, done.
Resolving deltas: 100 % (8 / 8), done.
Checking connectivity...done.
Submodule path 'pod-library': checked out '330417cf3fc1d2c
42092 b20506b0d296d90d0b5f '

可以看到 init Submodule 会自动被 clone 下来

  1. 先 clone 父项目,再初始化 Submodule
    执行
git clone git@github.com:jjz/pod-project.gitcd pod-project
git submodule init

会看到

Submodule 'pod-library' (git@github.com:jjz/pod-library.git) 
registered for path 'pod-library'

然后更新 Submodule

git submodule update

看到输出结果为

  Cloning into 'pod-library'...
  remote: Counting objects: 34, done.
  remote: Compressing objects: 100 % (25 / 25), done.
  remote: Total 34(delta 8), reused 30(delta 7), pack - reused 0
  Receiving objects: 100 % (34 / 34), 12.95 KiB | 0 bytes / s, done.
  Resolving deltas: 100 % (8 / 8), done.
  Checking connectivity...done.
  Submodule path 'pod-library': checked out '330417cf3fc1d2c42092b20506b0d296d90d0b5f'

所以,用两种方法都能初始化 Submodule

  • 删除 Submodule
    git 并不支持直接删除 Submodule,需要手动删除对应的文件:
cd pod-project
git rm --cached pod-library
rm -rf pod-library
rm .gitmodules

更改 git 的配置文件 config

vim .git/config

可以看到 Submodule 的配置信息:

[submodule "pod-library"] 
    url = git@github.com:jjz/pod-library.git

删除submodule相关的内容,然后提交到远程服务器

git commit -a -m 'remove pod-library submodule'

Submodule 有在项目开发的过程中有很大的用处,希望文章对大家有帮助。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 使用场景 基于公司的项目会越来越多,常常需要提取一个公共的类库提供给多个项目使用,但是这个library怎么和gi...
    姜家志阅读 18,517评论 1 26
  • git子模块的使用 git子模块可以用于项目包含另一个项目的情况,也许是第三方库或被多个项目引用的基础框架。此次学...
    看似平淡阅读 3,015评论 0 0
  • 写在前面: 1、使用Git Submodule可能遇到的坑(http://blog.devtang.com/201...
    Funnyer阅读 5,745评论 0 0
  • 好几年前脑子里就住进了一个童话 主角是一只 雪白的 放电影的 熊 在森林深处一个祥和的小村中 电影放映员熊君每天负...
    深藏攻与名阅读 293评论 0 1
  • 今天是一个值得纪念的日子,二零一柒年二月二十二日。今天下雪了,是儿子生命中第一场雪。 儿子五岁了,一直以来都欠他一...
    6cb106582cd2阅读 732评论 0 3