位置: 编程技术 - 正文

mssql2005数据库镜像搭建教程(数据库镜像是什么意思)

编辑:rootadmin

一 概述

数据库镜像是SQL SERVER 用于提高数据库可用性的新技术。数据库镜像将事务日志记录直接从一台服务器传输到另一台服务器,并且能够在出现故障时快速转移到备用服务器。可以编写客户端程序自动重定向连接信息,这样一旦出现故障转移就可以自动连接到备用服务器和数据库。

优势:数据库镜像可以在不丢失已提交数据的前提下进行快速故障转移,无须专门的硬件,并且易于配置和管理。

二 环境准备

操作系统:Window enterprise sp2(至少两台,如要启用自动故障转移,必需三台)

SQL版本:MSSQL SERVER SP3

检查SQL SERVER版本:

exec xp_msver

select SERVERPROPERTY('productlevel')

数据库准备:准备一个数据库:ccerp_jzt ,备份此数据库还原到另外一台机器上,另外一台必须是with no recovery

这里我假设服务器A,B,C

A为主体服务器,B为镜像服务器,C为见证服务器

A服务器

use master

go

restore filelistonly from disk=N'f:databakccerp_jzt_backup_.bak'

restore database ccerp_jzt from disk=N'f:databakccerp_jzt_backup_.bak' with replace,recovery,

move 'ccerp_ydswzip_Data' to 'd:dataccerp_jzt.mdf',

move 'ccerp_ydswzip_Log' to 'd:dataccerp_jzt_log.ldf'

exec sp_helpdb 'ccerp_jzt'

backup database ccerp_jzt to disk =N'f:databaksk.bak' with init

--更改恢复模式

alter database ccerp_jzt set recovery full

B服务器:

CREATE DATABASE ccerp_jzt

ON

( NAME = Sales_dat,

FILENAME = 'd:dataccerp_jzt.mdf',

SIZE =

)

LOG ON

( NAME = 'ccerp_jzt_log',

FILENAME = 'd:dataccerp_jzt_log.ldf',

SIZE = 5MB

)

GO

restore filelistonly from disk=N'f:xxzxdatask.bak'

use master

go

restore database ccerp_jzt from disk=N'f:xxzxdatask.bak' with replace,norecovery,

exec sp_helpdb 'ccerp_jzt'

C服务器只要装上SQL SERVER 就可以,无需其他准备

准备完成后如下图所示:

三 三种模式的搭建

数据库镜像要建立必需得建立信任关系,那么在WIN环境下建立信任关系可以通过三种方式:域帐户,证书信任,windows 匿名登陆,现就前两种模式做配置说明.

3.1 域帐户模式:

3.1.1 更改mssqlserver服务的的登陆方式为域帐户登陆方式:

进入windows服务管理控制台,更改服务登陆帐户,使域账户有更改MSSQL SERVER服务状态的权限.三台机器都做同样设置

将域帐户赋予sysadmin角色

3.1.2 建立端点:

通过图形界面建立端点:

启动SQLWB,按图一直下一步

用域帐户登陆

如果成功则:

3.2 证书模式

3.2.1建立证书&端点

参与数据库镜像会话的服务器必须彼此信任。对于本地通信而言,例如一个域内的通信,信任意味着SQL Server实例登陆账号必须有权限连接到其他镜像服务器,也包括endpoints。首先在每个服务器上使用CREATE LOGIN命令,然后使用GRANT CONNECT ON ENDPOINT命令.非信任域之间的通信必须使用证书。如果使用CREATE CERTIFICATE语句创建自签名的证书,基本上所有数据镜像证书的要求都可以满足。确认在CREATE CERTIFICATE语句中将证书标记为ACTIVE FOR BEGIN_DIALOG。

一 建立证书:

镜像服务器上执行:

USE master;

CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'TEST';

CREATE CERTIFICATE HOST_A_cert WITH SUBJECT='HOST_A certificate', START_DATE='--';

主体服务器上执行:

USE master;

CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'TEST';

