git-github 子模块仓库更新(git submodule)/git中submodule子模块的添加、使用和删除

一、git submodule背景

Git Submodules 允许你在一个 Git 仓库中引用另一个 Git 仓库,作为其子目录。这个子目录实际上是一个指向另一个 Git 仓库的指针,而不是实际的文件。这样,你就可以在父仓库中维护一个或多个子模块仓库,每个子模块仓库都有自己的版本历史、分支和标签。

子模块有自己的分支和标签,与父仓库的分支和标签是分开的。你可以在子模块中切换到不同的分支,进行开发或测试。但是,在父仓库中,你只能通过更新子模块的提交ID来引用子模块的不同版本

项目中经常使用别人维护的模块,在git中使用子模块的功能能够大大提高开发效率。
使用子模块后,不必负责子模块的维护,只需要在必要的时候同步更新子模块即可。

1. git将submodule有关的信息在哪?

git将submodule有关的信息保存在两个地方:

  • .gitmodules在仓库中,有版本控制,修改之后会同步到其他仓库,使用submodule相关命令的时候会自动更新
  • .git/config在本地,需要手动更新,或者执行git submodule sync将新的配置从.gitmodules拷贝到.git/config
  • git submodule sync会将submodule远程的 url 配置设置到.gitmodules,并且只会影响.git/config已经有 url 的条目,指定–recursive,将会递归更新注册的submodule

2. 子模块的添加

添加子模块非常简单,命令如下:

git submodule add <repository> <path>

其中 是子模块仓库的 URL, 是子模块在父仓库中的路径。

执行成功后,git status会看到项目中修改了.gitmodules,并增加了一个新文件(为刚刚添加的路径)
git diff --cached查看修改内容可以看到增加了子模块,并且新文件下为子模块的提交hash摘要

git commit提交即完成子模块的添加。

3. 子模块仓库更新

如果你克隆了一个包含子模块的仓库,你需要初始化并更新子模块以获取其实际内容。

当使用git clone下来的工程中带有submodule时,初始的时候,submodule的内容并不会自动下载下来的,此时,只需执行如下命令:

git submodule init # 初始化子模块
git submodule update # 更新子模块到最新版本

或:

git submodule update --init

执行后,子模块目录下就有了源码,再执行相应的makefile即可。

子模块的更新

子模块的维护者提交了更新后,使用子模块的项目必须手动更新才能包含最新的提交。

在项目中,进入到子模块目录下,执行 git pull更新,查看git log查看相应提交。

完成后返回到项目目录,可以看到子模块有待提交的更新,使用git add,提交即可。

4. 删除子模块

有时子模块的项目维护地址发生了变化,或者需要替换子模块,就需要删除原有的子模块。

删除子模块较复杂,步骤如下:

rm -rf 子模块目录 删除子模块目录及源码
vi .gitmodules 删除项目目录下.gitmodules文件中子模块相关条目
vi .git/config 删除配置项中子模块相关条目
rm .git/module/* 删除模块下的子模块目录,每个子模块对应一个目录,注意只删除对应的子模块目录即可

执行:git submodule status
linux下执行:
git ls-files --stage | grep 160000 
windows下执行:
git ls-files --stage | findstr 160000

执行完成后,再执行添加子模块命令即可,如果仍然报错,执行如下:

git rm --cached 子模块名称

完成删除后,提交到仓库即可。

过程中问题
  1. fatal: Please stage your changes to .gitmodules or stash them to proceed
    D:\GoWorks\src\mylotus>git rm --cached extern/filecoin-ffi
    fatal: Please stage your changes to .gitmodules or stash them to proceed

    如果提示Please stage your changes to .gitmodules or stash them to proceed直接删掉.gitmodules文件即可
    $ rm ./gitmodules

二、git submodule工作常用总结

拉取到带有子模块的仓库时候,需要再执行以下命令:

git submodule init
git submodule update --recursive --checkout

这个命令用于更新所有子模块,并将它们切换到主仓库所期望的特定提交。通常用于确保所有子模块都更新到主仓库所期望的状态。

更新git子项目,你可以使用以下命令: 1. 首先,同步子模块的代码: `git submodule sync` [1] 2. 然后,使用以下命令来初始化更新子模块的代码: - `git submodule update --init` 用于初始化子模块的版本 [1][2] - `git submodule update --remote` 用于更新子模块到最新版本 [2] 3. 如果你在父项目中做了一些更改并想要提交子模块的新版本,你可以执行以下步骤: - 使用 `git add` 命令将子模块所在文件夹添加到暂存区 [2] - 使用 `git commit -m "说明信息"` 命令提交更改 [2] - 最后,使用 `git push` 命令将更改推送到远程仓库 [2] 综上所述,这些命令可以帮助你更新git子项目。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [git-github 子模块仓库更新git submodule)/gitsubmodule子模块添加使用删除](https://blog.csdn.net/inthat/article/details/108416238)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [git子模块的修改更新操作](https://blog.csdn.net/qq_28087491/article/details/122134008)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

西京刀客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值