执行此操作:git svn dcommit committing wrong file?,现在我在SVN服务器端存储库中有一个 - 最新版本错误;我想删除它。我知道我可以根据How do I fix a repository with one broken revision?执行svnadmin dump / filter / load,但我希望有一个更简单的解决方案。
所以我尝试了这个测试:
cd /tmp
svnadmin create newRepo
svn co file:///tmp/newRepo newRepo-checkout
# Checked out revision 0.
cd newRepo-checkout/
echo aaa > AA.txt
svn add AA.txt
# A AA.txt
svn ci -m 'first commit'
# Adding AA.txt
# Transmitting file data .
# Committed revision 1.
echo bbb > BB.txt
svn ci -m '2ns commit'
svn add BB.txt
# A BB.txt
svn ci -m '2nd commit'
# Adding BB.txt
# Transmitting file data .
# Committed revision 2.
echo ccc > CC.txt
svn add CC.txt
# A CC.txt
svn ci -m '3rd commit'
# Adding CC.txt
# Transmitting file data .
# Committed revision 3.
现在,如果我只是将相应的文件删除到db / revs和db / revprops中的最新版本(3),我得到这个:
$ cd ../newRepo
$ svnadmin verify .
* Verified revision 0.
* Verified revision 1.
* Verified revision 2.
* Verified revision 3.
$ ls db/revprops/0/
0 1 2 3
$ ls db/revs/0/
0 1 2 3
$ rm db/revs/0/3
$ rm db/revprops/0/3
$ svnadmin verify .
* Verified revision 0.
* Verified revision 1.
* Verified revision 2.
svnadmin: No such revision 3
经过一番聆听后,结果显示文件./db/txn-current
和./db/current
包含内容' 3',所以我尝试更改:
$ echo 2 > ./db/current
$ echo 2 > ./db/txn-current
$ svnadmin verify .
* Verified revision 0.
* Verified revision 1.
* Verified revision 2.
......而且svn co file:///tmp/newRepo newRepo-checkout2
似乎也有效。
所以我的问题是 - 这是否相当安全,或者在SVN服务器中存储修订版还有更多内容吗?
答案 0 :(得分:2)
没有。手动编辑存储库数据库文件永远不会“相当安全”。它更安全,并且最终可能更简单,只需使用svn工具进行转储/过滤/加载。