从SVN迁移到GIT并保留所有的提交记录

早期某些项目使用的SVN,目前都使用的是GIT,那么如何将SVN的项目迁移到GIT并保留之前提交的记录呢

一:创建用户映射文件

创建一个用户映射文件userinfo.txt,将项目中所有提交的SVN用户和GIT用户对应起来

复制代码
SVN用户名1 = GIT用户名1<邮箱>
SVN用户名2 = GIT用户名2<邮箱>

如果上面的文件中有用户缺失,后面的 SVN 命令将会停止。不过你可以更新用户映射然后接着再来(类似断点续传)。

二:SVN迁移至GIT

1:拉取代码

从SVN仓库拉取所有数据

复制代码
git svn clone SVN仓库地址 --stdlayout --no-metadata -A userinfo.txt project(拉取的数据存储目录)

这个命令将会在 `project` 新建一个 Git repo,并开始从 SVN 中拉取代码。请注意 "`--stdlayout`" 参数表示你的项目在 SVN 中是常见的 "`trunk/branches/tags`" 目录结构,如果不是,那你需要使用 `--tags`, `--branches`, `--trunk` 参数(请通过 `git svn help` 自行了解)。

SVN仓库地址一些常见协议都是支持的 : `svn://`, `http://`, `https://`。注意这个 URL 应该指向项目的 base repository,例如 `http://svn.mycompany.com/myrepo/repository\`。 不要指到了 `/trunk`, `/tag` 或 `/branches` 里。

2:异常处理

如果出现用户名没找到,更新你的 `userinfo.txt` 文件,然后

复制代码
cd project
git svn fetch

如果你的项目非常大,你可能需要重复上面的git svn fetch命令好几次,直到所有的 SVN commit 都被抓下来了

三:推送至GIT远程仓库

复制代码
git remote add origin GIT仓库地址
git push -u origin master

四:参考地址

将代码库从 SVN 迁移至 Git 并保留所有 commit 记录 -- 尘埃落定

相关推荐
海参崴-8 小时前
【Linux 项目自动化构建工具 -- make/makefile && 版本管理 Git 的使用&&第一个程序
linux·git·自动化
W-琑8 小时前
Git基本操作及操作原理
git
流星雨在线10 小时前
项目 Git 分支 + Tag 管理规范
git
爱宇阳11 小时前
Git Clone 完整入门指南(从 0 到团队实战)
git
为什么要做囚徒12 小时前
IDEA Git更新后.iml/.idea丢失、项目配置清空问题排查与解决
git·intellij-idea
卖报的大地主14 小时前
Learn Claude Code Agent 开发 | 12、目录级隔离:Git Worktree实现多任务并行无冲突
大数据·git·elasticsearch
Amnesia0_014 小时前
linux中的git和gdb
linux·运维·git
原来是猿14 小时前
Git【多人协作二】
git
小陈工15 小时前
2026年4月1日技术资讯洞察:AI芯片革命、数据库智能化与云原生演进
前端·数据库·人工智能·git·python·云原生·开源
我先去打把游戏先16 小时前
Git 一个本地仓库同时推送到两个远程仓库(私人 GitHub + 公司 Git)保姆级教程
git·vscode·单片机·嵌入式硬件·物联网·学习·github