您现在的位置: 首页 资讯 > > 正文
Git 子模块 天天快看
发布时间:2023-06-28 10:18:18 来源:博客园


(相关资料图)

1 概览

使用 Git 管理源代码,进行子模块操作时,此文可作为参考(Lookup Cheat-Sheet)

2 何时使用 submodules

合适的场景:

子模块代码应独立于其他应用者项目(container/container project)。不依赖,高内聚,同一代码库共享于多个应用者项目。代码规模大,若其中某个同样大规模的代码模块长时间不需要更新,器皿项目无需每次拉取时都涉及该模块时,应将该模块独立为子模块。方便合作代码贡献者可以选择只初始化一次,之后都不再提取(fetch)该子模块。子模块与器皿项目应用不同的框架或语言。

与其使用 submodules,不如使用 subtrees 的场景:

需要让某个模块具有子代码的概念,作为一个器件,依附于器皿项目当中,对其做定制化修改,而不用去动器皿项目,只操作器件。同时具备管理一套代码库的简便性。模块简单,或模块有依赖器皿项目的代码,则不必拆分为单独的项目仓储,避免冗杂的本地/远程引用(ref)管理。所有代码都是一套本地代码。
SubmodulesSubtrees
更复杂 (尤其对初学者)更简单
另一个仓储的一个提交引用链接代码提交会合并到器皿项目的提交历史中
能够单独被访问(存在于中心服务器中的独立仓储)去中心化(直接通过器皿项目访问)
需要更多的步骤来操作克隆,拉取,推送都与之前相同(当然也有针对子树的命令)
不占用器皿项目仓储大小直接占用器皿项目仓储容量
3 使用技巧及规范3.1 为仓储添加和配置子模块
# 添加子模块并跟踪名称为 branch_name 的分支,不加 -b 将会对后续子模块的跟踪产生影响git submodule add -b branch_name URL_to_Git_repo optional_directory_path
3.1.1 一般原则

为子模块设定分支。除了 git submodule add时使用 -b参数设定以外,还可以通过修改 .gitmodules 文件更改。

设计好仓储内子模块的存放路径。除了 git submodule add时通过 optional_directory_name设定以外,还可以通过修改 .gitmodules 文件更改。

注:除了直接用文本编辑器修改 .gitmodules 文件以外,还可以通过命令进行修改(参考如下示例)。

# 查看现有的 submodule 属性git config --file=.gitmodules -l# 修改 submodule 属性git config --file=.gitmodules submodule.modulename.branch branch_namegit config --file=.gitmodules submodule.modulename.path path/to/submodulegit config --file=.gitmodules submodule.modulename.url URL_to_Git_repo
3.2 从一个已经设置好子模块的仓储获取子模块
# 克隆仓储时,同时克隆仓储的子模块,相当于进行了子模块的初始化和更新git clone --recursive URL_to_Git_repo
# 克隆仓储后,初始化并更新子模块,子模块就会引用子模块仓储默认分支下最新一次提交git submodule update --init
# 子模块设置变更、子模块变更(新增、更名、删除等)git pullgit submodule syncgit submodule update --init
3.2.1 对子模块仓储直接进行代码编写
# 签出分支,使子模块具备拉取最新修改并直接连通父仓储推送的能力git submodule foreach "git checkout $(git config -f $toplevel/.gitmodules submodule.$name.branch || echo main)"
# 子模块远程有更新,需要获取。以下命令等同于进入子模块目录执行 `git pull`。如果本地有未提交的修改,均需要合并操作,有冲突无法合并则获取会失败。git submodule update --remote --merge
# 推送代码到远程分支git push --recurse-submodules=on-demand
3.2.2 不更改子模块代码

使用 detached HEAD,子模块链接的是提交 commit 的哈希值 hash。无法拉取或提交代码,只能通过更新仓储的子模块版本,再通过 git submodule update命令更新子模块。

