最近在使用華為軟件開(kāi)發(fā)云進(jìn)行開(kāi)發(fā)項(xiàng)目管理,目前華為軟件開(kāi)發(fā)云支持500M的免費(fèi)項(xiàng)目空間,而且還可以在線編譯和構(gòu)建,不用擔(dān)心開(kāi)發(fā)環(huán)境和生產(chǎn)環(huán)境的不同,很好的體現(xiàn)了DevOps的開(kāi)發(fā)理念.
之前一直是用svn做代碼管理,而華為軟件開(kāi)發(fā)云是使用目前國(guó)外比較流行的Git進(jìn)行代碼版本控制.在網(wǎng)上查詢了遷移方式,發(fā)現(xiàn)Git本身有命令可以直接克隆SVN的代碼庫(kù),而且遷移后能保持原SVN的提交記錄.以下是總結(jié)的SVN代碼庫(kù)向華為軟件開(kāi)發(fā)云遷移的過(guò)程.
主要步驟
1.通過(guò)git svn clone命令將SVN代碼庫(kù)克隆至本地
2.華為開(kāi)發(fā)云創(chuàng)建代碼倉(cāng)庫(kù),獲取Git倉(cāng)庫(kù)地址
3.本地新建test分支,提交后合并至master分支.開(kāi)發(fā)云代碼庫(kù)中根據(jù)引導(dǎo)完成代碼合并. (新建分支合并的原因后面會(huì)講.)
準(zhǔn)備條件
1.準(zhǔn)備要遷移的svn代碼庫(kù)地址;本地安裝Git
2.登錄華為軟件開(kāi)發(fā)云(https://www.hwclouds.com/devcloud/),并已創(chuàng)建好項(xiàng)目.
完整遷移流程
1.通過(guò)git svn clone命令將SVN代碼庫(kù)克隆至本地
$ git svn clonehttps://SVN服務(wù)器地址/ibeisi.iPMSystem/ --no-metadata --trunk=trunk
#查看SVN提交記錄
$ cd ibeisi.iPMSystem/
$ git log
2.華為軟件開(kāi)發(fā)云創(chuàng)建代碼倉(cāng)庫(kù),獲取Git倉(cāng)庫(kù)地址
代碼倉(cāng)庫(kù)創(chuàng)建好之后,需根據(jù)在線幫助,添加SSH秘鑰,步驟很詳細(xì),此處就不作贅述.
SSH秘鑰主要是本地與華為軟件開(kāi)發(fā)云代碼庫(kù)的一個(gè)管理,無(wú)需每次通過(guò)用戶名和密碼驗(yàn)證
打開(kāi)代碼倉(cāng)庫(kù),拷貝代碼倉(cāng)庫(kù)地址
3.根據(jù)步驟2中獲取到的代碼倉(cāng)庫(kù)地址,本地添加遠(yuǎn)程倉(cāng)庫(kù)地址
$ git remote add origin
git@codehub.devcloud.hwclouds.com:3bf9c1ed148142d880d759e80100b923/iPMSystem.git
#拉取遠(yuǎn)程分支
$ git pull
可以看到代碼倉(cāng)庫(kù)中默認(rèn)已建好主分支,如果無(wú)需保留SVN原提交記錄,可以直接將代碼通過(guò)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
#新建空文件,原因是若沒(méi)有更改git不會(huì)進(jìn)行push操作
$ vi test.txt
#空文件添加至分支中
$ git add .
#git的commit命令只是在本地提交,并不會(huì)上傳至代碼庫(kù).
$ git commit -m "上傳代碼新建緩存分支"
#通過(guò)以下push命令可以發(fā)起test與master分支合并請(qǐng)求.
$ git push--set-upstream origin test
5.刷新代碼庫(kù)頁(yè)面(或重新打開(kāi)代碼庫(kù)),可以看到合并請(qǐng)求的處理指引,按照指引操作即可完成合并.
可以看到原svn代碼庫(kù)的提交記錄都被完整保存了下來(lái).
至此, svn代碼庫(kù)可以說(shuō)完整地遷移到了華為軟件開(kāi)發(fā)云的CodeHub中车海。