当前位置:  开发笔记 > 编程语言 > 正文

回滚或将整个svn存储库还原为旧版本

如何解决《回滚或将整个svn存储库还原为旧版本》经验,为你挑选了6个好方法。

我搞砸了我的SVN存储库,现在需要将整个存储库从版本28恢复到24,并且不想处理差异或冲突.有一种快速简单的方法吗?我已经能够在使用merge命令之前恢复单个文件 - 但在这个实例中,它希望将所有文件从版本28添加回存储库,而我真正想做的就是删除它们.

我在linux框(bash)上使用命令行.

谢谢

编辑

感谢您的帮助!我通过以下方式修复:

svnadmin create /svnroot/.fixed
svnadmin dump -r 1:24 /svnroot/ --incremental > dump.svn
svnadmin load /svnroot/.fixed < dump.svn

然后将旧的repo放在备份位置并将repo.fixed移动到repo.

再次感谢!



1> Justin Love..:

检查svnadmin dump/load.它会为您的每个文件版本创建一个文本文件.可以删除某个点上方/下方的所有内容并重新导入.

请参阅例如Migrating Repository Data Elsewhere


我现在正在研究这个谢谢.当然,我不得不意外地输入svnadmin dump而不管它,所以现在我的整个项目都被写入stdin(并且不会用ctrl + c停止)......我不会再犯这个错误:p

2> luapyad..:

"反向"合并可能就是您所需要的.请参阅svn book的"撤消更改"部分.

例如svn merge -r 28:24 [svn的路径]


对不起 - 我一定不太了解你的问题.我曾经多次使用反向合并来摆脱新的(但是不正确的)添加文件...(但你的情况必须略有不同?)(你通常不能删除svn repo中的修订版 - 只添加修复的新版本错误).

3> fuenfundacht..:

如果您有权访问SVN服务器,则只需编辑path/db/current,将要恢复的旧版本号(此处为24)放在那里,然后从中删除不再需要的修订文件(即25,26,27,28)path/db/revs/0/.在我意外删除了存储库中的目录之后,至少这对我有用.



4> Sander Rijke..:

如果您确实需要擦除文件中存在的"证据",则需要执行上述svndump/svnload操作.

在"正常"情况下,您犯了一个错误,您需要使用反向合并.这样可以确保在r24之后撤消更改也可以恢复,差异等.

下面的命令应该可以撤消您的更改(您需要提交合并的结果以反映存储库中的合并)

svn merge -r 28:24



5> MarcH..:

如果你没有使用管理员权限,那么你不能删除任何旧版本,但你仍然可以通过一个非常简单的"svn copy"命令非常好地隐藏它们(nickf和JesperE已经提到了这个,但是以一种相当神秘的方式)

svn delete protocol:// svnserver/some/resource
svn copy protocol:// svnserver/some/resource @ 24 protocol:// svnserver/some/resource

就是这样,修订版25到28已经完全从svn log中消失了.它根本不是黑客攻击,它是一种安全且(几乎没有)记录的功能.

如果"resource"是一个目录,那么您必须从最后一个URL中删除它:

svn copy protocol:// svnserver/some/directory @ 24 protocol:// svnserver/some /

(否则你会在里面复制它)



6> Paul Suart..:

对于任何使用TortoiseSVN的人来说,解决方案很简单:

查看更改日志

右键单击要回滚到的修订版本...

...选择"还原到此修订版"

提交您的更改

此方法保留版本历史记录(即您还原的所有修订版本).

推荐阅读
吻过彩虹的脸_378
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有