3.3 删除已有子模块
# 从 .git/config 中删除子模块git submodule deinit -f path/to/submodule# 从器皿项目(父项目)的 .git/modules 目录中删除子模块文件夹rm -rf .git/modules/path/to/submodule# 从 .gitmodules 中去掉子模块入口并删除子模块所在物理路径 path/to/submodule 下的所有文件git rm -f path/to/submodule
3.4 常用命令解析
# 为所有子模块执行 git 命令,-q 参数静默模式,--recursive 循环操作所有子模块(包括子模块的子模块引用)git submodule foreach "git command"
# 更新子模块# --remote 从子模块远程分支更新(最新),不加此参数则从父仓储的子模块版本链接更新(对应提交哈希值)# --recursive 循环操作所有子模块(包括子模块的子模块引用)# --merge,合并远程分支的修改,有冲突需要解决冲突。不会 detach HEAD。# --rebase,撤销本地提交,临时保存并保留本地修改,应用远程修改,再将本地修改合并,合并时同样需要解决冲突。不会 detach HEAD。git submodule update

注:对于 --remote 而言

remote 使用 submodule..branch=branch_name来确认分支名称,若未设置则使用远程仓储设定的默认分支。再通过读取子模块 branch.branch_name.remote=origin来确认从远程分支获取的地址和 HEAD,默认为 detached HEAD,对应 remotes/origin/HEAD,获取该分支最新提交。如果本地子模块签出了某个分支,则 HEAD attached 到对应分支,即 branch.branch_name.merge=refs/heads/branch_name。如果本地子模块当前的 HEAD commit hash 和 submodule..branch中的值不一致的话,会导致子模块被 detach HEAD,不再追踪某个分支,而是映射到 submodule..branch最新的提交上。以上通常存在两种情况,第一种是 HEAD 和 submodule..branch分支本身就不同。第二种是本地子模块的提交落后于 submodule..branch最新的提交。通过添加 --merge 参数可以避免 detachment。如果子模块有本地提交并与远程提交产生了冲突,需要用 --rebase 参数来解决。子模块内使用 git pull直接使用的是对应分支的 HEAD,为 branch.branch_name.merge=refs/heads/branch_name。对应上述第2点,和一个签出 branch_name 分支后 HEAD attach 到 heads/branch_name 的子模块的 HEAD 是一致的。
3.5 常用 git 设置(推荐进行配置)除了直接改 .gitconfig 文件,还可通过命令查看和更改
# 查看现有 git 设置git config --global -l# 修改现有 git 设置git config --global status.submoduleSummary truegit config --global diff.submodule loggit config --global alias.spush "push --recurse-submodules=on-demand"
查看 submodule 提交变更
[status]submoduleSummary = true
diff 时可以看到 submodule 的变更项
[diff]submodule = log
命令别名
[alias]sdiff = "!git diff && git submodule foreach "git diff""spull = "!git pull && git submodule sync && git submodule update --init"smerge = "submodule update --remote --merge"srebase = "submodule update --remote --rebase"scheckout = "submodule foreach "git checkout $(git config -f $toplevel/.gitmodules submodule.$name.branch || echo main) && git pull""spush = "push --recurse-submodules=on-demand"
4 参考链接官方链接1官方链接2Github个人分享1Github个人分享2submodules vs subtrees

标签:

股市蒸发的钱去哪里了?股票割肉的钱去哪了?

我们经常会看到一些消息说,某某股票大跌市值蒸发多少亿元,实际上股市蒸发的钱都被平摊走了。在股票跌...

粤 水 电: 第七届董事会第三十二次会议决议公告_世界今日报

证券代码:002060   证券简称:粤水电   公告编号:临 2022-177        广东水电二局股...

扬杰科技:发行GDR申请事宜获中国证监会受理|每日热点

(原标题:扬杰科技:发行GDR申请事宜获中国证监会受理)证券时报e公司讯,扬杰科技(300373)12月6日晚间...

沪深两市合计成交量继续小幅萎缩 大盘反弹中个股涨多跌少

