SQL Server AlwaysON从入门到进阶(6)——分析和部署AlwaysOn Availability Group
前言:
- Windows Server AD域
- DNS基础设施
- DHCP(如需)
- Windows Server Failover Cluster(WSFC)
- WSFC上的节点
为什么使用AlwaysOn可用组?
- 多网卡及TCP/IP网络用于网络冗余。
- 新的多数节点集仲裁模型 (从 Windows server 2003 SP1 开始) 移除磁盘依赖项,并增加对多站点群集的支持。
- 使用多个计算机节点以抵消核心节点硬件故障(如主板等)。
什么是AlwaysOn可用组:
- 副本数量:SQL 2012中最大5个:1主4次要副本。SQL 2014中为1主8次要共9个副本。
- 同步复制的设置:最大3个,其他副本只能使用异步模式。
- 自动故障转移数量:最多2个,并且必须为同步模式。
行版本的影响:
可读辅助副本? | 启用了快照隔离或 RCSI 级别隔离? | 主数据库 | 辅助数据库 |
---|---|---|---|
否 | 否 | 无行版本或 14 个字节的系统开销 | 无行版本或 14 个字节的系统开销 |
否 | 是 | 行版本和 14 个字节的系统开销 | 无行版本但有 14 个字节的系统开销 |
是 | 否 | 无行版本但有 14 个字节的系统开销 | 行版本和 14 个字节的系统开销 |
是 | 是 | 行版本和 14 个字节的系统开销 | 行版本和 14 个字节的系统开销 |
缺少统计信息的影响:
优点:
- 没有共享存储:每个服务器\实例都使用本地存储,并且移除了共享存储的单点故障风险。
- AlwaysOn侦听器服务用于接受集中请求到HA数据库组。
- 多个可用可用数据库取代了传统的一主一备(往往是不可读)。
- 更合理的Failover功能。
- 在副本层面挂起数据移动。
- 支持多IP子网。
- 可以把备份负载分摊到次要数据库。
部署可用组:
是否要使用列出的端点? 英文: The Endpoints tab lists at least one endpoint that uses only Windows Authentication. However, the server instance might be running under a nondomain account. To use the listed endpoint, change the corresponding SQL Server service account to a domain account. To continue using the nondomain account, alter the endpoint to use a certificate. Do you want to use the listed endpoints?
对于这种警告,通常有两种方式:
- 最合理:各节点使用同一个域账号启动SQL Server,可以使用较低权限的域用户账号。
- 权宜之计:在有些情况下,账号并非随你操作,所以你可以使用类似语句授权:
- GRANT CONNECT ON endpoint::hadr_endpoint
- TO [domain\servername$]
GRANT CONNECT ON endpoint::hadr_endpoint
TO [domain\servername$]
- CREATE ENDPOINT [Hadr_endpoint]
- STATE=STARTED
- AS TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
- FOR DATA_MIRRORING (ROLE = ALL
- , AUTHENTICATION = WINDOWS NEGOTIATE
- , ENCRYPTION = REQUIRED ALGORITHM AES)
CREATE ENDPOINT [Hadr_endpoint]
STATE=STARTED
AS TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
FOR DATA_MIRRORING (ROLE = ALL
, AUTHENTICATION = WINDOWS NEGOTIATE
, ENCRYPTION = REQUIRED ALGORITHM AES)
但是基于很多原因,还是尽量使用相同的、有足够权限的域账号进行配置。关于这部分的内容可以查阅官方文档:可用性组侦听器和服务器主体名称 (SPN)
AG1listener.Adventure-Works.com
的可用性组配置 SPN,所有实例都应被配置为在域帐户 corp/svclogin2
下运行:
- setspn -A MSSQLSvc/AG1listener.Adventure-Works.com:1433 corp/svclogin2
setspn -A MSSQLSvc/AG1listener.Adventure-Works.com:1433 corp/svclogin2
接下来是【备份首选项】,如下图:
- FULL:完整,其字面解释如下图,这个选项要求完整和日志备份,并把备份还原到每个次要副本中。
- Join Only:仅联接,已经以【NORECOVERY】模式还原数据库,这个选项直接把库加入可用组中。
- Skip initial data synchronisation:跳过初始化数据同步,这个选项可以让你在完成向导之后还原数据库和把次要副本加入AlwaysON可用性组中。
- get-clusterresource -cluster "WindowsClusterName" | where-object{$_.ResourceType -ilike "SQL Server Availability Group"} | ft
get-clusterresource -cluster "WindowsClusterName" | where-object{$_.ResourceType -ilike "SQL Server Availability Group"} | ft
注意替换上面的WindowsClusterName。
- ALTER AVAILABILITY GROUP [YourAG] FAILOVER
ALTER AVAILABILITY GROUP [YourAG] FAILOVER
配置只读路由:
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE1\INST1'
WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE1\INST1'
WITH
(SECONDARY_ROLE (
READ_ONLY_ROUTING_URL
=
N'TCP://stokecsclnode1.stokecs2.co.uk:58001'
));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE2\INST1'
WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE2\INST1'
WITH
(SECONDARY_ROLE (
READ_ONLY_ROUTING_URL
=
N'TCP://stokecsclnode2.stokecs2.co.uk:58001'
));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE3\INST1'
WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE3\INST1'
WITH
(SECONDARY_ROLE (
READ_ONLY_ROUTING_URL
=
N'TCP://stokecsclnode3.stokecs2.co.uk:58001'
));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE1' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE1' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://CLUSTERNODE1.george.com:1433'));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE2' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE2' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://CLUSTERNODE2.george.com:1433'));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE3' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE3' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://CLUSTERNODE3.george.com:1433'));
ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE1' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY)); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE1' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://CLUSTERNODE1.george.com:1433')); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE2' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY)); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE2' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://CLUSTERNODE2.george.com:1433')); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE3' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY)); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE3' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://CLUSTERNODE3.george.com:1433'));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE1\INST1'
WITH (PRIMARY_ROLE (
READ_ONLY_ROUTING_LIST
= (
'STOKECSCLNODE3\INST1', 'STOKECSCLNODE2\INST1', 'STOKECSCLNODE1\INST1'
)));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE2\INST1'
WITH (PRIMARY_ROLE (
READ_ONLY_ROUTING_LIST
= (
'STOKECSCLNODE3\INST1', 'STOKECSCLNODE1\INST1', 'STOKECSCLNODE2\INST1'
)));
ALTER AVAILABILITY GROUP
[STOKEAG_1]
MODIFY REPLICA ON
N'STOKECSCLNODE3\INST1'
WITH (PRIMARY_ROLE (
READ_ONLY_ROUTING_LIST
= (
'STOKECSCLNODE2\INST1', 'STOKECSCLNODE1\INST1', 'STOKECSCLNODE3\INST1'
)));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE1' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST = ('CLUSTERNODE3', 'CLUSTERNODE2', 'CLUSTERNODE1')));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE2' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST = ('CLUSTERNODE3', 'CLUSTERNODE1', 'CLUSTERNODE2')));
- ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
- N'CLUSTERNODE3' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST = ('CLUSTERNODE2', 'CLUSTERNODE1', 'CLUSTERNODE3')));
ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE1' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST = ('CLUSTERNODE3', 'CLUSTERNODE2', 'CLUSTERNODE1'))); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE2' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST = ('CLUSTERNODE3', 'CLUSTERNODE1', 'CLUSTERNODE2'))); ALTER AVAILABILITY GROUP GeorgeAG MODIFY REPLICA ON
N'CLUSTERNODE3' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST = ('CLUSTERNODE2', 'CLUSTERNODE1', 'CLUSTERNODE3')));
挂起数据移动:
测试故障转移场景和观察结果:
自动故障转移:
手动和强制故障转移:
在故障转移过程中群集角色资源状态:
总结:
SQL Server AlwaysON从入门到进阶(6)——分析和部署AlwaysOn Availability Group的更多相关文章
- SQL Server AlwaysON从入门到进阶(1)——何为AlwaysON?
本文属于SQL Server AlwaysON从入门到进阶系列文章 本文原文出自Stairway to AlwaysOn系列文章.根据工作需要在学习过程中顺带翻译以供参考.系列文章包含: SQL Se ...
- SQL Server AlwaysON从入门到进阶(3)——基础架构
本文属于SQL Server AlwaysON从入门到进阶系列文章 前言: 本文将更加深入地讲解WSFC所需的核心组件.由于AlwaysOn和FCI都需要基于WSFC之上,因此我们首先要了解在Wind ...
- SQL Server AlwaysON从入门到进阶(2)——存储
本文属于SQL Server AlwaysON从入门到进阶系列文章 前言: 本节讲解关于SQL Server 存储方面的内容,相对于其他小节而言这节比较短.本节会提供一些关于使用群集或者非群集系统过程 ...
- SQL Server审计功能入门:SQL Server审核 (SQL Server Audit)
原文:SQL Server审计功能入门:SQL Server审核 (SQL Server Audit) 介绍 Audit是SQL Server 2008之后才有的功能,它能告诉你"谁什么时候 ...
- SQL Server审计功能入门:更改跟踪(Change Tracking)
原文:SQL Server审计功能入门:更改跟踪(Change Tracking) 介绍 更改跟踪是一种轻量型解决方案,它为应用程序提供了一种有效的更改跟踪机制.常规的,自定义变更跟踪和读取跟踪数据, ...
- SQL Server审计功能入门:CDC(Change Data Capture)
原文:SQL Server审计功能入门:CDC(Change Data Capture) 介绍 SQL Server 2008引入了CDC(Change Data Capture),它能记录: 1. ...
- Sql Server新手学习入门
Sql Server新手学习入门 http://www.tudou.com/home/_117459337
- 对Oracle 、SQL Server、MySQL、PostgreSQL数据库优缺点分析
对Oracle .SQL Server.MySQL.PostgreSQL数据库优缺点分析 Oracle Database Oracle Database,又名Oracle RDBMS,或简称Oracl ...
- sql注入(从入门到进阶)
随着B/S模式应用开发的发展,使用这种模式编写应用程序的程序员也越来越多.但是由于这个行业的入门门槛不高,程序员的水平及经验也参差不齐,相当大一部分程序员在编写代码的时候,没有对用户输入数据的合法性进 ...
随机推荐
- sublime text3设置
我的sublime的设置,ps:这个博文只是为了我自己的一个记录 { "color_scheme": "Packages/Theme - Solarized Flat/S ...
- POJ-3069
Saruman's Army Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10994 Accepted: 5555 D ...
- python3.5 jira网站实现用户的批量插入
工作中,经常要给多个用户创建账号,为了减少工作量,写了个自动化脚本来帮助我批量创建用户 代码如下: """自动创建Jira的学生账号""" ...
- 如何让IntPtr指向一块内存,以及托管内存与非托管内存的相互转化
IntPtr idp= IntPtr.Zero; StringBuilder idata = new StringBuilder("000000"); string idata = ...
- ZOJ 1586 QS Network Kruskal求最小生成树
QS Network Sunny Cup 2003 - Preliminary Round April 20th, 12:00 - 17:00 Problem E: QS Network In the ...
- 数据库路由中间件MyCat - 源代码篇(9)
此文已由作者张镐薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 3. 连接模块 3.5 后端连接 3.5.1 后端连接获取与负载均衡 上一节我们讲了后端连接的基本建立和响应 ...
- lightoj1010【规律】
思路: 根据案例的规律其实已经猜的差不多了,answer=n*m/2; 有一条边是1的情况,也很好判断,answer=n*m; 就是有一条边是2的时候比较隐秘:是连续2*2一块可以填,然后2*2不填, ...
- zoj2901【DP·二进制优化】
题意: 要排一个L长度的序列,当 j 放在 i 后面的时候会增加v[ i ][ j ]的值,求构成L长度序列的最大值. 思路: 可以想到预处理任意两点<i,j>的最大值是多少,然后题目还有 ...
- ue4 代码入门
官网:暴露游戏元素给蓝图 https://docs.unrealengine.com/latest/CHN/Engine/Blueprints/TechnicalGuide/ExtendingBlue ...
- 十、正则表达式和JSON
一.什么是正则表达式 正则表达式是一个特殊字符序列,一个字符串是否与我们所设定的这样的字符序列相匹配. 应用:快速检索文本.实现一些替换文本的操作 1.检查一串数字是否是电话号码 2.检查一个字符串是 ...