架構優化——submodule轉為subtree

文章目錄

  • 背景
  • subtree優勢
  • submodule切換到subtree腳本
  • subtree使用
    • 切開發分支
    • 推送代碼
    • 同步代碼

背景

submodule過多,目前20個submodule需要切出20個分支,查看提交記錄、切分支等使用起來麻煩。

團隊深受困擾!

subtree優勢

  1. 繼承submodule的優點,基礎功能倉庫,可被其他多個倉庫同時使用
  2. 開發時,不需要再切n個分支,也不需要提到不同倉庫,只需要往主倉庫推送即可,一個倉庫一個分支,搞定日常開發,讓開發工作更愉快
  3. 代碼合并時,不需要再合那么多子倉庫

submodule切換到subtree腳本

可以一鍵切換,但是要注意m_branch的更改,更改為子模塊你想追蹤的分支名

#!/bin/bash
# set -e
m_branch="release/3_5_6_2"
cat .gitmodules | while read i; doif [[ $i == \[submodule* ]]; thenecho converting $iread impath=$(echo $i | grep -E "(\S+)$" -o)echo path: $mpathread imurl=$(echo $i | cut -d= -f2 | xargs)echo url: $murlmname=$(basename $mpath)echo name: $mname# 先獲取 commit,必須在 git rm 之前mcommit=$(git ls-tree HEAD "$mpath" | awk '{print $3}')echo commit: $mcommitgit submodule deinit -f "$mpath"echo "11"git add .git commit -m "#40664 Stage .gitmodules changes before removing submodule"git rm -r --cached "$mpath"echo "22"rm -rf "$mpath"echo "33"git config -f .gitmodules --remove-section "submodule.$mpath" || trueecho "44"git config --remove-section "submodule.$mpath" || trueecho "55"git commit -m "#40664 Removed $mpath submodule at commit $mcommit"echo "66"if ! git remote get-url "$mname" &>/dev/null; thengit remote add "$mname" "$murl"fiecho "77"# git fetch "$mname"# 用 commit 創建臨時分支并用它 add subtree# git branch -f "_$mname" "$mcommit"echo "88"git add .git commit -m "#40664 Save changes before subtree add"echo "mpath:$mpath murl:$murl  m_branch:${m_branch} "git subtree add --prefix="$mpath" "$murl" "${m_branch}"echo "99"# git branch -D "_$mname"echo "10"git commit -m "#40664 Converted $mpath submodule to subtree"echo "11"git push origin "${m_branch}"echofi
donegit rm -f .gitmodules
git commit -m "#40664 Removed .gitmodules after converting submodules"

subtree使用

接入subtree后,日常開發提交代碼,切分支等,都只對主倉庫進行操作,日常使用起來,就只是主倉庫。

更新的內容也只在主倉庫生效(默認子倉庫不會同步更新)

如需單獨更新子模塊倉庫,需要用特殊的命令

切開發分支

git checkout -b  feature/3553_xzx_subtree
git push origin  feature/3553_xzx_subtree
# 以上即可開始開發

推送代碼

git add 修改文件
git commit -m "修改內容"
git push origin  feature/3553_xzx_subtree
# 以上即可推送修改到云端(只會更新quicktron倉庫),然后直接打包即可,會把提交的修改帶上

如果需要單獨推送子模塊倉庫(只開發quicktron,是不需要做這一步的

例如params_api未來可能被quicktron以及算法那邊的倉庫共同使用,我們在params_api修復了bug,則需要推送到子模塊倉庫中去,讓算法那邊也可同步到我們的修改,則使用以下命令:

git subtree push --prefix=src/nav_process ssh://git@gitlab.flashhold.com:10022/hardware/upper_computer/basic/nav_process.git feature/3553_xzx_subtree

同步代碼

git pull origin release/3_5_5_3
git push origin  feature/3553_xzx_subtree
# 以上即可同步最新修改到本地,并且推送到quicktron倉庫

如果需要單獨更新某個子模塊(只開發quicktron,是不需要做這一步的

例如params_api被算法那邊修復了bug,并且已經推送到對應子倉庫了,那我們需要同步最新修改到qucktron

則使用以下命令:

git subtree pull --prefix=src/params_api ssh://git@gitlab.flashhold.com:10022/hardware/upper_computer/basic/nav_process.git release/3_5_5_3
git push origin  feature/3553_xzx_subtree

在submodule初步切為subtree這段時間,可能有原先是submodule形式的提交,在nav_process子倉庫上的修改,需要同步到subtree形式的主線上,則也是使用以上指令。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/85214.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/85214.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/85214.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

車載軟件架構 --- 汽車中央控制單元HPC軟件架構方案實例

我是穿拖鞋的漢子,魔都中堅持長期主義的汽車電子工程師。 老規矩,分享一段喜歡的文字,避免自己成為高知識低文化的工程師: 做到欲望極簡,了解自己的真實欲望,不受外在潮流的影響,不盲從,不跟風。把自己的精力全部用在自己。一是去掉多余,凡事找規律,基礎是誠信;二是…

零基礎開始的網工之路第二十一天------性能優化

目錄 一、性能優化概述 二、性能監控工具 1. 基礎工具 2. 高級工具 三、子系統優化策略 1. CPU優化 2. 內存優化 3. 磁盤I/O優化 4. 網絡優化 四、資源限制優化 1. ulimit 2. cgroups(控制組) 五、安全與注意事項 六、綜合案例 案例1&…

【Google Chrome】谷歌瀏覽器歷史版本下載

最新版: Chrome for Testing availability 谷歌瀏覽器 Chrome 最新版離線安裝包下載地址 v137.0.7151.104 - 每日自動更新 | 異次元軟件 歷史版本: Download Google Chrome 105.0.5195.102 for Windows - Filehippo.com chrome瀏覽器,chrome插件,谷…

線性表實訓(頭歌實踐平臺課程答案詳細解說)

C 和 C 支持 4 種基本數據類型(整型、浮點型、字符型、布爾型)和 3 種復合型數據類型(數組、指針、結構)。復合類型的數據對于數據結構至關重要,因為從某種程度上來說數據量的多少和數據結構的好壞決定了程序的復雜程度…

【前端】threeJS學習(長期更新)

簡介 Three.js是用JavaScript編寫的第三方庫,用于實現3D功能,基于WebGL進行封裝。 一個3D模型的建立主要由以下幾個部分組成(基本版): * 創建場景scene--相機camera--渲染器renderer--(燈光light); *…

Linux系統--權限

大家好,上一次我們學習了關于Linux中的基礎指令,那么我們今天來繼續學習Linux的新的內容:權限。那么話不多說,我們開始今天的學習: 目錄 Linux權限 1. Linux權限的概念 2. Linux權限管理 3. ?件權限值的表??法…

論文筆記 <交通燈> <多智能體>DERLight雙重經驗回放燈機制

今天看的論文是這篇 主要提出了傳統優先級經驗回放(PER)在復雜交通場景中效率低下,使用二叉樹存儲樣本,導致大規模樣本時計算復雜度高。而且不丟棄樣本,造成存儲空間浪費。 雙重經驗池: 為了解決以上問題…

Chromium 136 編譯指南 macOS篇:環境準備與系統配置(一)

1. 引言 在瀏覽器技術的星空中,Chromium 猶如一顆最亮的明星,照亮了整個互聯網的發展軌跡。作為推動現代 Web 技術革命的核心引擎,Chromium 不僅是 Google Chrome 的技術基石,更是 Microsoft Edge、Opera、以及眾多定制瀏覽器的共…

linux機器間無密碼如何傳輸文件

1. scp傳輸時的問題 $ scp deepseek_r1_distill_qwen1.5b_content_audit_fp16_20250613_2_Q4_K_M.gguf xxx192.168.xxx:/home/xxx/pretrained_model/output The authenticity of host 192.168.xxx (192.168.xxx) cant be established. ED25519 key fingerprint is SHA256:deOs…

PySpark 使用pyarrow指定版本

背景說明 在 PySpark 3.1.3 環境中,當需要使用與集群環境不同版本的 PyArrow (如 1.0.0 版本)時,可以通過以下方法實現,而無需更改集群環境配置 完整操作說明 去pyarrowPyPI下載對應版本的whl文件后綴whl直接改成zip解壓后有兩個文件夾&am…

安卓APP投屏調試工具使用教程

安卓APP投屏調試工具使用教程 一、準備工作(一)下載ADB工具(二)配置ADB的環境變量(三)檢查是否成功安裝(四)adb核心命令說明 二、無線調試流程(一)環境要求&a…

huggingface網站里的模型和數據集

直接下載肯定是不太行,平時訪問都不容易,更別提下載東西了,但是我們可以通過國內鏡像進行快速下載。 鏡像網址: hf-mirror地址:HF-Mirror 進入網站之后,在搜索框里搜索你想下載的內容,接下來…

Node.js 路由請求方式大全解:深度剖析與工程實踐

文章目錄 🌐 Node.js 路由請求方式大全解:深度剖析與工程實踐一、📜 HTTP 請求方法全景圖🏆 核心方法深度對比HTTP 請求方法概念對比表🛠? 特殊方法應用場景 二、🎨 各方法深度解析1. GET - 數據查看器&am…

JS-實現一個鏈式調用工具庫

要求: 支持鏈式調用,如:_chain(data).map().filter().value()實現map、filter、等常用方法支持惰性求值(延遲執行、直到用到value()時才真正計算)。 鏈式調用的實現原理的關鍵點是:函數執行完以后&#x…

【人工智能數學基礎】實變函數與泛函分析

數學分析、解析幾何、高等代數、實變函數、常微分方程、近世代數、微分幾何、復變函數、點集拓撲、概率論、數理統計、數理邏輯、偏微分方程、泛函分析、動力系統、數學物理方程、數論導引、群與代數表示、微分流形、代數拓撲、代數幾何、金融數學、多元統計分析、應用隨機過程…

css3 背景色漸變

在 CSS 中,使用漸變色需要用到 gradient 屬性,而 gradient 屬性分為 線性漸變 linear-gradient 與 徑向漸變 radial-gradient。今天主要是說一下 linear-gradient 線性漸變屬性。 例如:background: linear-gradient(90deg, #e7f1fc, #f5f9fb…

將圖片合成為視頻(基于 OpenCV)

本文將介紹如何使用 Python 和 OpenCV 將一組圖像文件合成為一個視頻文件。你將學會: 使用 os 模塊遍歷文件夾中的圖像 使用 cv2.VideoWriter 寫入視頻 設置分辨率與幀率參數 對圖像尺寸進行統一處理 簡單的視頻生成應用開發 1. 所需模塊與安裝 本章需要以下 …

HanLP 使用教程:從安裝到實戰應用

HanLP 使用教程:從安裝到實戰應用 HanLP 是由hankcs開發的一款高效、多功能的中文自然語言處理(NLP)工具包,支持分詞、詞性標注、命名實體識別(NER)、依存句法分析、關鍵詞提取、文本摘要等任務。本教程將…

MySQL 分組函數全面詳解與最佳實踐

MySQL 分組函數全面詳解與最佳實踐 MySQL 分組函數(聚合函數)的核心知識、注意事項和高級應用技巧: 📊 分組函數核心列表 函數描述示例COUNT()計算行數COUNT(*)SUM()計算數值總和SUM(salary)AVG()計算平均值AVG(score)MAX()獲取…

華為OD 最小循環子數組

1. 題意 給定一個由若干整數組成的數組 nums,請檢查數組是否是由某個子數組重復循環拼接而成,請輸出這個最小的子數組。 2. 題解 利用 k m p kmp kmp中的 n e x t next next數組性質,我們可以求出 n u m s nums nums中的最長公共 前綴后綴…