svn迁移到git

通过git bash将svn迁移到git上,并保留svn的提交历史。

一、准备

1、在电脑上安装git

2、确认svn账号具备该svn地址的操作权限

3、准备将要操作的svn项目地址、以及该项目下所有提交人的账号信息(在idea工具看提交历史),将信息存放到author.txt(随便命名),信息存放的格式: 提交者svn账号=提交者git账号<邮箱>

bash 复制代码
zhangsan=zhangsan<zhangsan@qq.com.com>
lisi=lisi<lisi@qq.com>

二、操作步骤

1、首先在项目组的gitlab上创建对应的空项目,拿到该项目的git地址,如:

https://192.168.0.88:1111/web/demo.git
注意:当前帐号为管理者,避免接下来push有问题

2、切换到将要存放该git项目的父目录,打开Git Bash,例如是:d:\java\code\。

执行脚本:

bash 复制代码
git svn clone -r124245:HEAD http://192.168.0.88:81/svn/java/demo --no-metadata --no-minimize-url --authors-file=/d/java/code/author.txt demo --username=zhangsan
命令 含义
-r124245:HEAD 从版本号124245到最新的提交记录(idea工具svn历史记录可以查看),如果不加这个命令,默认从版本号0开始,非常费时
--no-metadata 保留svn的metadata信息,快很多
--no-minimize-url 如果账号没有根目录的权限,建议加上。默认是从根目录一直检索下来,如果不加的话,会因为权限问题报错:Using higher level of URL: 加上则表示只从你定义的目录检索
--authors-file author.txt所在的路径,不能用windows的路径,参考git bash默认的路径方式
--username 要操作svn的账号信息

3、打开本地git项目的目录,把一些不必要的配置信息删除,然后bash进入到该项目目录下,将项目关联到远程仓库,并push到远程仓库,整个过程就结束了。

bash 复制代码
git remote add origin https://192.168.0.88:1111/web/demo.git
git push -u origin master
相关推荐
南山nash4 小时前
git从入门到熟练
git
夜流冰6 小时前
Git - GitForWindows
git
一个很帅的帅哥7 小时前
部署chat-vue
大数据·git·elasticsearch
芒鸽7 小时前
鸿蒙PC使用ffmpeg+electron实现视频中音频的提取
git
SunkingYang8 小时前
使用TortoiseGit工具推送(push)时,忘了先拉取(Pull),提示冲突,后续怎么处理冲突?
git·tortoisegit·pull·push·推送·冲突·拉取
BestOrNothing_20159 小时前
Git 团队开发冲突合并全流程:本地是否改动 + 远端是否更新,如何正确同步并合并(同分支/不同分支下的几种场景)
git·分支管理·git pull·git merge·分支冲突·git协作·git fetch
zzlyyds9 小时前
工作的时候遇到的git版本冲突与合并问题
git
BestOrNothing_20159 小时前
Git fetch 详解:git fetch 和 git fetch origin 到底有什么区别?(origin/xxx、远端跟踪分支一次讲透)
git·分支管理·开发规范·新手教程·fetch / origin·本地/远程 分支·detached head
gsls2008089 小时前
服务器状态监控Uptime Kuma
运维·服务器·git
XiaoHu020710 小时前
Linux进程间通信
linux·运维·服务器·c++·git·vscode