SQL Server数据库镜像基于可用性组故障转移

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:

微软从SQL Server 2005开始引入数据库镜像,很快成为一个流行的故障转移解决方案。数据库镜像的一个大的问题是故障转移是基于数据库级别的,因此,如果某个数据库故障,镜像只会针对这个数据库切换,但是,其他数据库都仍然在主服务器上。缺点是越来越多的应用程序是基于多个数据库来构建,所以,如果某一个数据库故障转移而其他数据库仍然在主服务器上,那应用程序将无法工作。当这种情况发生的时候,我如何知晓?并执行该应用程序调用的所有数据库一起故障转移呢?

 

在SQL Server的所有功能中,有一种方式可以在数据库镜像故障发生时得到告警或者检查发生的事件。用于数据库镜像的事件提醒并不如你想象的那样直接,但它可以实现该功能。

 

对于数据库镜像,你可以选择使用跟踪事件,或者配置SQL Server告警来检查对于数据库镜像状态的改变的WMI(Windows Management Instrumentation)事件。

 

在开始之前,我们需要一些准备工作:

 

镜像数据库和msdb数据库必需启用service broker。可以使用如下查询来检查:

1
2
SELECT  name , is_broker_enabled
FROM  sys.databases

 

如果service broker的值不为1,你可以对每个数据库使用以下命令开启。

1
ALTER  DATABASE  msdb  SET  ENABLE_BROKER

 

如果SQL Server代理正在运行,那么这个命令将不会完成。你需要先停止SQL Server代理,运行以上命令,然后再次启动SQL Server代理。

 

最后,如果SQL Server代理没有运行,你需要启动它。

 

创建告警

 

首先,我们来创建告警,与其他告警不同的是,我们会选择”WMI event alert“类型。

 

使用SSMS连接到实例,展开SQL Server Agent,在Alerts上点击右键,选择“New Alert“。

clip_image001

 

弹出”New Alert“界面,选择“WMI event alert”。需要注意一下查询的Namespace。默认,SQL Server会根据你操作的实例选择正确的名称空间。

clip_image003

 

对于Query,使用以下查询:

1
SELECT  FROM  DATABASE_MIRRORING_STATE_CHANGE  WHERE  State = 7  OR  State = 8

 

该数据从WMI获取,当数据库镜像状态变为7(手动故障转移)或8(自动故障转移)时,将会触发作业或者提醒。

 

此外,你可以进一步对于每一个特定的数据库定义查询:

1
SELECT  FROM  DATABASE_MIRRORING_STATE_CHANGE  WHERE  State = 8  AND  DatabaseName =  'Test'

 

可以阅读下联机帮助中DATABASE_MIRRORING_STATE_CHANGE的内容。

以下是可以被监控到的不同状态改变的列表。更多内容,可以从Database Mirroring State Change Event Class里找到。

  • 0 = Null Notification

  • 1 = Synchronized Principal with Witness

  • 2 = Synchronized Principal without Witness

  • 3 = Synchronized Mirror with Witness

  • 4 = Synchronized Mirror without Witness

  • 5 = Connection with Principal Lost

  • 6 = Connection with Mirror Lost

  • 7 = Manual Failover

  • 8 = Automatic Failover

  • 9 = Mirroring Suspended

  • 10 = No Quorum

  • 11 = Synchronizing Mirror

  • 12 = Principal Running Exposed

  • 13 = Synchronizing Principal

 

在Response界面,可以配置当事件发生时如何处理。你可以配置当告警触发时执行一个作业,或者给操作者发送一个提醒。

clip_image005

 

最后,如下所示可以配置额外的选项。

clip_image007

 

配置示例

 

例如,一个应用程序有调用3个数据库(Customer、Orders和Log),如果其中一个数据库自动切换,你也想要两外两个数据库也一起故障转移。此外,这个镜像配置了一个见证服务器,如果发生故障,会自动故障转移。

 

