备份数据库的磁盘上结构版本为611.服务器支持版本539,无法还原或升级数据库

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了备份数据库的磁盘上结构版本为611.服务器支持版本539,无法还原或升级数据库相关的知识,希望对你有一定的参考价值。

服务器已经安装了sql2005,恢复数据时提示已备份数据库的磁盘上结构版本为611.服务器支持版本539,无法还原或升级数据库,求高手帮忙

两个方法1.升级现在的数据库到20082.找一台2008把数据库挂上,用导入导出的方法把数据导入到你这台2005上(步骤比较麻烦) 参考技术A 两个方法
1.升级现在的数据库到2008
2.找一台2008把数据库挂上,用导入导出的方法把数据导入到你这台2005上(步骤比较麻烦)追问

SQL分别安装2000,2005,2008,都提示备份数据库的磁盘上结构版本为611.服务器支持版本539,求高手指点。

追答

我去看了一下,539是sql2000的,611是sql2005的,你要用sql2005 的 SQL Server Management Studio 去还原的

参考技术B 两个方法1.升级现在的数据库到20082.找一台2008把数据库挂上,用导入导出的方法把数据导入到你这台2005上(步骤比较麻烦)

SVN版本库实时备份整理

        因为公司最近SVN服务器的文件特别多,数据量很大,有500g,而用于备份的外接磁盘除了故障,因此需要在这段时间对svn服务器上的数据做备份,所以特地研究了下svn库的备份,因为平时不怎么接触服务端,一般就用svn客户端TortoisSVN对代码checkOut,commit,update简单的操作。所以整理了份不同服务器间进行库备份的文档,并记录下来,供大家参考,也方便日后复用。

 svn备份一般采用三种方式:
1)svnadmin dump 
2)svnadmin hotcopy 
3)svnsync

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

注:上述介绍摘自网络

下面进入正题,笔者今天介绍的是第三种方式。

--------------------------------------------------------------------------------------------------

本文中设备:

Window笔记本(Lenovo y400) ip:10.16.122.49  库d:/Repositories/MyRepository01

VMware虚拟机(Centos6.7)   ip:192.168.193.100 库/repo/svn/svn-mirror

 

本文做备份采用的SVN Server提供的svnsync命令,这种方式备份其实就是做镜像,备份服务器上安装SVN Server(SubVersion)即可提供svn服务

虽然文中将的是是window同步至linux,其实反之或者同类型服务器之间都类似,不同的是脚本类型不同window脚本*.bat ,Linux脚本随意命名,需要赋予执行权限

windows需准备工作:

1更改window服务器上的同步库配置文件

进入安装SVN Server时配置的的仓库目录D:\\Repositories\\MyRepository01\\hooks

复制post-commit.tmpl文件,重命名post-commit.bat并编辑,

删除尾部没有以#开始的所有行,并在尾部加入:

svnsync sync --non-interactive http://192.168.193.100/svn-mirror  --username admin1 --password 123456

注:参数--non-interactive为非交互模式

     usernamepassword为能通过svn认证的用户名和密码

     192.168.193.100Linux服务器的ip

 

2打开注册表(win+r àregedit)

应该都是64位的机器吧现在,注意键名带引号

1.  for 32-bit system(32):

[HKEY_LOCAL_MACHINE\\SOFTWARE\\VisualSVN\\VisualSVN Server]
添加 "CreateGnuTLSCompatibleCertificate"=dword:00000001

2.  for 64-bit system(64):

[HKEY_LOCAL_MACHINE\\SOFTWARE\\Wow6432Node\\VisualSVN\\VisualSVN Server] 添加"CreateGnuTLSCompatibleCertificate"=dword:00000001

window上打开VisualSVN Server Manager

选择Action(操作)—Properties如下图:

