SVN如何遷移到Git?

最近在使用華為軟件開發(fā)云進(jìn)行開發(fā)項(xiàng)目管理,目前華為軟件開發(fā)云支持500M的免費(fèi)項(xiàng)目空間,而且還可以在線編譯和構(gòu)建,不用擔(dān)心開發(fā)環(huán)境和生產(chǎn)環(huán)境的不同,很好的體現(xiàn)了DevOps的開發(fā)理念.

之前一直是用svn做代碼管理,而華為軟件開發(fā)云是使用目前國外比較流行的Git進(jìn)行代碼版本控制.在網(wǎng)上查詢了遷移方式,發(fā)現(xiàn)Git本身有命令可以直接克隆SVN的代碼庫,而且遷移后能保持原SVN的提交記錄.以下是總結(jié)的SVN代碼庫向華為軟件開發(fā)云遷移的過程.

主要步驟

1.通過git svn clone命令將SVN代碼庫克隆至本地

2.華為開發(fā)云創(chuàng)建代碼倉庫,獲取Git倉庫地址

3.本地新建test分支,提交后合并至master分支.開發(fā)云代碼庫中根據(jù)引導(dǎo)完成代碼合并. (新建分支合并的原因后面會(huì)講.)

準(zhǔn)備條件

1.準(zhǔn)備要遷移的svn代碼庫地址;本地安裝Git

2.登錄華為軟件開發(fā)云(https://www.hwclouds.com/devcloud/),并已創(chuàng)建好項(xiàng)目.

完整遷移流程

1.通過git svn clone命令將SVN代碼庫克隆至本地

$ git svn clonehttps://SVN服務(wù)器地址/ibeisi.iPMSystem/ --no-metadata --trunk=trunk

#查看SVN提交記錄

$ cd ibeisi.iPMSystem/

$ git log

2.華為軟件開發(fā)云創(chuàng)建代碼倉庫,獲取Git倉庫地址

代碼倉庫創(chuàng)建好之后,需根據(jù)在線幫助,添加SSH秘鑰,步驟很詳細(xì),此處就不作贅述.

SSH秘鑰主要是本地與華為軟件開發(fā)云代碼庫的一個(gè)管理,無需每次通過用戶名和密碼驗(yàn)證

打開代碼倉庫,拷貝代碼倉庫地址

3.根據(jù)步驟2中獲取到的代碼倉庫地址,本地添加遠(yuǎn)程倉庫地址

$ git remote add origin

git@codehub.devcloud.hwclouds.com:3bf9c1ed148142d880d759e80100b923/iPMSystem.git

#拉取遠(yuǎn)程分支

$ git pull

可以看到代碼倉庫中默認(rèn)已建好主分支,如果無需保留SVN原提交記錄,可以直接將代碼通過master分支進(jìn)行提交(commit)和推送(push);但我想保留原提交記錄,所以下面以新建分支合并到master的方式進(jìn)行代碼上傳。

4.本地新建分支test,并發(fā)起與master分支合并請(qǐng)求

$ git branch test

#checkout命令會(huì)讓當(dāng)前切換到test分支,及后續(xù)操作都只影響test分支

$ git checkout test

#新建空文件,原因是若沒有更改git不會(huì)進(jìn)行push操作

$ vi test.txt

#空文件添加至分支中

$ git add .

#git的commit命令只是在本地提交,并不會(huì)上傳至代碼庫.

$ git commit -m "上傳代碼新建緩存分支"

#通過以下push命令可以發(fā)起test與master分支合并請(qǐng)求.

$ git push--set-upstream origin test

5.刷新代碼庫頁面(或重新打開代碼庫),可以看到合并請(qǐng)求的處理指引,按照指引操作即可完成合并.

可以看到原svn代碼庫的提交記錄都被完整保存了下來.

至此, svn代碼庫可以說完整地遷移到了華為軟件開發(fā)云的CodeHub中。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Git 是目前最流行的分布式版本控制系統(tǒng)之一。 版本控制指的是,記錄每次版本變更的內(nèi)容和時(shí)間等細(xì)節(jié),保留各版本之間...
    神齊閱讀 1,514評(píng)論 0 7
  • 對(duì)于軟件開發(fā)人員來說,版本控制系統(tǒng)他們?cè)偈煜げ贿^了,所謂版本控制系統(tǒng)就是軟件項(xiàng)目開發(fā)過程中用于儲(chǔ)存開發(fā)人員所寫代碼...
    程序員的那點(diǎn)事閱讀 1,626評(píng)論 0 18
  • &開發(fā)過程中離不開源代碼的管理, 目地:為了解決在軟件開發(fā)過程中,由源代碼引發(fā)的各種蛋疼、繁瑣的問題。 目前開發(fā)使...
    早起的蟲兒子被鳥吃閱讀 2,628評(píng)論 0 16
  • 前言 Git使用教程 Git是什么 Git是一個(gè)開源的分布式版本控制系統(tǒng),用于敏捷高效地處理任何或小或大的項(xiàng)目。 ...
    90后的思維閱讀 1,026評(píng)論 0 0
  • 多種多樣的工作流使得在項(xiàng)目中實(shí)施Git時(shí)變得難以選擇。這份教程提供了一個(gè)出發(fā)點(diǎn),調(diào)查企業(yè)團(tuán)隊(duì)最常見的Git工作流。...
    JSErik閱讀 4,610評(píng)論 2 8

友情鏈接更多精彩內(nèi)容