CREATE CERTIFICATE HOST_B_cert WITH SUBJECT='HOST_B certificate', START_DATE='--';

见证服务器上执行:

USE master;

CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'TEST';

CREATE CERTIFICATE HOST_C_cert WITH SUBJECT='HOST_C certificate', START_DATE='--';

二 建立端点:

镜像服务器上执行:

--create mirror endpoint on primary A

CREATE ENDPOINT Endpoint_Mirroring

STATE = STARTED AS

TCP ( LISTENER_PORT= , LISTENER_IP = ALL )

FOR DATABASE_MIRRORING

( AUTHENTICATION = CERTIFICATE HOST_A_cert , ENCRYPTION = REQUIRED ALGORITHM AES , ROLE = ALL );

主体服务器上执行:

--Create endpoint on mirror server B

CREATE ENDPOINT Endpoint_Mirroring

STATE = STARTED

AS

TCP ( LISTENER_PORT= , LISTENER_IP = ALL )

FOR

DATABASE_MIRRORING

( AUTHENTICATION = CERTIFICATE HOST_B_cert , ENCRYPTION = REQUIRED ALGORITHM AES , ROLE = ALL );

见证服务器上执行:

--Create endpoint on witness server C

CREATE ENDPOINT Endpoint_Mirroring

STATE = STARTED

AS

TCP ( LISTENER_PORT= , LISTENER_IP = ALL )

FOR

DATABASE_MIRRORING

( AUTHENTICATION = CERTIFICATE HOST_C_cert ,

ENCRYPTION = REQUIRED ALGORITHM AES , ROLE = witness );

SELECT * FROM sys.database_mirroring_endpoints;

证书互备:

镜像服务器上执行:

--backup certificate

BACKUP CERTIFICATE HOST_A_cert TO FILE = 'e:HOST_A_cert.cer'

主体服务器上执行

--backup certificate

BACKUP CERTIFICATE HOST_B_cert TO FILE = 'e:HOST_B_cert.cer'

见证服务器上执行:

BACKUP CERTIFICATE HOST_c_cert TO FILE = 'e:HOST_C_cert.cer'

将备份到的证书进行互换,即HOST_A_cert.cer复制到B机的e: 将HOST_B_cert.cer复制到A机的E:,也就是每台服务器有三个证书

三:建立登陆用户:

镜像服务器上执行:

--Create user

CREATE LOGIN HOST_B_login WITH PASSWORD = 'test';

CREATE USER HOST_B_user FOR LOGIN HOST_B_login;

CREATE CERTIFICATE HOST_B_cert AUTHORIZATION HOST_B_user FROM FILE = 'e:HOST_B_cert.cer';

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_B_login];

CREATE LOGIN HOST_C_login WITH PASSWORD = 'test';

CREATE USER HOST_C_user FOR LOGIN HOST_c_login;

CREATE CERTIFICATE HOST_c_cert AUTHORIZATION HOST_c_user FROM FILE = 'e:HOST_c_cert.cer';

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_c_login];

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_A_login];

--query user sid

select loginname,name,sid From syslogins

主体服务器上执行:

--Create user

CREATE LOGIN HOST_A_login WITH PASSWORD = 'test';

CREATE USER HOST_A_user FOR LOGIN HOST_A_login;

CREATE CERTIFICATE HOST_A_cert AUTHORIZATION HOST_A_user FROM FILE = 'e:HOST_A_cert.cer';

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_A_login];

-- add witness user

CREATE LOGIN HOST_C_login WITH PASSWORD = 'test';

CREATE USER HOST_C_user FOR LOGIN HOST_c_login;

CREATE CERTIFICATE HOST_c_cert AUTHORIZATION HOST_c_user FROM FILE = 'e:HOST_c_cert.cer';

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_c_login];

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_B_login];

--query sid

select loginname,name,sid From syslogins

见证服务器上执行:

--Create user

CREATE LOGIN HOST_A_login WITH PASSWORD = 'test';

CREATE USER HOST_A_user FOR LOGIN HOST_A_login;

