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

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

 

1. 新建一個summary倉庫

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

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倉庫中。url

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

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中。code

相關文章
相關標籤/搜索