git-子仓操作

为什么

为什么要将代码仓作为子模块?有什么优势?

  1. 精确版本控制:父仓记录子仓的commit哈希值,确保代码版本固定,避免隐式升级导致的兼容性问题
  2. 模块化管理:将独立仓库作为子模块嵌入父仓,实现代码物理隔离,支持多团队写作与独立开发
  3. 代码复用与共享:同一模块可被多个项目引用,避免重复代码,确保一致性
  4. 权限与协作分离:子模块独立管理,父仓开发者无需介入子模块开发流程

父子仓项目结构

python 复制代码
主仓库:Project/
├── 子模块A  (通过submodule链接仓库)
├── 子模块B
└── 子模块C

相关操作

1. 添加子仓

bash 复制代码
git submodule add <repo> <Current_DIR Path>

添加以后,git会在父仓create两个文件:

  1. new file------> .gitmodules (保存子仓作为子模块所在的路径以及repo_url)

  2. new file -------> repo_file(子仓,由于是通过哈希值链接,所以是以file的形式存储而不是dir)

2. 更新子仓commit

在开发过程中,子仓会不断commit,所以父仓要随时或者定期的进行update submodule。

update 子仓commit:

bash 复制代码
git submodule update --remote <Current_DIR Path>

执行完上面操作后,本地submodule更新了,但是父仓remote尚未更新,所以需要单独push一下repo_file(保证父仓commit哈希与子仓最新commit一致):

bash 复制代码
git add <Current_DIR Path>

git commit -m "update submodule"

git push origin cc/appworld

3. 相同路径更换子仓

有时候我们可能需要在相同路径下更换不同的仓库作为submodule,该操作需要

删除:

  1. 该路径下submodule的git索引
  2. 彻底删除子模块的内部 Git 配置目录
  3. 删除物理文件

code options:

bash 复制代码
# 查看该submodule是否被git追踪
git ls-files | grep <submodule_path>
# 删除git索引
git rm --cache <submodule_path>
# 彻底删除子模块的配置信息 确保路径干净
rm -rf .git/modules/<submodule_path>
# 将新仓库作为子仓链接 (忽略冲突)
git submodule add -f <new_repo_url> <submodule_path> 

补充:

-->git的索引是暂存区,记录了哪些文件需要被提交到仓库,--cache选项表示从索引中移除该文件不再追踪,但是物理文件还是在的,所以需要手动删除一下物理文件然后重新submodule add

--> git子模块本质是一个嵌套的git仓库,其配置和对象都存储在.git/modules/<submodule_path>,rm -rf会强制递归删除路径下所有内容。相当于彻底清除子模块与git的联系。

--> git submodule add -f 中 -f是强制重新添加,避免忘记删除物理文件导致的existing error(忽略冲突)

还有一个更为便捷的方法,直接更新子模块的url:

bash 复制代码
git submodule set-url <path>  <new-url>

该操作仅仅更新仓库url并不会将原有仓库的文件进行更替或者删除

4. 子模块中包含其他子模块

如果你需要添加的子仓中也潜逃了子仓,那么需要执行下面命令进行添加

bash 复制代码
# 初始化并更新嵌套子模块
git submodule update --init --recursive

# 克隆主仓库时自动初始化嵌套子模块
git clone --recurse-submodules --recursive <main-repo-url>
相关推荐
MUTA️21 小时前
git传输超过100MB的文件
git
ALex_zry21 小时前
Git大型仓库推送失败问题完整解决方案
大数据·git·elasticsearch
二进制coder1 天前
Git Fork 开发全流程教程
大数据·git·elasticsearch
程序员馨馨1 天前
不扰远程仓库,本地双版本:master 留 A 稿,分支藏 B 稿
git
无限进步_1 天前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
用户47861297206921 天前
Git:如何排查非线性历史中被隐秘覆盖的修改(完整实战笔记)
git
weixin_377634841 天前
【Git使用】PyCharm中的Git使用
ide·git·pycharm
爱吃泡芙的小白白1 天前
vscode、anaconda、git、python配置安装(自用)
ide·git·vscode·python·anaconda·学习记录
ALex_zry1 天前
Git大型仓库推送失败问题解决方案:大文件传输优化指南
git
草莓熊Lotso1 天前
Git 分支管理:从基础操作到协作流程(本地篇)
大数据·服务器·开发语言·c++·人工智能·git·sql