CREATE CERTIFICATE HOST_A_cert AUTHORIZATION HOST_A_user FROM FILE = 'e:HOST_A_cert.cer';

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_A_login];

--add user host_b_login to have pemission to access witness

CREATE LOGIN HOST_B_login WITH PASSWORD = 'test';

CREATE USER HOST_B_user FOR LOGIN HOST_B_login;

CREATE CERTIFICATE HOST_B_cert AUTHORIZATION HOST_B_user FROM FILE = 'e:HOST_B_cert.cer';

GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [HOST_B_login];

grant connect on endpoint::endpoint_mirroring to HOST_C_login

USE master;

exec sp_addlogin

@loginame = 'HOST_B_login',

@passwd = 'test',

@sid = 0x1ACA3D1DCEBCE4C4F ;

ALTER DATABASE ccerp_jzt SET PARTNER = '

四.建立镜像:

先在镜像服务器上执行:

ALTER DATABASE ccerp_jzt SET PARTNER = '

接着主体服务器执行:

ALTER DATABASE ccerp_jzt SET PARTNER = '

ALTER DATABASE ccerp_jzt SET witness = '

至此引证书建立完毕

四、测试操作

1、主备互换

--主机执行:

1USE master;2ALTER DATABASE <DatabaseName> SET PARTNER FAILOVER;

2、主服务器Down掉,备机紧急启动并且开始服务

--备机执行:

1USE master;2ALTER DATABASE <DatabaseName> SET PARTNER FORCE_SERVICE_ALLOW_DATA_LOSS;

3、原来的主服务器恢复,可以继续工作,需要重新设定镜像

1--备机执行:2USE master;3ALTER DATABASE <DatabaseName> SET PARTNER RESUME; --恢复镜像4ALTER DATABASE <DatabaseName> SET PARTNER FAILOVER; --切换主备

4、原来的主服务器恢复,可以继续工作

--默认情况下,事务安全级别的设置为 FULL,即同步运行模式,而且SQL Server 标准版只支持同步模式。

--关闭事务安全可将会话切换到异步运行模式,该模式可使性能达到最佳。

1USE master;2ALTER DATABASE <DatabaseName> SET PARTNER SAFETY FULL; --事务安全,同步模式3ALTER DATABASE <DatabaseName> SET PARTNER SAFETY OFF; --事务不安全,异步模式

错误说明:消息,级别,状态3,第1 行

默认情况下,数据库镜像是被禁用的。当前提供的数据库镜像仅供评估使用,并不应使用于生产环境中。若要以评估为目的启用数据库镜像,请在启动过程中使用跟踪标志。有关跟踪标志和启动选项的详细信息,请参阅SQL Server 联机丛书。

解决办法:没打SP1以上补丁.强烈建议打SP3

消息,级别,状态2,第1 行

由于"ccerp_jzt" 数据库可能有尚未备份的大容量日志记录更改,所以无法启用数据库镜像。必须在镜像上还原主体数据库的上一次日志备份。

主体上:backup log ccerp_jzt to disk ='e:log.trn' with no_truncate

镜像上:restore log ccerp_jzt from disk='e:log.trn' with norecovery

推荐整理分享mssql2005数据库镜像搭建教程(数据库镜像是什么意思),希望有所帮助,仅作参考,欢迎阅读内容。

mssql2005数据库镜像搭建教程(数据库镜像是什么意思)

文章相关热门搜索词:mssql镜像数据库,数据库镜像是什么意思,mssql镜像数据库,mysql数据库镜像,mysql数据库镜像,sql数据库镜像怎么部署,sql2008数据库镜像,sql2008数据库镜像,内容如对您有帮助,希望把文章链接给更多的朋友!

SQL Server DTS导入平面数据出现错误解决方案 SQLServerDTS导入平面数据源时,总是被截断,无法执行的错误解决方案1典型的错误信息如下:消息*错误0xca1:数据流任务:数据转换失败。列列2的数

sql 日志清理 SQL压缩清除日志的方法 教你如何清除SQL日志1.打开查询分析器,输入命令DUMPTRANSACTION数据库名WITHNO_LOG2.再打开企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收

