当前位置: 首页 > article >正文

git子模块处理的一些方法

一、实际问题

在实际应用中遇到了一些代码管理问题,一个工程需要依赖其它几个子模块。其中一个模块由于不小心在本地的应用中修改后提交了(即A中有子模块B,直接在A中将B修改提交了,而不是修改B工程,再在A中更新)即开发者将module本地hash提交到了主分支. 因此其它开发者更新时候因为gitlab中不含有这个hash分支而无法正常获取。结果导致服务器打包时无法正常的拉取相关的子模块,最终的现象就是数据不一致,引发了一些模块的崩溃。

二、初步解决

在确定是这个问题后,使用原有的命令:

#enter sub path
git submodule update --remote

本地环境可以实现,但如果使用自动环境(如Jenkins),仍然会拉取老的子模块代码。经过查找相关资料,发现可以使用下面的方法:
1、在Git中删除原子模块的依赖并再次增加
1)删除原子模块
执行下列命令:

git submodule deinit -f 子模块路径
git rm -f 子模块路径
git add -u
git commit -m "删除子模块"
git push
#也可使用其它GIT删除子模块方法 

2)增加相关模块
有两种方法:
第一种是:

git submodule add -b main --force  git@192.168.3.214:libs/子模块名字.git

第二种:

git submodule add <url> <path>
git submodule add <git库URL> path  //如果进入path则不用再指定

然后:

git add .(-u)
git commit
git push

说明:这样做可能不太安全,需要下面的4的处理方式

2、强制更新方式

git submodule foreach git pull origin main
或
git submodule foreach git submodule update --remote(此种未测试)

3、子模块改名
在上述的实际问题中,有一个子模块是需要改名字的,即可能拉下来是A,但实际的名字叫B,可以使用下面的方法:

git mv msglib msg
git submodule sync

它可以放在1的增加相关模块后,注意,如果只是单纯的修改名字,此时就可以使用提交命令提交即可。否则需要等最终一起提交修改。
4、安全说明
如果在上面直接提交子模块的更新,则可能导致安全性的问题,比如提交的有问题。那么可以使用分支的方式进行:

git checkout -b fixmiss_module

git commit -m "fix"

#git push origin fixmiss_module:main

分支提交一般容易为GIT跟踪和控制,这也是一个好的应用习惯。

三、总结

用得越多,遇到的问题也越多,这就是经验的来源。经验是一个好的东西,也是一个不好的东西。它让人可以快速的处理实际问题也可以让人固化于这种思维。至于如何打破这种边界,需要自己不断的学习,与时俱进。


http://www.kler.cn/a/304686.html

相关文章:

  • QT开发技术 【基于TinyXml2的对类进行序列化和反序列化】一
  • 网络安全面试题汇总(个人经验)
  • RV1126+FFMPEG推流项目(6)视频码率及其码率控制方式
  • springboot如何解析 Map 的泛型信息来确定要注入哪些 Bean?
  • 【Rust自学】13.2. 闭包 Pt.2:闭包的类型推断和标注
  • 接口测试自动化实战(超详细的)
  • 2024年华为9月4日秋招笔试真题题解
  • WalkMe的数字用户体验到底是啥
  • APP广告变现流量售卖,选择API还是SDK对接?
  • 前端Excel热成像数据展示及插值算法
  • DAY 9 - 10 : 树
  • 海量智库第31期 | 自治事务原理与应用解析
  • C++生成唯一值的五种方法
  • 【机器学习(六)】分类和回归任务-LightGBM算法-Sentosa_DSML社区版
  • 前端项目node版本问题导致依赖安装异常的处理办法
  • 网络安全实训七(MSF与CS互相连接)
  • “AI大语言模型+”助力大气科学相关交叉领域实践技术应用
  • ubuntu20.4安装Qt5.15.2
  • SQL案例分析:计算延迟法定退休年龄
  • vue项目如何在js文件中导入assets文件夹下图片
  • SAP B1 营销单据 - 单据字段介绍(中)
  • AI 工具如何提高工作效率
  • 果蔬识别系统性能优化之路(五)
  • Kafka 基于SASL/SCRAM动态认证部署,kafka加账号密码登录部署
  • 树莓派5开发板-安装Raspberry Pi系统-学习记录1
  • 钉钉虚拟位置打卡