第三文 配置SQL Server镜像——域环境

原文出处:http://blog.csdn.net/dba_huangzj/article/details/28904503

本文将演示如何在域环境下部署镜像,在域中部署相对来说简单很多,但是很多企业并不真正使用域来管理服务器(本人所在的公司就是其一),所以有必要演示非域环境,并且重点放在非域环境下。但是作为实践经验和最佳建议,强烈使用域环境管理。非域环境将在第四文中演示:http://blog.csdn.net/dba_huangzj/article/details/27652857 。本文只关注域环境下的搭建。

无论使用哪种方式,都可以分成两部分,第一部分是准备工作,第二部分是实施工作

准备工作:

 

除了OS级别的配置之外,还有下面的步骤需要提前操作:

 

1. 设置数据库的恢复模式,镜像需要数据库的恢复模式为完整模式,可以使用下面语句修改:

 

ALTER DATABASE AdventureWorks2008R2 SET RECOVERY FULL;
   
   

 

2. 检查数据库的兼容级别是否为90或以上,即是否为2005或以上的SQL Server,如果不是,可以使用下面脚本修改:

 


   
   
  1. ALTER DATABASE AdventureWorks2008R2 SET COMPATIBILITY_LEVEL= 100--2008
  2. SP_DBCMPTLEVEL @DBNAME=’’,@NEW_CMPTLEVEL= 90 --2005


 

3. 配置所有所需的登录帐号,主体和镜像都要,可以使用下面方式:

 

1. SSIS传输登录

2. 生成脚本方式

3. 手动同步

4. 配置外部资源,比如SSIS包、维护计划,共享文件等。

 

安装前配置:

 

1. 禁用服务器上的完整备份和日志备份作业。

2. 执行完整备份,并把备份文件复制到镜像服务器

3. 使用NORECOVERY还原备份到镜像服务器,

4. 执行日志备份并复制到镜像服务器,同样以NORECOVERY还原日志

 

如果没有使用NORECOVERY,配置过程会报错,需要重新还原,所以这一点非常重要。

 

域环境下配置镜像:

 

环境:虚拟机使用hyper-v,安装了简单的域环境(这部分不属于演示范畴,读者可以自行查找相关资料),OS均为Windows Server 2008R2 x64。

SQL Server 2008R2 x64 企业版。创建一个域帐号 MirrorAdmin,密码为Pa$$w0rd (其中的0为数字不是字母o)。

 

DC上的IP:

 

clip_image001

 

SQL-A的IP:

 

clip_image002

SQL-B的IP:

 

clip_image003

 

添加域用户到SQL Server中:

 

先用域管理员或者安装时添加的Windows账号或者用sa登录:

 

clip_image005

 

然后添加新建的域账号到SQL Server中:

clip_image006

添加Windows账号:

 

clip_image008

添加SQL Server服务器角色,为了演示方便,这里选择sysadmin角色:

 

clip_image010

 

添加成功后,以这个加进去的Windows账号登录Windows,然后以Windows 身份验证登录SQL Server:

 

clip_image011

 

开始搭建:

 

下面开始使用微软示例数据库AdventureWorks2008R2作为演示:

 

clip_image012

文件存放在本地C:\DB\

 

 

clip_image014

 

首先根据前面的准备工作把库的恢复模式、完整备份等操作先做完,完整备份我们先新建一个共享文件夹存放,供传输到镜像服务器也就是本文中的SQL-B使用,注意选择【NORECOVERY】恢复状态,如图:

 

clip_image016

还原后在镜像数据库中可以看到如图:

 

clip_image017

 

现在回到主体服务器,打开镜像选项:

 

clip_image019

选择【配置安全性】:

 

clip_image021

 

这里先不搭建见证服务器,所以选择【否】:

clip_image023

 

这一步如果不需要改动其他信息,可以直接点【下一步】:

clip_image025

选择【镜像服务器】:

clip_image027

如果发现连不上镜像服务器,比如下面的报错:

 

clip_image029

 

可以选择关闭防火墙,或者开启5022等所需端口,直到能连上为止:

 

clip_image031

选择【服务账号】:

clip_image033

 

完成配置:

clip_image035

 

 

 

clip_image037

 

完成配置之后,界面会马上弹出是否需要【开始镜像】,如果一切准备好了,并且的确需要开启,就点击【开始镜像】:

 

clip_image039

 

成功开始镜像过程之后,可以看到如下截图,证明搭建已经完毕,可以使用红框部分的【故障转移】进行Failover,把主体数据库的活动会话转到镜像数据库上:

 

clip_image041

 

搭建完毕之后,检查两个服务器的数据库状态:

 

clip_image042

下面测试一下故障转移(Failover):

clip_image044

 

再刷新两台服务器的数据库,可见下面状态:

 

clip_image045

 

SQL Server镜像功能提供了一个【数据库镜像监视器】,可以在下图中的地方打开,这个工具在监控镜像时很有用,如何使用这个工具将在后面的文章中介绍:

clip_image046

打开之后,可以检查镜像环境的一些信息:

clip_image048

 

除了进行故障转移,还可以下切换运行模式 :

clip_image050

首先检查原有的运行模式:

clip_image052

可见目前是高安全性模式(Safety为FULL)。

然后进行模式转换,再检查状态:

clip_image054

 

可见目前已经是高性能模式(Safety为OFF)。

 

添加见证服务器:

clip_image055

 

这里需要选择【是】:

clip_image057

 

然后点下一步:

 

clip_image059

 

在主体服务器中连接见证服务器,也就是本文的【SQL-CORE】实例:

clip_image061

 

指定镜像环境中的账号,由于在域环境中,所以可以使用同一个域账号:

 

clip_image063

 

搭建完毕后可以看到下面的截图:

 

clip_image065

 

我们可以通过停止主体服务器(SQL-A)的服务进行检验:

 

clip_image066

 

可见主体数据库已经切换到原镜像服务器(SQL-B)中:

 

clip_image067

 

重新启动SQL-A,然后再停止SQL-B的服务:

 

clip_image068

 

可见主体库又回到了SQL-A中:

clip_image069

至此,域环境下的镜像搭建演示已经完毕。

 

SQL Server镜像有一个重要补丁,这个补丁主要是修复2005的镜像环境中日志问题,对2008不需要处理:http://support.microsoft.com/kb/947462。当你在搭建和使用2005的镜像功能时,如果报错:当您启动数据库镜像会话,SQL Server 2005 中错误消息:"与远程服务器实例的通信TCP: / / < 计算机名>:< 端口号> 数据库镜像尚未完全启动之前发生故障"。则意味着你需要使用这个补丁修复。

搭建镜像,特别在域环境中其实非常简单,本系列把重点放在自动化部署、监控和优化过程中,所以不会做过多的部署演示。

下文是对非域环境的搭建:http://blog.csdn.net/dba_huangzj/article/details/27652857

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值