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

本文详细介绍Git子模块的使用方法,包括子模块的添加、更新、删除等操作流程,以及常见问题解决策略。深入探讨如何利用子模块提高项目开发效率。

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

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

### 如何在 GitHub 上设置管理子仓库Submodules) #### 添加子模块 通过 `git submodule add` 命令可以将一个远程仓库作为子模块添加到当前项目中。命令格式如下: ```bash git submodule add <repository-url> [path] ``` 此操作会克隆指定的 `<repository-url>` 并将其放置在 `[path]` 所定义的位置下[^1]。 #### 更新子模块 当父仓库中的子模块有新的提交时,可以通过以下方式同步最新的更改: ```bash git submodule update --remote ``` 该命令会获取子模块仓库的新版本并更新本地副本[^2]。 #### 配置 SSH 身份验证 如果遇到 HTTPS 协议拉取卡住的问题,则可能是因为未正确配置用户的全局名称 (`user.name`) 或邮箱地址 (`user.email`),以及缺少有效的 SSH 密钥认证。确保已执行以下步骤来完成必要的配置: - 设置用户名:`git config --global user.name "Your Name"` - 设定电子邮件:`git config --global user.email your-email@example.com` - 创建或关联现有的 SSH 密钥至 GitHub 账户[^3] #### 删除子模块 要移除不再需要的子模块,需编辑 `.gitmodules` 文件以删除对应的条目,并运行下面两条指令清理残留数据: ```bash git rm --cached path/to/submodule rm -rf .git/modules/path/to/submodule ``` ```python import os def check_git_config(): """Check if the necessary Git configurations are set.""" name = os.popen('git config user.name').read().strip() email = os.popen('git config user.email').read().strip() if not (name and email): raise Exception("Git username or email is missing.") check_git_config() ```
评论 11
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

西京刀客

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

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

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

打赏作者

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

抵扣说明:

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

余额充值