SQLServerAlwaysOn高可用性解决方案

SQLServerAlwaysOn高可用性解决方案
SQLServerAlwaysOn高可用性解决方案

SQLServerAlwaysOn 高可用性解决方案

1

2020年4月19日

Microsoft SQL Server AlwaysOn

高可用性解决方案

1.术语定义

1)高可用性:HA(High Availability)

一般来描述一个系统经过专门的设计,从而减少停工时间,而保持其服务的高度可用性

2)灾难恢复:DR(Disaster Recovery)

指自然或人为灾害后,重新启用信息系统的数据、硬件及软件设备,恢复正常商业运作的过程

3)故障转移群集:WSFC(Windows Server Failover Cluster)

微软操作系统针对服务器提供的一种服务,该服务用于防止单台服务器故障导致服务失效。

2.公司数据库使用现状及问题瓶颈

其它部门对应用开发部负责的融资管理系统性能提出以下问题:

1)数据部:

a)服务器不稳定

b)数据库性能配置低

2)市场部:

a)查询效率太低

3)产品部:

a)报表、BI支撑难

这些性能问题无不涉及到后台数据库的性能及可靠性问题。

还有一个安全问题也值得重视。当前,公司产品数据库和融资管系统都部署

在10.44.1.3一台服务器上。理论上,产品数据库不应与Web应用部署在同一台机器而暴露给用户,产品数据库最好只交由专职DBA来管理。因为,万一Web应用遭受黑客攻击,产品数据将会面临巨大威胁,甚至有可能被永久性物理删除。前不久,就有报道携程数据遭受有预谋的内部攻击被物理删除()。

如果分开部署,那么即使Web应用遭受攻击,只要产品数据在,我们依然能够在短时间内部署新的Web应用。

3.SQL Server 高可用技术简介

1)故障转移群集(Failover Cluster)

共享存储,效率高,但某一个时间点只有一个节点处于活动状态,造成硬件资源浪费。

2)数据库镜像(Database Mirror)

提供几乎是瞬时的故障转移,以提高数据库的可用性。但其最大弊端在于镜像数据库处于不可读状态,同样造成硬件资源浪费。

3)日志传送(Log Shipping)

还原作业之间的间隔时间内的只读访问权限,可用做报表查询。一般用于远程的异步容灾,存在部分数据丢失的可能性。

4)复制(Replication)

基于数据库对象级别,灵活性较高,但弊端在于,它不支持DDL命令,不便维护。

5)AlwaysOn

AlwaysOn是SQL Server 中提供的一种全新的高可用性技术,其集中了上述4种高可用性技术的优点,以确保企业无需增加成本和提高复杂度,即可实现最高

级别的可用性和数据保护。可在数据中心内部以及跨数据中心实现数据冗余,快速地实现应用程序故障转移,保护现有硬件资源,同时简化了其配置过程。AlwaysOn 能够实现服务器实例级和数据库级配置高可用性,所对应的技术就是AlwaysOn故障转移群集实例和AlwaysOn可用性组。

下图1展示了使用Alwayson可用性组的 HA 和 DR 解决方案

图1

4.AlwaysOn高可用性技术介绍

1)AlwaysOn 故障转移群集实例

一般来说,在单服务器情况下,当服务器上出现硬件或软件故障时,连接到该服务器的应用程序或客户端将会停机。在AlwaysOn故障转移群集实例环境中,SQL Server 实例的高可用性受到冗余节点的保护。在群集环境中,一次只能有一个节点拥有群集的资源组。在出现故障(硬件故障、操作系统故障、应用程序或服务故障)或进行计划的升级时,该资源组的所有权就会转移至另一个群集节点。此过程对于连接到 SQL Server 的客户端或应用程序是透明的,能够最大限度地缩短出现故障时应用程序或客户端的停机时间。因此AlwaysOn故障转移群集实例必须由一组物理服务器节点构成,这些服务器节点推荐使用类似的硬件配置以及相同的软

相关文档
最新文档