沪深两市7月7日探底回升,合计成交量继续小幅萎缩,大盘反弹中个股涨多跌少。龙虎榜中,虽然大盘出现反...

多家基金公司发布溢价风险提示 LOF基金二级市场表现异常

近日,多只场内规模不大、流动性欠缺的LOF产品的二级市场交易坐上过山车,价格在多个交易日内暴涨暴跌。...

业绩预增股走出强势独立行情 吸引了机构抢筹

近期市场震荡盘整,业绩预增股却走出强势独立行情,而部分机构已提前埋伏其中,部分业绩大幅预增股则吸...

重庆:到2025年25个重点领域企业能效全部达到基准水平

3月18日,重庆日报记者从市发展改革委获悉,日前,市发展改革委、市经济信息委、市生态环境局、市市场监...

重磅!2021“发现重庆之美”获奖名单揭晓

3月19日,2021发现重庆之美颁奖典礼在线上举行,最美城市管理人、最美坡坎崖、最美街头绿地、垃圾分类时...

去年重庆回收废弃农膜1.4万吨 农膜回收率达89.31%

3月16日,市五届人大常委会第六十九次主任会议听取了市政府关于《重庆市人大常委会对市人民政府农业面源...

申报分两批!今年国家级博士后科研工作站新设站工作启动

3月19日,重庆日报记者从市人力社保局获悉,为推动产学研深度融合,加强博士后工作平台建设,我市将开展...

浙江鄞州:“水、电、气、数”通办专窗实现城乡公共服务均等化

近日,在宁波市鄞州区邱隘镇公共事务服务中心,66岁的邱隘镇沈家新村居民邱秀月在一个窗口相继办理了不...

打开“浙里办” 浙江1000家农贸市场农产品可线上比价

今天哪个菜场的五花肉最便宜?食品安全抽检结果怎么样?这些问题,浙江居民只需打开浙里办APP上的浙里市场...

浙江鉴湖国家湿地公园规划发布 打造乡村数字旅游

19日上午,鉴湖国家湿地公园规划发布暨东鉴湖农旅观光体验启动仪式在绍兴市越城区陶堰街道举行。当天,...

总投资超10亿元!6个石化装备运维项目在岱山签约

日前,总投资超10亿元的6个石化装备运维项目在岱山经济开发区集中签约。此次签约的项目占地106亩,规划...

如何避免成为“买而不做”的“装备党”祝 杰

自恋是人的天性,人们总是希望自己是更好的,那么自己拥有的事物,也就相应地被自我赋予了更高的价值,...

山西临汾:率先在全省建起农村集体经济开发区

3月17日,临汾市农村集体经济发展(集团)有限公司在临汾经济开发区揭牌。以此为标志,临汾率先在全省建起...

一线工作近22年的缉毒警:我知道坏的是毒品不是人性

  “影子”般的缉毒警:一线工作22年,我知道坏的是毒品不是人性  如果我不继续干,别人也要干,缉...

