多個git合並,並保留log歷史記錄


面臨的需求是:將多個git倉庫作為一個單獨目錄,整合到一個新的git倉庫中;並且保留歷史記錄。

 

1. 新建一個summary倉庫

新建一個summary倉庫,用於整合一系列git倉庫。

git clone <http_url>/summary.git
cd summary
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master

2. 將其它git倉庫merge到summary中

git remote add alias_memory <http_url>/memory.git-------------------------將memory.git作為別名alias_memory加入到當前倉庫中。
git fetch alias_memory----------------------------------------------------從alias_memory拉取數據到summary倉庫。
git checkout -b branch_memory alias_memory/master-------------------------將alias_memory/master分支內容對checkout到summary倉庫的branch_memory分支。。
git checkout master-------------------------------------------------------切換到summary倉庫的master分支。
git merge branch_memory---------------------------------------------------將branch_memory分支合並到master分支。

至此就將memory倉庫的內容merge到了summary倉庫中。

但是此時summary中目錄結構和memory一樣,就需要將新建一個memory目錄,並將memory倉庫中對應文件移到summary倉庫的memory目錄中。

mkdir memory
git mv xxx memory--------------------------------------------------------這里面使用git mv要優於mv,git mv的結果就是一個rename操作。
git commit -s -m "Merge memory.git to memory."
git push -u origin master

依次重復上面內容,即可將多個git倉庫合並到summary中。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM