首页 > 数据库 >SQLServer 复制和数据库镜像 详细配置部署

SQLServer 复制和数据库镜像 详细配置部署

时间:2023-01-27 15:09:13浏览次数:85  
标签:kk 数据库 SQLServer -- Cert 服务器 GO 镜像


SQLserver 可以把镜像和复制同时部署,结合了双方的高可用性,可以使数据库得到更好的高可用性和容灾的保证。


关于镜像:​​数据库镜像​

关于复制:​​SQL Server 复制​

本章的复制为事务可更新订阅:​​事务复制的可更新订阅​

关于复制和数据库镜像:​​复制和数据库镜像​


理论的东西参考官方文档吧,这里主要是部署配置过程。



下图为本章参考部署的架构图:

SQLServer 复制和数据库镜像 详细配置部署_数据库

本章模拟的服务器:

kk-ad

192.168.2.1

DC(域控)

kk-db1

192.168.2.10

主机(Replication + Mirror)

kk-db2

192.168.2.11

镜像(Mirror)

kk-db3

192.168.2.12

见证机(WITNESS)+ 分发

kk-db4

192.168.2.13

订阅(测试1个)



将复制与数据库镜像一起使用时,注意以下要求和注意事项:


1. 主体数据库和镜像数据库必须共享分发服务器。 建议此处使用远程分发服务器,如果发布服务器有意外故障转移,则远程分发服务器可以提供较大的容错能力。



2. 对于合并复制,以及对于使用只读订阅服务器或排队更新订阅服务器的事务复制,复制支持对发布数据库进行镜像。 不支持即时更新对等拓扑中的订阅服务器、Oracle 发布服务器、发布服务器并重新发布。

 

3. 存在于数据库外部的元数据和对象不复制到镜像数据库,包括登录名、作业、链接服务器等等。 如果要求镜像数据库中有元数据和对象,则必须手动复制它们。




配置复制和数据库镜像主要步骤:

1. 配置数据库镜像;(参考 ​​ SQLServer 数据库镜像(二)域环境中完整镜像脚本配置​​)

2. 配置分发服务器;(参考 ​​ 如何配置发布和分发​​​  , ​​如何在分发服务器上启用远程发布服务器​​)

3. 配置发布和订阅;(参考 ​​ 如何创建事务性发布的可更新订阅​​  ,​​SqlServer 使用脚本创建分发服务及事务复制的可更新订阅​​)


说明及注意修改的地方:

本测试使用域账号作为数据库登录账号:[KK\UserReplMirror]

对应数据库用户:[UserReplMirror]

测试数据库:[DemoDB]


确保各服务器能相互访问

数据库 [DemoDB]  恢复模式为完整模式(镜像必须)

数据库 [DemoDB]  所有者改为 [sa]

账号 [KK\UserReplMirror] 授予 sysadmin 权限;或者在数据库 [DemoDB] 中授予用户 [UserReplMirror] 数据库角色为 [db_owner] 

复制的代理作业的所有者都改为[sa]

数据库外的对象不会镜像:如登录账户,代理作业 等



1. 配置数据库镜像:

--主体创建数据库
USE [master]
GO
CREATE DATABASE [DemoDB]
GO
ALTER DATABASE [DemoDB] SET RECOVERY FULL WITH NO_WAIT
GO


--主体:创建证书 和 备份
USE master;
GO
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'kk_2012@';
GO
CREATE CERTIFICATE Cert_kk_db1_mssqlserver
WITH SUBJECT = 'Cert_kk_db1_mssqlserver',
START_DATE = '2015-06-01',EXPIRY_DATE = '2018-06-01';
GO
BACKUP CERTIFICATE Cert_kk_db1_mssqlserver
TO FILE = 'C:\Databases\Cert_kk_db1_mssqlserver.cer';
GO

--镜像:创建证书 和 备份
USE master;
GO
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'kk_2012@';
GO
CREATE CERTIFICATE Cert_kk_db2_mssqlserver
WITH SUBJECT = 'Cert_kk_db2_mssqlserver',
START_DATE = '2015-06-01',EXPIRY_DATE = '2018-06-01';
GO
BACKUP CERTIFICATE Cert_kk_db2_mssqlserver
TO FILE = 'C:\Databases\Cert_kk_db2_mssqlserver.cer';
GO

--见证:创建证书 和 备份
USE master;
GO
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'kk_2012@';
GO
CREATE CERTIFICATE Cert_kk_db3_mssqlserver
WITH SUBJECT = 'Cert_kk_db3_mssqlserver',
START_DATE = '2015-06-01',EXPIRY_DATE = '2018-06-01';
GO
BACKUP CERTIFICATE Cert_kk_db3_mssqlserver
TO FILE = 'C:\Databases\Cert_kk_db3_mssqlserver.cer';
GO


-- 交换证书(相互拷贝证书):
/*
主体证书(拷贝到)————>镜像、见证
镜像证书(拷贝到)————>主体、见证
见证证书(拷贝到)————>主体、镜像
*/



-- 主体(创建用户、还原证书、创建端点):
USE master
GO
CREATE LOGIN [KK\UserReplMirror] FROM WINDOWS;
GO
CREATE USER [UserReplMirror] FOR LOGIN [KK\UserReplMirror];
GO
CREATE CERTIFICATE [Cert_kk_db2_mssqlserver]
AUTHORIZATION [UserReplMirror]
FROM FILE = 'C:\Databases\Cert_kk_db2_mssqlserver.cer';
GO
CREATE CERTIFICATE [Cert_kk_db3_mssqlserver]
AUTHORIZATION [UserReplMirror]
FROM FILE = 'C:\Databases\Cert_kk_db3_mssqlserver.cer';
GO

CREATE ENDPOINT [Endpoint_For_Mirror]
AUTHORIZATION [KK\UserReplMirror]
STATE=STARTED
AS TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
FOR DATA_MIRRORING
(ROLE = PARTNER, AUTHENTICATION = CERTIFICATE Cert_kk_db1_mssqlserver, ENCRYPTION = REQUIRED ALGORITHM AES)
GO
--GRANT CONNECT ON ENDPOINT::Endpoint_For_Mirror TO [KK\UserReplMirror];
--GO



-- 镜像(创建用户、还原证书、创建端点):
USE master
GO
CREATE LOGIN [KK\UserReplMirror] FROM WINDOWS;
GO
CREATE USER [UserReplMirror] FOR LOGIN [KK\UserReplMirror];
GO
CREATE CERTIFICATE [Cert_kk_db1_mssqlserver]
AUTHORIZATION [UserReplMirror]
FROM FILE = 'C:\Databases\Cert_kk_db1_mssqlserver.cer';
GO
CREATE CERTIFICATE [Cert_kk_db3_mssqlserver]
AUTHORIZATION [UserReplMirror]
FROM FILE = 'C:\Databases\Cert_kk_db3_mssqlserver.cer';
GO

CREATE ENDPOINT [Endpoint_For_Mirror]
AUTHORIZATION [KK\UserReplMirror]
STATE=STARTED
AS TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
FOR DATA_MIRRORING
(ROLE = PARTNER, AUTHENTICATION = CERTIFICATE Cert_kk_db2_mssqlserver, ENCRYPTION = REQUIRED ALGORITHM AES)
GO
--GRANT CONNECT ON ENDPOINT::Endpoint_For_Mirror TO [KK\UserReplMirror];
--GO


-- 见证(创建用户、还原证书、创建端点):
USE master
GO
CREATE LOGIN [KK\UserReplMirror] FROM WINDOWS;
GO
CREATE USER [UserReplMirror] FOR LOGIN [KK\UserReplMirror];
GO
CREATE CERTIFICATE [Cert_kk_db1_mssqlserver]
AUTHORIZATION [UserReplMirror]
FROM FILE = 'C:\Databases\Cert_kk_db1_mssqlserver.cer';
GO
CREATE CERTIFICATE [Cert_kk_db2_mssqlserver]
AUTHORIZATION [UserReplMirror]
FROM FILE = 'C:\Databases\Cert_kk_db2_mssqlserver.cer';
GO

USE master;
CREATE ENDPOINT [Endpoint_For_Mirror]
AUTHORIZATION [KK\UserReplMirror]
STATE=STARTED
AS TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
FOR DATA_MIRRORING
(ROLE = WITNESS, AUTHENTICATION = CERTIFICATE Cert_kk_db3_mssqlserver, ENCRYPTION = REQUIRED ALGORITHM AES)
GO
--GRANT CONNECT ON ENDPOINT::Endpoint_For_Mirror TO [KK\UserReplMirror];
--GO


--主体:备份数据库
USE master;
BACKUP DATABASE [DemoDB]
TO DISK = 'C:\Databases\DemoDB.BAK' WITH INIT,FORMAT
GO

BACKUP LOG [DemoDB]
TO DISK = 'C:\Databases\DemoDB_LOG.BAK' WITH INIT,FORMAT
GO


--镜像:还原数据库(NORECOVERY)
USE master;
RESTORE DATABASE [DemoDB]
FROM DISK = N'C:\Databases\DemoDB.BAK'
WITH FILE = 1,
MOVE N'DemoDB' TO N'C:\Databases\DemoDB.mdf',
MOVE N'DemoDB_log' TO N'C:\Databases\DemoDB_log.ldf',
NOUNLOAD, NORECOVERY, STATS = 10
GO

RESTORE DATABASE [DemoDB]
FROM DISK = N'C:\Databases\DemoDB_LOG.BAK'
WITH NORECOVERY
GO



--开始镜像

--在【镜像】执行,PARTNER为主服务器
USE [master]
GO
ALTER DATABASE [DemoDB] SET PARTNER = 'TCP://192.168.2.10:5022';
GO

--在【主体】执行,PARTNER为镜像服务器
USE [master]
GO
ALTER DATABASE [DemoDB] SET PARTNER = 'TCP://192.168.2.11:5022';
GO
ALTER DATABASE [DemoDB] SET WITNESS = 'TCP://192.168.2.12:5022';
GO

--在主体执行:设置为高安全模式
ALTER DATABASE [DemoDB] SET SAFETY FULL


SQLServer 复制和数据库镜像 详细配置部署_数据库_02


EXEC [DemoDB].dbo.sp_changedbowner @loginame = N'sa', @map = false
GO
EXEC master..sp_addsrvrolemember @loginame = N'KK\UserReplMirror', @rolename = N'sysadmin'
GO




2. 配置分发服务器

登录到该服务器。

kk-db3

192.168.2.12

见证机(WITNESS)+ 分发


右键复制,配置分发。

SQLServer 复制和数据库镜像 详细配置部署_服务器_03

分发服务器选择 “kk-db3” 本地服务器。添加 “KK-DB1 ” (主机)和  “KK-DB2 ” (镜像) 为发布服务器,否则连接不到该分发服务器。

SQLServer 复制和数据库镜像 详细配置部署_服务器_04

注意:创建分发服务器时,要求数据管理密码。右键“复制”—“分发服务器属性”—“发布服务器”  可看到和设置。

SQLServer 复制和数据库镜像 详细配置部署_数据库_05


配置用于故障转移的复制代理

可配置参数 PublisherFailoverPartner 的代理:
1 - 复制快照代理(对于所有发布)
2 - 复制日志读取器代理(对于所有事务发布)
4 - 复制合并代理(对于合并订阅)
9 - 复制队列读取器代理(对于支持排队更新订阅的事务发布)


当前为可更新订阅,只要更改1,2,9 就行(分发库执行)

--@parameter_value 为镜像服务
exec sp_add_agent_parameter @profile_id = 1,
@parameter_name = N'-PublisherFailoverPartner',
@parameter_value = N'kk-db2'

exec sp_add_agent_parameter @profile_id = 2,
@parameter_name = N'-PublisherFailoverPartner',
@parameter_value = N'kk-db2'

exec sp_add_agent_parameter @profile_id = 9,
@parameter_name = N'-PublisherFailoverPartner',
@parameter_value = N'kk-db2'


接着 重启SQL Server 代理



3. 配置发布和订阅

登录到服务器

kk-db1

192.168.2.10

主机(Replication + Mirror)


创建本地发布,选择分发服务器。(只有分发中添加了发布服务器的信息,此处才能访问)

SQLServer 复制和数据库镜像 详细配置部署_服务器_06


这里需要输入在分发服务器设置的管理密码。

SQLServer 复制和数据库镜像 详细配置部署_sql_07


SQLServer 复制和数据库镜像 详细配置部署_服务器_08


注:此时在分发服务器( 192.168.2.12 )生成的复制相关作业代理,所有者改为 [sa]


登录到服务器

kk-db4

192.168.2.13

订阅


创建订阅:(发布选择 “kk-db1”)

SQLServer 复制和数据库镜像 详细配置部署_服务器_09

SQLServer 复制和数据库镜像 详细配置部署_sql_10



创建完成订阅后,初始化订阅,登录到服务器:

kk-db1

192.168.2.10

主机(Replication + Mirror)

SQLServer 复制和数据库镜像 详细配置部署_数据库_11

SQLServer 复制和数据库镜像 详细配置部署_服务器_12


登录到服务器:

kk-db3

192.168.2.12

见证机(WITNESS)+ 分发


右键 “复制”—“启动复制监视器”,右键 “添加发布服务器”,将 发布服务器 “kk-db1” 添加,即可看到复制监控情况

SQLServer 复制和数据库镜像 详细配置部署_服务器_13

SQLServer 复制和数据库镜像 详细配置部署_数据库_14


配置已完成!~


4. 测试

现在把主体(Replication + Mirror)服务停止:

SQLServer 复制和数据库镜像 详细配置部署_sql_15


停止后,到原来的镜像(kk-db2)查看,镜像变成了主体,本地发布也出现了(原来镜像是不存在的)

SQLServer 复制和数据库镜像 详细配置部署_服务器_16

但是,当我从现在的主体(kk-db2)插入数据时,数据并没有同步到订阅!~

难道是哪里配置不对??!~~


网上查找后,发现是BUG,原因是:

This problem occurs because Log Reader Agent does not copy the transactions that are marked for replication from the transaction log into the distribution database. Log Reader Agent cannot read past a specific log sequence number (LSN). This specific LSN represents the last LSN that has been hardened to the transaction log of the mirror database.


​FIX: Changes in the publisher database are not replicated to the subscribers in a transactional replication if the publisher database runs exposed in a database mirroring session in SQL Server 2005​



暂时不修复,用其他方法设置也可以:

(先启动 kk-db1 的SQLserver 服务)

在主体 和 镜像中,设置服务启动参数,添加 -T1448,重启服务即可。

SQLServer 复制和数据库镜像 详细配置部署_数据库_17


此时停止主体实例,镜像变成主体,操作数据可正常和订阅同步了!~


至此,就算完成了,个人测试,也可能有不对的地方。



2016-03-15 域中配置数据库镜像,无需见证。服务器账户为域账户启动。

--DB设置完整模式
USE master;
GO
ALTER DATABASE [MyDB] SET RECOVERY FULL
GO

