怎么svn服务器上的 数据库备份到本地?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么svn服务器上的 数据库备份到本地?相关的知识,希望对你有一定的参考价值。

将本地的记录修改成与服务器上的一致。也就是说,将本地与服务器上不同的地方,改成与服务器上的一样。
svn备份一般采用三种方式:
1)svnadmin dump
2)svnadmin hotcopy
3)svnsync.

注意,svn备份不宜采用普通的文件拷贝方式(除非你备份的时候将库暂停),如copy命令、rsync命令。
笔者曾经用 rsync命令来做增量和全量备份,在季度备份检查审计中,发现备份出来的库大部分都不可用,因此最好是用svn本身提供的功能来进行备份。

优缺点分析
==============
第一种svnadmin dump是官方推荐的备份方式,优点是比较灵活,可以全量备份也可以增量备份,并提供了版本恢复机制。
缺点是:如果版本比较大,如版本数增长到数万、数十万,那么dump的过程将非常慢;备份耗时,恢复更耗时;不利于快速进行灾难恢复。
个人建议在版本数比较小的情况下使用这种备份方式。
第二种svnadmin hotcopy原设计目的估计不是用来备份的,只能进行全量拷贝,不能进行增量备份;
优点是:备份过程较快,灾难恢复也很快;如果备份机上已经搭建了svn服务,甚至不需要恢复,只需要进行简单配置即可切换到备份库上工作。
缺点是:比较耗费硬盘,需要有较大的硬盘支持(俺的备份机有1TB空间,呵呵)。
第三种svnsync实际上是制作2个镜像库,当一个坏了的时候,可以迅速切换到另一个。不过,必须svn1.4版本以上才支持这个功能。
优点是:当制作成2个镜像库的时候起到双机实时备份的作用;
缺点是:当作为2个镜像库使用时,没办法做到“想完全抛弃今天的修改恢复到昨晚的样子”;而当作为普通备份机制每日备份时,操作又较前2种方法麻烦。
参考技术A 用软件,IBM 的备份软件本回答被提问者采纳

备份具有完整历史记录的SVN存储库

我需要在具有完整历史记录的本地计算机上备份SVN存储库,以便我可以在从服务器删除存储库后比较修订并查看注释。我使用TortoiseSVN作为客户端,并将其作为存储库服务器。实际上我的帐户将在几天内解散,我需要在本地系统上获取回购以进行进一步处理。

我该怎么办?

答案

您可以使用svnsync下载存储库的完整副本,包括历史记录。它基本上只是将每个变更集复制到您选择的本地路径。我过去曾用它作为备份,它就像一个魅力。

有一个教程解释如何在Windows上执行此操作:http://creekcodes.blogspot.com/2010/02/how-to-svnsync-on-windows.html

另一答案
另一答案

您可以使用Mercurial,这是自TortoiseHG版本1.7以来提供的,因此完全支持。

此工具类似于hgsubversion但转储远程存储库。有关如何使用,请参阅svnrdump答案。

另一答案

WordAligned提供了一些提示和三种方法来做一个svn存储库的镜像 - 一种方法也可以用于备份。看看original Subversion distribution

以上是关于怎么svn服务器上的 数据库备份到本地?的主要内容,如果未能解决你的问题,请参考以下文章

SVN主机备份到另一台电脑

svn服务器备份svnsync命令怎么用

sqlserver怎么把服务器上的数据库备份到本地,不是局域网的服务器?

备份具有完整历史记录的SVN存储库

跪求:SQL远程数据库备份到本地数据 的方法

SVN版本库实时备份整理