热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

svn搬移到gitlab及使用

svn是一款非常简便,易用的源代码管理工具,用了这么多年,对它情有独钟。都说习惯最难改,那为何要搬移到gitlab上呢?喜欢尝试新东西,前提还是git比较强大,svn有的它都有,svn没有的它也

  svn是一款非常简便,易用的源代码管理工具,用了这么多年,对它情有独钟。都说习惯最难改,那为何要搬移到gitlab上呢? 喜欢尝试新东西,前提还是git比较强大,svn有的它都有,svn没有的它也有。

 

  这次是把公司有7年历史的svn项目搬移到gitlab上,期间各种折腾,有几点原因:

     1、第一次使用git。

     2、gitlab托管到linux服务器上,对命令不熟悉。

     3、跟着前人的路走,以为这样能少走弯路,结果方法没对,没搞懂原理就跟随。

     4、svn服务器上很多历史版本已经损毁。

 

  后来才知道以上问题跟转移库其实没多大关系,刚开始都想的复杂了,接触“新事物”还是需要不断尝试,成功之后总结的步骤:

     1、安装工具:Git-1.9.0-preview20140217.exe、Git-1.7.0.2-preview20100309.exe

     2、转换现有svn为git库(所谓的克隆),任何一台机器上都可以操作,只要能访问到svn库所在的服务器。

     3、登录gitlab;创建项目库;拷贝项目库地址;切换到本地机器将本地克隆好的git库提交到gitlab上的项目库。

 

  克隆SVN库命令,克隆成功整个任务就已经完成90%了

git svn clone svn_url --authors-file=c:\users.txt 库保存路径

  svn_url:指定你的svn服务器地址, 如:http://×.×.×.×:88/svn/trd/trd_work/Carpa.NET

      库路径 : 如:D:\gitclone\CarpaNET(指定克隆库保存路径)

  users.txt:存储svn账号与gitlab上账号的关联性,如下:

VisualSVN Server = wssf2014
yqdong = yqdong<×××@163.com>
user11 = yqdong<×××@163.com>
yyong = yyong<×××@gmail.com>
msfei = mashifei<×××fei@foxmail.com>
......
......

格式: svn用户名 = git用户名
  注意: svn里面有的账号必须要做关联,否则clone会失败.比如上面的user11找不到是哪个开发人员,也不知道它该对应哪个git账号,那就随便指定一个git账号就行了,这样做的目的其实就是将user11在svn里面的所有提交日志关联到yqdong的git账号下。 转到git之后,原svn账号就无关紧要,各司其职了。
 
  绑定user.txt的意义仅在于,将svn里面的提交者日志,注意是提交者,不是svn里面所有的用户信息都得关联,仅仅是往项目提交过代码的svn账号,将这些svn账号找出来,然后关联到现有的git账号,一旦转到git上之后,每个git用户就能看到自己过去在svn里面提交的日志,绕了这么大一圈,现在明白了吧?
 

 

通过svn里面的log工具,可以找出svn项目里面所有的提交者,完成上面的user.txt(必须步骤,应该有命令),点击下图的“Show All”之后,按Author排序,就可以很方便的找出所有的提交者,然后做关联。

 

 

     注意:凡是执行了一次git svn clone命令,不管成功失败,第二次执行该命令前,请删除前一条命令中指定的库路径(避免重复,只要库路径不相同就可以)

    

     如果以上克隆没有遇到问题,那恭喜你已经成功了,不需要进行下一步。

 

 

 

  下一步

      问题在于svn_url对应的服务器本身,服务器有6w多条日志,其中部分日志已经损坏,导致整个克隆失败,而一次克隆命令至少要执行一个小时,上面有7年的log日志,是很宝贵的东西,因此无论如何也要想办法把它们抓出来。其实就是想删除1-6w条日志中部分有问题的日志,这样clone时候就不会出现中断的情况,这个方法亲自尝试过,非常之麻烦,不提倡这种做法,google半天没有找到别人的经验,这事反复折腾了Two days.

  后来发现git有合并功能,这下简单了,换了做法,不去纠结svn服务器的问题,只要git svn clone能执行就ok(毫无顾虑),其它事情就跟提交代码到git一样简单。

     新步骤:

     1、先克隆svn上1~5000版本号,存放到库1;  git svn clone -r0:5000 svn_url --authors-file=c:\users.txt 库保存路径1(不能重复)

     2、克隆svn上5010~最新,存放到库2;         git svn clone -r5010:HEAD svn_url --authors-file=c:\users.txt 库保存路径2(不能重复)

     3、将库1提交到分支1

     4、将库2提交到分支2

     5、本地合并分支1、2,合并分支的时候必然会有冲突,而且冲突不少,全部处理就行了,都是历史记录没什么影响。

     这样做就跳过了svn上某些版本导致无法克隆的问题,舍弃一小部分日志没影响,要顾全大局。

 

 

 

git库推送图解:

如果安装了工具,还是不能执行git svn clone命令,请乖乖设置环境变量吧!

 

 

1、gitlab上创建Group.

 

2、在group上创建project.

 

 

3、copy服务器创建的git项目地址:

 

 

4、进入本地库1所在路径,使用GitExtensions工具推送代码,同理操作库2、库3....

 

5、合并库1和库2分支,最后提交.

 

 

 

 

 

 

gitlab取代svn,势不可挡啊!!!看图!!!

 


推荐阅读
  • IamsettingupApacheserverwithTortoiseSVNforalocalsourcecoderepository.Ihaveobservedt ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • WebSocket与Socket.io的理解
    WebSocketprotocol是HTML5一种新的协议。它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送 ... [详细]
  • 1找现有的镜像dockerhub上搜索到一个,其在github上公布了镜像构建的dockerfile,并且支持http和svn两种协议,就这个吧。https:github.come ... [详细]
  • TheProblem:-Iwhanttoperiodicalymakeabackupofmydatabase,forthispurpose ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
author-avatar
男人32ABC_130
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有