当前位置:   article > 正文

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

git submodule sync

一、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>
  • 1

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

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

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

3. 子模块仓库更新

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

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

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

或:

git submodule update --init
  • 1

执行后,子模块目录下就有了源码,再执行相应的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
  • 1
  • 2
  • 3
  • 4
  • 5

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

git rm --cached 子模块名称
  • 1

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

过程中问题
  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
  • 1
  • 2

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/秋刀鱼在做梦/article/detail/745566
推荐阅读
相关标签
  

闽ICP备14008679号