前言:

  最近公司需要将整体项目从svn迁移至gitlab上,经过几天的研究,现记录一下流程

  整体思路是进行一次导入:

  先通过subgit将svn整个import至本地,在与git上的项目进行合并.

1.硬件环境

  git:git version 2.7.4
  svn: 1.6.11

   subgit:3.2.2
2.下载subgit

  官网下载subgit: https://subgit.com/

  将subgit解压:    

tar -zcvf subgit-3.2..zip 

3.在gitlab上新建一个需要合并的项目

  进入gitlab管理界面,新建项目:lclctest  

git@xx.xx.xx.xx:lclc/lclctest.git (我这边新建了一个lclc的组)

  建好以备用.

4.进入subgit-3.2.2/bin 目录,使用configure命令  

./subgit configure http://ip:port/svn/lclctest  lclctest

完成后会有一些提示:  

) Adjust Subversion to Git branches mapping if necessary:
/root/lclctmp/tmp/subgit-3.2./bin/lclctest/subgit/config
) Define at least one Subversion credentials in default SubGit passwd file at:
/root/lclctmp/tmp/subgit-3.2./bin/lclctest/subgit/passwd
OR configure SSH or SSL credentials in the [auth] section of:
/root/lclctmp/tmp/subgit-3.2./bin/lclctest/subgit/config
) Optionally, add custom authors mapping to the authors.txt file(s) at:
/root/lclctmp/tmp/subgit-3.2./bin/lclctest/subgit/authors.txt
) Run SubGit 'install' command:
subgit install lclctest

意思是进行一些配置,然后进行install

  配置config:由于3.2.2默认是配置好的,可以不进行配置  