1,Network选项卡中将Use secure connection(https://)前的复选框去掉勾选,

2,看图


直至创建self-signed certificate结束。

:如果没有上述的准备的话在linux上执行下面的svnsync init file:usr/backuprepohttp://yao-pc/svn/MyRepository01/时候,会报:SSLhandshake failed: SSL错误:Keyusage violation in certificate has been detected的错,因为virtual svn在生成鉴权数据的时候使用了一个插件,而这个插件是OpenSSL支持的,但GnuTls是不支持

Linux服务器端操作

1,创建Linux用户和用户组(重要)

   此用户是使用http协议访问svn库的认证用户

# groupadd admin
# useradd admin1 -g admin
# passwd admin1

 

2,linux服务器中安装SubVersion

命令:

# yum install subversion
 # yum install mod_dav_svn   #为了http协议http://ip/repo访问svn,默认只能svn://ip/repo形式                            

3,创建版本库svn-mirror(随意取名)

# mkdir –p /repo/svn  #创建存放svn库的根目录
# svnadmin create /repo/svn/svn-mirror

4将/repo授权给用户admin1及其组

# chown –R admin1:admin /repo
 

5, 配置备份SVN(Linux)的pre-revprop-changehook(钩子)

 

# cd /repo/svn/svn-mirror/hooks
# cp pre-revprop-change.tmpl  pre-revprop-change
# chmod +x pre-revprop-change
# vim pre-revprop-change
清空并添加如下脚本
#!/bin/sh
USER="$3"
if [ "$USER" = "admin1" ]; then exit 0; fi 
 
echo "Only the admin1 user may change revision properties" >&2
exit 1

 6,配置备份SVN的start-commit hook(可选,但建议配上)

# cp start-commit.tmpl  start-commit
# chmod +x start-commit
# vim start-commit
清空并添加如下脚本
#!/bin/sh
USER="$2"
if [ "$USER" = "admin1" ]; then exit 0; fi 
 
echo "Only the admin1 user may change revision properties" >&2
exit 1
注:建议7,8,9步骤(采用本地文件路径file:///)可以先忽略,待至第二部分配置svnhttp访问(采用http模式)结束后再初始化和同步以及启动

7,初始化备份SVN

# svnsync init file:///repo/svn/svn-mirror http://10.16.122.49/svn/MyRepository01/

8,同步版本库

# svnsync sync file:///repo/svn/svn-mirror

9,启动svnserver

# svnserve -d -r /repo/svn   #/usrsvn根目录即创建版本仓库svn-mirror 的目录
参数--listen-port 3691 可以指定端口默认3690  

配置svn的http访问

1编辑httpd.conf

# vim /etc/httpd/conf/httpd.conf

ServerName localhost:80   #去掉前面的#

Useradmin1               #将用户名更改为admin1为了下文root启动httpd时候用admin1运行

Groupadmin               #将组名更改为admin

 

2编辑subversion.conf配置文件

# vim /etc/httpd/conf.d/subversion.conf

增加:

<Location /svn-mirror>

        DAV svn

        SVNPath /repo/svn/svn-mirror#前文创建的版本库

</Location>

3 添加用户认证

  在上一步中浏览器访问时候任何人都可以匿名访问,并且拥有写入,读取,删除权限,这不安全,下面配置用户写入时需认证

# mkdir -p /etc/svn
# htpasswd –c /etc/svn/svnusers.conf admin1 
New password:
Re-type new password:
Adding password for user admin1

4 修改上文步骤2中配置的subversion.conf文件:

<Location /svn-mirror>
   DAV svn
   SVNPath /repo/svn/svn-mirror
   #对库的写权限需要用户认证,访问读取时不受限制的
   <LimitExcept GET PROPFIND OPTIONS REPORT>
      #使用用户名和密码认证
      AuthType Basic
      #认证对话框中提示信息
      AuthName "Authorization Realm"
      #认证用户的文件路径
      AuthUserFile /etc/svn/svnusers.conf
      #只有认证正确才能访问svn
      Require valid-user
   </LimitExcept>
</Location>

5 开启httpd服务

# apachectl start  #root用户启动
浏览器访问http://192.168.193.100/svn-mirror
注:svn-mirrorsubversion.conf中配置的<Location /svn-mirror>,名称可以随意配置

 

6更改配置/home/admin1/.subversion/servers

# vim /home/admin1/.subversion/servers

#将前面的#号放开,并改为yes,为了取消在同步时候需要互动(手动填写提示信息)

store-plaintext-passwords = yes

7初始化svn(Linux上执行)

# svnsync init http://192.168.193.100/svn-mirror  http://10.16.122.49/svn/MyRepository01/--username admin1 –-password 123456

8同步svn

# svnsync sync http://192.168.193.100/svn-mirror --usernameadmin1 --password 123456

 

测试

新建任意文件提交至MyRepository01库中,检查svn-mirror库中的文件是否已经更新


以上是关于备份数据库的磁盘上结构版本为611.服务器支持版本539,无法还原或升级数据库的主要内容,如果未能解决你的问题,请参考以下文章

已备份数据库的磁盘结构版本号为611,server支持版本号为539,无法还原或升级数据库

sql还原时出现3169错误

SVN版本库实时备份整理

服务器要怎么备份

PHP5.5降版本到5.4.45,K哥

mysql备份问题,mysql版本5.7.2