广东肇庆“毒驾连撞5车致1死”肇事司机被批捕

  1月5日14时30分许,广东肇庆市端州区一男子赵某毒驾连撞5车,致一人死亡。  1月10日,澎湃新闻(ww...

江西最大文物倒卖案宣判:倒卖国家二级文物 9人获刑

  中新网南昌1月10日电 (冷峥嵘 张一怡)江西省共青城市人民法院10日发布消息称,近日,该院依法审结...

青海保障门源地震后生活必需品应急物资

  中新网西宁1月10日电 (记者 孙睿)记者10日从青海省商务厅获悉,青海海北州门源县6 9级地震灾害发...

广西东兴口岸恢复通关 入境需网上预约

  中新社防城港1月10日电 (翟李强)自2022年1月10日零时起,广西东兴口岸和边民互市贸易区恢复人员、...

呼和浩特:寒假期间有条件的学校要开展校内托管服务

  中新网呼和浩特1月10日电 (记者 张林虎)10日,记者从呼和浩特市教育局获悉,在暑假校内托管试点的...

“中国最后一个原始部落”翁丁老寨火灾原因公布

  “中国最后一个原始部落”翁丁老寨火灾原因公布:小孩玩火引起  中新网昆明1月10日电 (罗婕)近日...

北京市十五届人大五次会议胜利闭幕

  北京市十五届人大五次会议胜利闭幕   蔡奇陈吉宁李伟魏小东张延昆出席   张延昆齐静当选市人...

天津市委市政府致全市父老乡亲的慰问信:我们一定能够打赢

  中新网天津1月10日电 (记者 张道正)中共天津市委、天津市人民政府10日发布了“致全市父老乡亲的慰...

天津米面油存量由20天提高至30天 超市菜市场进货量翻倍

兰州名师话“美育”:“尚乐立人”分层培优 以“美”润教

子夜直击,天津寒天战“疫”

重庆姐弟被生父扔下坠亡案上诉期结束 一审法院暂未收到两被告人上诉状

天津:划定封控区 全市开展全员核酸检测

江歌母亲江秋莲:尊重法院判决,法律认定在我意料之中

中国边疆“北方第一所”:9名民警守护“生命禁区”

辟谣!网传“封控区管控区相继解封”通知并非西安

河南安阳9日12时至24时新增11例本土确诊病例

老人5折环卫工8折生活困难免费 这家面馆背后有个暖心事

铁路公安以110幅优秀书画作品庆祝人民警察节

本周中东部冷空气频繁 东北等地有降雪

河南新增本土确诊病例60例

“打拐”民警眼里的百态人生:见证一份份不愿放弃的爱

迎腊八北京晴天上线 阵风6至7级体感冻人

多省份倡议春节“非必要不离开”,这地补贴1000元

伪造国家机关证件典型案例发布 有力打击制假贩假行为

15年照顾170多个新生儿 金牌月嫂“漂”到海外去看娃

江歌母亲江秋莲诉刘鑫案一审将于今日宣判

河南省安阳市两地划为高风险地区 一地划为中风险地区

员工迟到一次罚一千引争议 单位惩戒员工法律边界何在?

以体育人 秀出“青年范儿”

保安、厨师曾被竞业限制 企业滥用竞业限制让员工很苦恼

反诈老陈破圈:人民群众在哪 就把反诈宣传开展到哪

一所中职学校的育人实践

各地严惩恶意欠薪 保障农民工及时拿到工资

中学生成剧本杀行业潜在消费人群 多方助推行业“净化”

“这就是我最好的选择”

对餐饮浪费说“不”(百姓关注)

校园“直通车” 服务“零距离”

琉璃河遗址 两段铭文共证北京三千年建城史

千元修复个人征信报告?银行:“征信修复”都是骗局

琉璃河遗址 两段铭文共证北京三千年建城史

北京公交将开展无人驾驶道路测试

河南郑州调整五地为中风险区域 公路入郑需核酸检测阴性证明

“共享法庭”让金融消费者畅享“智慧司法”便利

《传奇2》网游著作权纠纷案峰回路转 最高法五份裁决四份改判一份发回重审

三代警察:从未放弃的28年

“胡叔叔”的寻亲工作室

天津津南本轮本土疫情第3—20例阳性感染者活动轨迹公布

“团圆”行动刑侦专家吕游 每一个案例都有单独的技术方案

河南“战疫”直面五重考验

开考古书店日均两三个顾客 流量时代她决心仍是只卖书

冬奥开幕在即 “双减”催热冰雪课堂

“不得以任何借口拒收患者”彰显生命至上

天津多站进京车票暂停发售

冷空气来袭广州气温骤降 广东多地发布寒冷预警

“电话发我”——“霸气回应”疫情求助背后的城市温度

天津津南区再增20例阳性感染者,详情公布

电影《农民院士》昆明首映 为观众呈现“把论文写在大地上”

x 广告
x 广告

Copyright ©  2015-2023 华夏自然网版权所有  备案号:琼ICP备2022009675号-37   联系邮箱:435 227 67@qq.com