以下展示了如何配置。

 

首先,我们只针对这3个数据库配置告警。

clip_image009

 

然后配置告警触发后运行哪个作业。

clip_image011

 

我们需要创建“Failover Databases”作业,用于当告警触发的时候运行。

 

对于SQL Server代理的“Failover Databases”作业,作业步骤如下:

1
2
3
4
5
6
7
8
9
IF EXISTS ( SELECT  FROM  sys.database_mirroring  WHERE  db_name(database_id) = N 'Customer'  AND  mirroring_role_desc =  'PRINCIPAL' )
ALTER  DATABASE  Customer  SET  PARTNER FAILOVER
GO
IF EXISTS ( SELECT  FROM  sys.database_mirroring  WHERE  db_name(database_id) = N 'Orders'  AND  mirroring_role_desc =  'PRINCIPAL' )
ALTER  DATABASE  Orders  SET  PARTNER FAILOVER
GO
IF EXISTS ( SELECT  FROM  sys.database_mirroring  WHERE  db_name(database_id) = N 'Log'  AND  mirroring_role_desc =  'PRINCIPAL' )
ALTER  DATABASE  Log  SET  PARTNER FAILOVER
GO

 

以上的ALTER DATABASE命令对其他没有自动转移的数据库强制故障转移。这跟你再GUI界面上点击“Failover”是一样的。


参考:

https://msdn.microsoft.com/en-us/library/ms191502.aspx

https://msdn.microsoft.com/en-us/library/ms186449.aspx


















本文转自UltraSQL51CTO博客,原文链接:http://blog.51cto.com/ultrasql/1906335 ,如需转载请自行联系原作者



相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
12天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
51 10
|
12天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
76 6
|
1天前
|
SQL Oracle 关系型数据库
sql语句创建数据库
在创建数据库之前,请确保你有足够的权限,并且已经考虑了数据库的安全性和性能需求。此外,不同的DBMS可能有特定的最佳实践和配置要求,因此建议查阅相关DBMS的官方文档以获取更详细和准确的信息。
|
1天前
|
SQL 缓存 数据库
sql 数据库优化
SQL数据库优化是一个复杂且关键的过程,涉及多个层面的技术和策略。以下是一些主要的优化建议: 查询语句优化: 避免全表扫描:在查询时,尽量使用索引来减少全表扫描,提高查询速度。 使用合适的子查询方式:子查询可能降低查询效率,但可以通过优化子查询的结构或使用连接(JOIN)替代子查询来提高性能。 简化查询语句:避免不必要的复杂查询,尽量使SQL语句简单明了。 使用EXISTS替代IN:在查询数据是否存在时,使用EXISTS通常比IN更快。 索引优化: 建立合适的索引:对于经常查询的列,如主键和外键,应创建相应的索引。同时,考虑使用覆盖索引来进一步提高性能。 避免过多的索引:虽然索引可以提高查询
|
8天前
|
SQL 安全 网络安全
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
19 0
|
9天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
9天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
33 3
|
12天前
|
SQL 监控 数据库
数据库管理与电脑监控软件:SQL代码优化与实践
本文探讨了如何优化数据库管理和使用电脑监控软件以提升效率。通过SQL代码优化,如使用索引和调整查询语句,能有效提高数据库性能。同时,合理设计数据库结构,如数据表划分和规范化,也能增强管理效率。此外,利用Python脚本自动化收集系统性能数据,并实时提交至网站,可实现对电脑监控的实时性和有效性。这些方法能提升信息系统稳定性和可靠性,满足用户需求。
42 0
|
12天前
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
|
4天前
|
关系型数据库 MySQL 分布式数据库
《MySQL 简易速速上手小册》第6章:MySQL 复制和分布式数据库(2024 最新版)
《MySQL 简易速速上手小册》第6章:MySQL 复制和分布式数据库(2024 最新版)
34 2

热门文章

最新文章