--主体备份(禁止操作)
BACKUP DATABASE [MyDB] TO DISK = N'C:\MyDB.bak'
WITH NOFORMAT, NOINIT, SKIP, NOREWIND, NOUNLOAD, COMPRESSION, STATS = 10
GO

--镜像还原处于还原状态……
RESTORE DATABASE [MyDB]
FROM DISK = N'C:\MyDB.bak'
WITH FILE = 1, NORECOVERY, NOUNLOAD, REPLACE, STATS = 10
GO

--主体创建端点
USE [master]
GO
CREATE ENDPOINT [Endpoint_For_Mirror]
AUTHORIZATION [HUANG\sqlservice]
STATE=STARTED
AS
TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
FOR DATABASE_MIRRORING (ROLE = PARTNER, AUTHENTICATION = WINDOWS NEGOTIATE, ENCRYPTION = REQUIRED ALGORITHM AES)
GO
--GRANT CONNECT ON ENDPOINT::Endpoint_For_Mirror TO [HUANG\sqlservice];
--GO


--镜像创建端点
USE [master]
GO
CREATE ENDPOINT [Endpoint_For_Mirror]
AUTHORIZATION [HUANG\sqlservice]
STATE=STARTED
AS
TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)--同一个服务器不同实例,不同端口
FOR DATABASE_MIRRORING (ROLE = PARTNER, AUTHENTICATION = WINDOWS NEGOTIATE, ENCRYPTION = REQUIRED ALGORITHM AES)
GO
--GRANT CONNECT ON ENDPOINT::Endpoint_For_Mirror TO [HUANG\sqlservice];
--GO


--见证创建端点
USE [master]
GO
CREATE ENDPOINT [Endpoint_For_Mirror]
AUTHORIZATION [HUANG\sqlservice]
STATE=STARTED
AS
TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
FOR DATABASE_MIRRORING (ROLE = WITNESS, AUTHENTICATION = WINDOWS NEGOTIATE, ENCRYPTION = REQUIRED ALGORITHM AES)
GO
--GRANT CONNECT ON ENDPOINT::Endpoint_For_Mirror TO [HUANG\sqlservice];
--GO



--镜像执行,PARTNER为主服务器
USE [master]
GO
ALTER DATABASE [MyDB] SET PARTNER = 'TCP://DB.huang.com:5022';
GO

--主体执行,PARTNER为镜像服务器
USE [master]
GO
ALTER DATABASE [MyDB] SET PARTNER = 'TCP://DB02.huang.com:5022';
GO

--主体执行,设置见证服务器
USE [master]
GO
ALTER DATABASE [MyDB] SET WITNESS = 'TCP://DB01.huang.com:5022';
GO


/*
--主体备份(禁止操作)
BACKUP LOG [MyDB] TO DISK = N'C:\MyDB_LOG.bak'
WITH NOFORMAT, NOINIT, SKIP, NOREWIND, NOUNLOAD, COMPRESSION, STATS = 10
GO

--镜像还原处于还原状态……
RESTORE DATABASE [MyDB]
FROM DISK = N'C:\MyDB_LOG.bak'
WITH FILE = 1, NORECOVERY, NOUNLOAD, REPLACE, STATS = 10
GO
*/


USE [master]
GO
--主体执行:设置为高安全模式(同步)
ALTER DATABASE [MyDB] SET SAFETY FULL

--主体执行:设置为高性能模式(异步)
ALTER DATABASE [MyDB] SET SAFETY OFF

--主体执行:主体与镜像切换
ALTER DATABASE [MyDB] SET PARTNER FAILOVER;


ALTER DATABASE [MyDB] SET PARTNER RESUME; --恢复镜像
ALTER DATABASE [MyDB] SET PARTNER FAILOVER; --切换主备
ALTER DATABASE [MyDB] SET PARTNER FORCE_SERVICE_ALLOW_DATA_LOSS; --强制恢复镜像
ALTER DATABASE [MyDB] SET ONLINE; --在线数据库