trunk = trunk:refs/heads/master
branches = branches/*:refs/heads/*
branches = branches/features/*:refs/heads/features/*
branches = hotfixes/*:refs/heads/hotfixes/*
tags = tags/*:refs/tags/*
shelves = shelves/*:refs/shelves/*

  配置用户映射文件 author.txt 格式为:svnUser = Git User <user@example.com> (也可以不修改)
5.进行install

$ ./subgit install lclctest

  此步将连接svn,需要耗时一段时间.

  完成后就把svn代码迁移到本地库了,这时候就需要用git push到远程库中

6.clone版本  

 git clone ./lclctest lclctest.git

7.进入lclctest.git目录  

git remote set-url origin git@yourip:lclc/lclctest.git(之前创建的git项目)
git push origin master

  在push的时候发现提示填写密码:  

 git@ip's password:

  此时说明需要进行身份验证,我们给git添加一个keygen就行了

  7.1:生成keygen 

cd ~
ssh-keygen -t rsa -C "your_email@example.com"

  生成的文件在 .ssh文件下有 id_rsa和id_rsa.pub文件

  7.2:上传keygen

  打开gitlab的管理界面

  

将id_rsa.pub文件中的内容复制到Key的文本框里.

再执行步骤7的git push origin master命令上传master

8.上传分支.

  进入lclctest.git目录,使用命令查看分支  

git branch -a

结果:

* master
remotes/origin/HEAD -> origin/master
remotes/origin/bugfix
remotes/origin/develop
remotes/origin/feature
remotes/origin/master

本项目一共有3个分支,分别是bugfix,develop,feature,分别进行上传

git push origin remotes/origin/feature:refs/heads/feature
git push origin remotes/origin/bugfix:refs/heads/bugfix
git push origin remotes/origin/develop:refs/heads/develop

注意:冒号后面为远程库中的地址,必须以refs/heads开头.

9.上传tags

git push --tags

参考资料:

  http://lattecake.com/post/20051

  http://stackoverflow.com/questions/23251394/subgit-import-and-multiple-branches-directories

使用subgit进行svn迁移至git(branch,tags)的更多相关文章

  1. SVN迁移到Git的过程(+ 一些技巧)

    SVN迁移到Git的过程(+ 一些技巧) 李顺利 Key Words SVN,Git,Clone,Conversion,Tips,VCS,Pro Git 关于在VCS中SVN和Git之间的迁移(Clo ...

  2. SVN迁移到Git的过程(+ 一些技巧

    关于在VCS中SVN和Git之间的迁移(Clone)这个部分网上已经有大批的文章介绍,而且都非常不错,能够满足我们的常见的需求,这里介绍的是我自己整理的一些技巧和使用中出现的一些问题和疑问.阅读本篇文 ...

  3. svn迁移到git仓库并保留commit历史记录

    svn迁移到git仓库并保留commit历史记录 最近在做svn迁移到gitlab,由于之前一直是由svn做版本控制.最简单的方式是将svn的内容export出来,然后添加到gitlab即可.但是,如 ...

  4. svn 迁移至git操作手册

    svn 迁移至git操作手册 项目交付.版本管理工具变更等情况下,迁移svn旧历史记录有很大必要,方便后续追踪文件的提交历史,文件修改记录比对等.git自带了从svn迁移至git的工具命令,可很好的对 ...

  5. git学习------>从SVN迁移到Git之后,项目开发代码继续在SVN提交,如何同步迁移之后继续在SVN提交的代码到Git?

    最近逐步逐步的将公司的项目都从SVN往Git迁移了,但是想团队成员都能够一步到位就迁移到Git是不可能的,因为还有大部分人都还不会Git,所以整个过渡过程估计得大半年. 因此导致虽然项目迁移过来了,但 ...

  6. 将代码库从 SVN 迁移至 Git 并保留所有 commit 记录

    公司内部原本使用 SVN 进行版本控制,但随着 Github 的流行我个人的代码管理习惯逐渐转变.虽然公司项目并非开源,SVN 所具有的标准 trunk / branches / tags 结构完全够 ...

  7. svn迁移到git

    步骤命令如下: > git svn clone https://svn-url/ProjectName --no-metadata --authors-file=user.txt --trunk ...

  8. 从svn迁移至Git并保留所有 commit 记录

    用户映射文件user.txt,等号左边为svn账号,右边为Git用户名和邮箱.注意:svn中有多少用户就要映射多少 test1=test1<147258369@qq.com>test2=t ...

  9. svn 迁移到 git 仓库并保留 commit 历史记录

    1.svn 转换为 git(会提示,让你输入先前 svn 的账号与密码) # 切换至 本地项目目录 cd /Users/jianbao/PhpStormProjects/fiisoo/ # 克隆 sv ...

随机推荐

  1. Hdu428 漫步校园 2017-01-18 17:43 88人阅读 评论(0) 收藏

    漫步校园 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submissi ...

  2. 阿里Sophix热修复

    阿里巴巴对Android热修复技术已经进行了长达多年的探索. 最开始,是手淘基于Xposed进行了改进,产生了针对Android Dalvik虚拟机运行时的Java Method Hook技术,Dex ...

  3. Java返回当前对象的好处

    自己使用了一个第三方框架,发现非常的灵活,于是去研究了下,才知道是返回当前对象,才可以做到,例如以下案例: // 可以不断的点出很多函数 Glide.with(PhotoPagerSlitherAct ...

  4. Python学习-25.Python中的分数

    在Python中,不止有浮点数(float),而且还有分数(Fraction)这个类型. 要使用分数,必须引入一个模块. import fractions 然后就可以声明一个分数了 x = fract ...

  5. TCP/IP协议族分层

    协议族的分层抽象,一定意义上来说,每层敬职敬责的做自己的工作,同时也共同完成通讯协议的共同目标. 这是一个垂直划分的抽象层次,挺有意义. 1.链路层/数据链路层/网络接口层 操作系统中的设备驱动程序和 ...

  6. 在TFS中使用Git Tags(标签或标记),实现代码的版本管理

    一.概述: 与TFVC中标记(Label)一样,Git的标签(Tag)也是TFS系统的代码管理中非常重要的一个版本管理工具.使用标签,我们可以每个时间点的代码注上一个通俗.并且容易记忆的名称(例如标签 ...

  7. Cookie操作-----Selenium快速入门(十一)

    什么是cookie?顾名思义,就是饼干,小甜饼.而根据读音则是“曲奇”的意思,相信不少的人都吃过.而在网络上,cookie是指浏览器在本地的一种少量数据的存储方式.例如,我们常见的,登陆的时候有个ch ...

  8. IdentityServer4中文文档

    欢迎IdentityServer4 IdentityServer4是ASP.NET Core 2的OpenID Connect和OAuth 2.0框架. 它在您的应用程序中启用以下功能: 认证即服务 ...

  9. 导出excle错误

    导出excel时出现下面的错误: 类型“GridView”的控件“SimpleForm1_ContentPanel2_GVD_List”必须放在具有 runat=server 的窗体标记内. 可以在对 ...

  10. 为什么不能用Abort退出线程

    在使用线程时,如果线程还未结束直接退出线程很有可能会导致数据丢失. class threadAbort { static void Main(string[] args) { WriteMessage ...