SQL利用ROW_NUMBER() OVER实现分页功能 1.首先介绍ROW_NUMBER()OVER的基本用法2.看一下实例数据初始化数据createtableemployee(empidint,deptidint,salarydecimal(,2))insertintoemployeevalues(1,,.)insertintoemployeeva

标签: 数据库镜像是什么意思

本文链接地址:https://www.jiuchutong.com/biancheng/319388.html 转载请保留说明!

上一篇:sql server 2005用户权限设置深入分析(sql server single user)

下一篇:SQL Server 2005 DTS导入平面数据出现错误解决方案

  • 金税开票软件下载安装
  • 车险发票不含车船税怎么记账
  • 长期待摊费用对方科目
  • 火车票丢失怎么补办
  • 调拨单可以根据哪些单据生成
  • 税盘服务费抵税怎么做分录
  • 盘盈固定资产属于企业的会计差错
  • 合法有效的凭证
  • 专票红冲账务处理
  • 职工伤残补助金被单位扣留违反什么法
  • 企业发生的辞退福利
  • 没有认缴时间的公司
  • 合并报表盈余公积怎么提
  • 企业进口应税物资在进口环节应交的消费税,应计入
  • 企业交的房产税在哪打印税单
  • 建筑安装税务分类编码为多少?
  • 分公司开票总公司收款行吗
  • 预缴税款是开票金额的多少
  • 其他应付款报表填列
  • 工资发错了,多发了怎么办
  • 作废的发票没有验旧丢了怎么办
  • 土地开垦费怎么征收
  • 差额发票如何缴纳增值税
  • 小规模减半征收什么时候开始
  • 收到小额支付转账什么意思
  • 股东以无形资产投资,撤资时怎么算
  • 苹果电脑删除win系统文件
  • 房地产企业预缴增值税如何申报
  • 固定资产无偿转让程序是什么
  • Linux系统中quota磁盘命令的相关使用解析
  • sgbhp.exe - sgbhp是什么进程 有什么用
  • php扩展ffmpeg教程
  • 经营租赁的房屋计提折旧吗
  • 租车接送员工上班怎么样
  • 赔付支出有哪些
  • php延迟静态绑定
  • 发票多久过期不能开
  • 异地开办分公司流程
  • 销售材料账务处理
  • 什么是重绘和回流
  • php php
  • 进口商品销售的会计分录
  • 个体工商户开增值税专用发票
  • 工地购买的厨房用品计入哪个科目
  • 印花税的会计处理方法
  • 建筑业普票与专票怎么抵扣
  • 收取物业费如何纳税
  • 公司向个人借款的会计分录怎么做
  • 固定资产能直接计入费用吗为什么
  • 餐饮店赠品
  • 以摊余成本计量的金融资产会计处理
  • 首先我们先了解一下作者英语怎么说呢
  • 甲方扣水电费施工方是否开票
  • 开设专栏方案
  • vista windows
  • Windows Server 2008关闭闲置状态的IDE通道
  • win73d设置怎么设置
  • win10蓝屏后黑屏
  • linux使用cp
  • 在pc上安装了hp网络打印机需要注意什么
  • 联想笔记本出厂编号怎么查询
  • find 命令 查找文件
  • 手动为LiteSpeed安装eAccelerator和XCache的方法分享
  • 2015.6.28开始写博客记录cocos2dx学习历程
  • 批量替换在哪
  • ubuntu与centos命令区别
  • Android---59---Toast的使用
  • js 不用var
  • jquery常用选择器种类
  • jQuery对checkbox 复选框的全选全不选反选的操作
  • python django
  • jquery移动版
  • h5实现微信分享
  • 个人经营所得定率征收税率表
  • 电子税务局用户名和密码是什么
  • 如何查询车辆购买的保险是哪家保险公司
  • 全资子公司和全资子企业的区别
  • 达州房管局备案查询系统
  • 贷款抵押担保合同
  • 代扣app有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设