select * from sys.certificates
select * from sys.endpoints
select * from sys.database_mirroring_endpoints
select * from sys.database_mirroring
select * from sys.database_mirroring_witnesses

------------------------------------------------------------------
--分发库执行:设置主体中的作业是否转移到镜像
1 - 复制快照代理(对于所有发布)
2 - 复制日志读取器代理(对于所有事务发布)
4 - 复制合并代理(对于合并订阅)
9 - 复制队列读取器代理(对于支持排队更新订阅的事务发布)

--(@parameter_value 为镜像服务 )
exec sp_add_agent_parameter @profile_id = 1,
@parameter_name = N'-PublisherFailoverPartner',
@parameter_value = N'DB02'

exec sp_add_agent_parameter @profile_id = 2,
@parameter_name = N'-PublisherFailoverPartner',
@parameter_value = N'DB02'

exec sp_add_agent_parameter @profile_id = 9,
@parameter_name = N'-PublisherFailoverPartner',
@parameter_value = N'DB02'
------------------------------------------------------------------




标签:kk,数据库,SQLServer,--,Cert,服务器,GO,镜像
From: https://blog.51cto.com/hzc2012/6024077

相关文章

  • Windows 2008 + SQLServer 2008 双机群集
    SQLserver版本要求:标准版(2个节点),企业版(16个节点)安装前,先了解相关信息:​​SQLServer2008故障转移群集入门 ​​SQLServer2008 群集是基于Windows群集:​​Windows2......
  • SqlServer 与 MySQL 基本操作语句对比
    继上篇 ​​MySQL基本操作语句​​ 后,个人测试和补充了 SqlServer与MySQL的 基本操作语句对比,主要是对比SQL命令的一些差异,不作更多说明。(由于mysql没有系统学习过......
  • SQLServer 2012 包含数据库(Contained Databases)
    “包含数据库”是独立于其他数据库以及承载数据库的SQLServer实例的一种数据库。SQLServer2012以4种方法帮助用户使其数据库独立于实例。▶很多用于描述数据库的......
  • Python 自定义数据库连接类
    创建一个配置文件:E:/mypy/mycnf.txt[mssql]host=HZCuser=kkpwd=kkdbname=DemoDB数据库连接类:E:/mypy/MSSQL.py#-*-coding:utf-8-*-#python3.5importsysimp......
  • Lepus(天兔)数据库监控系统
    更多介绍参考官网:​​http://www.lepus.cc/​​参考官方文档,以 Xampp集成安装相关软件。Xampp下载地址:​​https://www.apachefriends.org/download.html​​ 下载安装X......
  • SQL Server Powershell 开源数据库管理工具 dbatools
    在Windows中开发自动化运维,除了python就是powershell了,powershell与windows相关产品关联紧密,Windows环境下的自动化开发一般使用powershell,sqlserver亦是如此......
  • Windows 2008 双机群集配置(for SQLServer)
    此处配置Windows2008群集,将用于SQLserver2008双机故障转移群集,此处SQLserver的群集基于Windows群集实现。Windows2008集群更容易实现了,只要规划好IP和磁盘分配,可一直......
  • SQLServer 2014 内存优化表
    内存优化表是SQLServer2014的新功能,它是可以将表放在内存中,这会明显提升DML性能。关于内存优化表,更多可参考两位大侠的文章:​​SQLServer2014新特性探秘(1)-内存数据库......
  • 数据库的负载均衡
    .NET下数据库的负载均衡 相关下载:数据库的负载均衡-示例代码(dp1-DbBalance.rar)数据库的负载均衡-示例代码(dp1-DbBalance.rar)支持.Net/.NetCore/.NetFramewor......
  • JDBC连接数据库
    jdbc(javadatabasecontectivity),即java连接数据库。jdbc的核心思想.java提供数据库的接口,数据库提供驱动实现类。jdbc是由多个接口和类进行功能实现  ......