- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章SQLServer 镜像功能完全实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在域环境下我没配置成果,也许是域用户的原因,因为我在生产环境下搞的,更改域用户需要重启SQLServer ,所以这个方法放弃了,只能用证书形式。 环境: 主机:192.168.10.2 (代号A) 镜像:192.168.10.1 (代号B,为了一会说明方便) (条件有限我没有搞见证服务器。)两台服务器上的都是SQLServer2005 首先配置主机 主机上执行以下SQL 。
复制代码代码如下
--创建主机数据库主密钥 USE master; CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'password'; GO --在10.2上为数据库实例创建证书 CREATE CERTIFICATE As_A_cert WITH SUBJECT = 'As_A_cert', START_DATE = '09/02/2011', EXPIRY_DATE = '01/01/2099'; GO --在10.2上使用上面创建的证书为数据库实例创建镜像端点 CREATE ENDPOINT Endpoint_As STATE = STARTED AS TCP ( LISTENER_PORT=5022, LISTENER_IP = ALL ) FOR DATABASE_MIRRORING ( AUTHENTICATION = CERTIFICATE As_A_cert, ENCRYPTION = REQUIRED ALGORITHM RC4, ROLE = ALL ); GO 。
注:这里要注意设置数据库的镜像端口。5022. --备份10.2上的证书并拷贝到10.1上 BACKUP CERTIFICATE As_A_cert TO FILE = 'D:\As_A_cert.cer'; GO 注:备份证书A,并将证书A拷贝到镜像服务器B上。 配置镜像服务器 。
复制代码代码如下
USE master; CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'password'; GO --在10.1 B上为数据库实例创建证书 CREATE CERTIFICATE As_B_cert WITH SUBJECT = 'As_B_cert', START_DATE = '09/2/2011', EXPIRY_DATE = '01/01/2099'; GO --在10.1 B上使用上面创建的证书为数据库实例创建镜像端点 CREATE ENDPOINT Endpoint_As STATE = STARTED AS TCP ( LISTENER_PORT=5022 , LISTENER_IP = ALL ) FOR DATABASE_MIRRORING ( AUTHENTICATION = CERTIFICATE As_B_cert , ENCRYPTION = REQUIRED ALGORITHM AES , ROLE = ALL ); GO 。
--备份10.1 B上的证书并拷贝到10.2 A上 BACKUP CERTIFICATE As_B_cert TO FILE = 'D:\As_B_cert.cer'; GO 同样将备份的证书B 拷贝到A服务器上。 建立用于镜像登录的账户 在A上执行 --交换证书, --同步 Login 。
复制代码代码如下
CREATE LOGIN B_login WITH PASSWORD = 'password'; CREATE USER B_user FOR LOGIN B_login; CREATE CERTIFICATE As_B_cert AUTHORIZATION B_user FROM FILE = 'D:\As_B_cert.cer'; GRANT CONNECT ON ENDPOINT::Endpoint_Bs TO [B_login]; 。
在B上执行 。
复制代码代码如下
--交换证书, --同步 Login CREATE LOGIN A_login WITH PASSWORD = 'password'; CREATE USER A_user FOR LOGIN A_login; CREATE CERTIFICATE As_A_cert AUTHORIZATION A_user FROM FILE = 'D:\As_A_cert.cer'; GRANT CONNECT ON ENDPOINT::Endpoint_As TO [A_login]; 。
记得两台服务器的端口5022是不被占用的,并且保证两个服务器可以连接 以后步骤执行没问题,镜像已经完成一半了。 接下来完整备份A服务器上的Test库 。
复制代码代码如下
--主机执行完整备份 USE master; ALTER DATABASE Test SET RECOVERY FULL; GO BACKUP DATABASE Test TO DISK = 'D:\SQLServerBackups\Test.bak' WITH FORMAT; GO BACKUP LOG Test TO DISK = 'D:\SQLServerBackups\Test.bak'; GO 。
--将备份文件拷贝到B上。 一定要执行完整备份。 在B服务器上完整欢迎数据库 这里问题多多。一个一个说。 如果我们直接执行如下SQL. 。
复制代码代码如下
RESTORE DATABASE Test FROM DISK = 'D:\Back\Test.bak' WITH NORECOVERY GO RESTORE LOG Test FROM DISK = 'D:\Back\Test_log.bak' WITH FILE=1, NORECOVERY GO [code] 可能会报: 消息 3154,级别 16,状态 4,第 1 行 备份集中的数据库备份与现有的 'Test'数据库不同。 消息 3013,级别 16,状态 1,第 1 行 可能是两个数据库的备份集名称不同导致,找了半天原因未果,所以采用下面sp_addumpdevice方法来做。 用sp_addumpdevice来建立一个还原的设备。这样就保证了改备份文件是数据这个数据库的。 [code] exec sp_addumpdevice 'disk','Test_backup', 'E:\backup\Test.bak' exec sp_addumpdevice 'disk','Test_log_backup', 'E:\backup\Test_log.bak' go 。
成功之后我们来执行完成恢复 。
复制代码代码如下
RESTORE DATABASE Test FROM Test_backup WITH DBO_ONLY, NORECOVERY,STATS; go RESTORE LOG Test FROM Test_log_backup WITH file=1, NORECOVERY; GO 。
这里如果之前备份过多次数据库的话,肯会产生多个备份集。所以这里的 file就不能指定为1了。 这个错误可能是: 消息 4326,级别 16,状态 1,第 1 行 此备份集中的日志终止于 LSN 36000000014300001,该 LSN 太早,无法应用到数据库 。可以还原包含 LSN 36000000018400001 的较新的日志备份。 可以通过这句话来查询该备份文件的备份集 restore headeronly from disk = 'E:\backup\Test_log.bak' 找到最后一个的序号就指定给file就可以。 还需要注意的是第一次完整恢复的时候需要指定NORECOVERY。 至此所有准备工作都已经完成我们开始执行镜像 先在镜像服务器上执行 ALTER DATABASE Test SET PARTNER = 'TCP://192.168.10.2:5022'; 成功之后再在主机上执行 ALTER DATABASE Test SET PARTNER = 'TCP://192.168.10.2:5022'; 这样两台服务器的镜像就同步了。 。
删除镜像:
ALTER DATABASE Test SET PARTNER OFF 。
如果主机出现问题,在主机执行 。
复制代码代码如下
USE MASTER Go ALTER DATABASE Test SET PARTNER FAILOVER Go 。
总结: 如果在建立镜像的时候中间的那个步骤出国,需要重新执行的时候一定要把该删得东西删除掉。 --查询镜像 select * from sys.endpoints --删除端口 drop endpoint Endpoint_As --查询证书 select * from sys.symmetric_keys --删除证书,先删除证书再删除主键 DROP CERTIFICATE As_A_cert --删除主键 DROP MASTER KEY --删除镜像 alter database <dbname> set partner off --删除登录名 drop login <login_name> sp_addumpdevice 的语法 。
复制代码代码如下
sp_addumpdevice [ @devtype = ] 'device_type' , [ @logicalname = ] 'logical_name' , [ @physicalname = ] 'physical_name' ] 其中参数有: @devtype:设备类型,可以支持的值为disk和tape,其中disk为磁盘文件;tape为 windows支持的任何磁带设备。 @logicalname:备份设备的逻辑名称,设备名称。 @physicalname:备份设备的物理名称,路径 。
。
。
参考: http://msdn.microsoft.com/zh-cn/library/ms186289.aspx 。
最后此篇关于SQLServer 镜像功能完全实现的文章就讲到这里了,如果你想了解更多关于SQLServer 镜像功能完全实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
在我的 Windows 类库(由 MVC 网站使用)中,我安装了 NugetPackage Microsoft.SqlServer.Types (Spatial)。 现在,我正在使用 ado.net
测试sql: 复制代码代码如下: SET STATISTICS IO ON SET STATISTICS TIME ON SELECT COUNT(1)&n
我正在从 SqlConnection 构建 DbContext。当我使用它时,我收到以下错误: The Entity Framework provider type 'System.Data.Enti
我使用dotNet 4.5创建了WCF服务。数据库层是使用Entity Framework 6构建的。 我使用IIS 8托管了该服务。它运行正常。 现在,我需要使用Windows窗体客户端使用该服务,
我正在尝试从 SqlServer 1 上的 sql 数据库中导出一些表。在我们的内部网 LAN(就在我旁边)中有一个我制作的临时 Sql Server,称为 SqlServer 2。 我不想备份整个数
Error 1 Copying file bin\EntityFramework.SqlServer.xml to obj\Debug\Package\PackageTmp\bin\Entit
我正在尝试使用 SMO 通过 Powershell 恢复数据库,但是当我尝试定义和使用服务器对象时,出现以下错误: Cannot convert argument "srv", with value:
出于某种原因,我需要将我的表列之一从“NOT NULL”更新为“NULL”。命令很简单: ALTER TABLE TBLOGDOCMESSAGE ALTER COLUMN PROCESSID BIGI
我想知道我正在尝试做的事情是否可行。我相信它是在 TSQL 中使用 PIVOT 函数,但对 PIVOT 函数没有足够的经验来知道从哪里开始。 基本上,我正在尝试采用以下名为 #tmpbudgetdat
我正在尝试将子查询作为带有条件的列。 我从 SQL Server 得到的错误是: 子查询返回了 1 个以上的值。当子查询跟随 =、!=、、>= 或当子查询用作表达式时,这是不允许的。 我正在选择更多的
我有一个正在查询的 SQL 服务器数据库,我只想在特定行为空时获取信息。我使用了一个 where 语句,例如: WHERE database.foobar = NULL 它不返回任何东西。但是,我知道
1、拼接字符串(整个字符串不分割)步骤: 首先在字符串的前后加单引号; 字符串中的变量以'''+@para+'''在字符串中表示; 若在执行时存在类型转换错误,则应用相应的类型
说明: 收缩日志的原因有很多种,有些是考虑空间不足,有些则是应用程序限制导致的。 ?
Rand()函数是系统自带的获取随机数的函数,可以直接运行select rand() 获取0~1之间的float型的数字。 如果想要获取0~100之间的整数随机数,可以这样使用 select ro
将以下内容保存为 openSql.bat 双击运行即可 复制代码 代码如下: @echo ========= SQL Server Ports =================== @ech
新增的APPLY表运算符把右表表达式应用到左表表达式中的每一行。它不像JOIN那样先计算那个表表达式都可以,APPLY必选先逻辑地计算左表达式。这种计算输入的逻辑顺序允许吧右表达式关联到左表表达式。
SQL Server本身提供了这么一个DMV来返回这些信息,它就是sys.dm_exec_sessions 。 比如在我的机器上做一下查询: 复制代码 代码如下: SELECT * FROM
尽管从技术上讲,其它排名函数的计算与ROW_NUMBER类似,但它们的的实际应用却少很多。RANK和DENSE——RANK主要用于排名和积分。NTILE更多地用于分析。 先创建一个示例表: 复制
1、文件和文件组的含义与关系 每个数据库有一个主数据文件.和若干个从文件。文件是数据库的物理体现。 文件组可以包括分布在多个逻辑分区的文件,实现负载平衡。文件组允许对文件进行分组,以便于管理和数据的
我想很多人都知道,在oracle里面,存储过程里面可以传入数组(如int[]),也就是说,可以传多条记录到数据,从而一起更新。减少数据库的请求次数。 但SqlServer呢?bulk Insert这
我是一名优秀的程序员,十分优秀!