搭建 WSFC

配置计算机的 DNS 后缀

1、配置计算机的 DNS 后缀,注意在同个工作组

2、每个节点的机器都要做域名解析,修改 host 文件C:WindowsSystem32driversetc


安装故障转移集群

1、节点服务器添加故障转移群集功能

2、等待安装完成


验证集群

1、打开故障转移集群管理工具

2、点击验证配置

3、添加集群节点

4、运行所有测试

5、可以点击查看验证报告,勾选立即使用经过验证的节点创建集群


创建集群

1、配置集群的管理名称和管理IP

2、等待配置完成

3、可以查看集群报告,稍后配置文件共享见证


创建文件共享见证

由于我们是两个节点的故障转移集群,所以需要加上共享文件夹,如果是奇数节点,这一步是不需要做的!

1、配置集群仲裁

2、选择文件共享见证

3、在集群节点之外的一台服务器上创建共享文件夹XIANGMU4TEST01share,并设置 Everyone 完全控制的权限


配置 AlwaysOn

1、开启 AlwaysOn

2、需要重启 SQL Server 服务

3、检查,如果 AlwaysOn 启用成功,在服务器属性里可以看到启用HADR为True

4、查看各节点的投票数

SELECT * FROM sys.dm_hadr_cluster_members;

查看 cluster

SELECT * FROM SYS.[dm_hadr_cluster]

新建可用性组

但是既然节点没有加入AD,那么久不能用域认证,只能用证书认证,因此需要创建证书和端点。在配置可用性组前各节点进行证书认证信任。

1、修改 SQL 服务登陆账号为本机管理员账号

2、创建证书,两个节点都要创建证书,注意修改证书名称

--节点二:创建主密钥/证书,备份证书。USE master;GOCREATE MASTER KEY ENCRYPTION BY PASSWORD = 'AAA111aaa';GOCREATE CERTIFICATE Cert_server228WITH SUBJECT = 'Cert_server228',START_DATE = '2017-01-01',EXPIRY_DATE = '2099-12-30';GOBACKUP CERTIFICATE Cert_server228TO FILE = 'C:StorageCert_server228.cer';GO

注意:备份证书的文件夹要先创建好,并且赋予权限

将创建好的证书放到另一台节点服务器,并加入证书

--节点二:创建其他节点证书USE master;GOCREATE CERTIFICATE Cert_server227FROM FILE = 'C:StorageCert_server227.cer';GO

证书创建好后如下

重新创建端点,授权账号设置为本机管理员账号,验证方式使用上面创建的证书

--节点:创建端点CREATE ENDPOINT [testag_endpoint] AUTHORIZATION [POSTEST2-2016Administrator] STATE=STARTED AS TCP (LISTENER_PORT = 5023, LISTENER_IP = ALL) FOR DATA_MIRRORING (ROLE = ALL,AUTHENTICATION = CERTIFICATE Cert_server228, ENCRYPTION = REQUIRED ALGORITHM AES)GO

如果存在已有的端点,则需要将已有端点删除

在主节点服务器操作新建可用性组。

设置可用性组名称,建议勾选数据库级别运行状况检测。

  • 在之前的 AlwaysOn 2012 和 2014 中,如果实例健康出现问题,将触发故障转移。如果有一个数据库有问题,只要实例OK,可用性组就不会故障转移。
  • 在 AlwaysOn 2016 中,勾选之后,不论是一个实例有问题,还是一个或多个数据库有问题,都会发生故障转移。

选择数据库,要求数据库已经进行了完整备份

添加副本节点,并勾选自动故障转移,设置辅助副本为可读副本

将端点 URL 设置为 IP 方式,这里端点会显示为我们上面创建的端点,登陆账号为我们上面设置的账号

“备份首选项”和“侦听器”不需要设置,保持默认就行,可用性侦听器我们后面再添加,可以直接点击“下一步”

数据同步这里建议使用完整的数据库和日志备份的方式更方便,需要有一个共享文件夹,并且节点服务器要有相同的数据库文件目录结构

等待可用性组创建成功

创建成功后数据库状态显示为已同步

故障转移集群会显示拥有一个群集角色

显示面板可以查看集群信息


创建侦听器

一个侦听器包括虚拟IP地址、虚拟网络名称、端口号三个元素,一旦创建成功,虚拟网络名称会注册到DNS中,同时为可用性组资源添加IP地址资源和网络名称资源。用户就可以使用此名称来连接到可用性组中。

1、添加侦听器

2、选择使用静态 IP

3、创建成功后,在故障转移集群管理器里的角色节点,可以看到客户端访问名称和 IP 地址

4、连接数据库时使用侦听器的地址


可读副本的负载均衡

SQL Server 2016 支持多个只读副本负载分担只读操作。

右键一个可用性副本可以查看副本的只读性设置:

主角色中的连接

主角色中支持的连接访问类型:

  • 允许所有连接(ALL):主数据库同时允许读写连接和只读连接。这是主角色的默认行为。
  • 仅允许读/写连接(READ_WRITE):允许 ApplicationIntent=ReadWrite 或未设置连接条件的连接。不允许 ApplicationIntent=ReadOnly 的连接。仅允许读写连接可帮助防止客户错误地将读意向工作负荷连接到主副本。

修改脚本:

USE [master]GOALTER AVAILABILITY GROUP [posTestAg]MODIFY REPLICA ON N'POSTEST1-2016POSTEST' WITH (PRIMARY_ROLE(ALLOW_CONNECTIONS = READ_WRITE))GO

可读辅助副本

辅助角色支持的连接访问类型:

  • 无连接(NO):不允许任何用户连接。辅助数据库不可用于读访问。这是辅助角色中的默认行为。
  • 仅读意向连接(READ_ONLY):辅助数据库仅接受连接参数 ApplicationIntent=ReadOnly 的连接,其它的连接方式无法连接。
  • 允许任何只读连接(ALL):辅助数据库全部可用于读访问连接。此选项允许较低版本的客户端进行连接。

修改脚本:

USE [master]GOALTER AVAILABILITY GROUP [posTestAg]MODIFY REPLICA ON N'POSTEST1-2016POSTEST' WITH (SECONDARY_ROLE(ALLOW_CONNECTIONS = READ_ONLY))GO

设置数据库实例监听端口

1、Sql Server 配置管理工具找到数据库实例的网络配置,

2、右键 TCP/IP,默认配置的是动态端口

3、这里修改为固定端口 1433

4、最后需要重启 Sql Server 服务。

配置可用性组只读路由

执行下面 sql 获取可用性组名称:

select name,* from sys.availability_groups

执行下面 sql 获取要配置的可用性副本名称(服务器实例):

select replica_server_name,* from sys.availability_replicas
  1. 为可用性副本(服务器实例)配置只读路由 URL,路由地址可以填 IP 或者计算机名,端口填数据库实例绑定的 TCP/IP 端口。
  2. 执行脚本:
USE [master]GOALTER AVAILABILITY GROUP [posTestAg]MODIFY REPLICA ON N'POSTEST1-2016POSTEST' WITH (SECONDARY_ROLE(READ_ONLY_ROUTING_URL = N'TCP://10.98.98.227:1433'))GOALTER AVAILABILITY GROUP [posTestAg]MODIFY REPLICA ON N'POSTEST2-2016POSTEST' WITH (SECONDARY_ROLE(READ_ONLY_ROUTING_URL = N'TCP://10.98.98.228:1433'))GO

也可以右键可用性组选择属性,通过 UI 方式更改

  1. 每个自动转移副本配置只读路由列表
USE [master]GOALTER AVAILABILITY GROUP [posTestAg]MODIFY REPLICA ONN'POSTEST1-2016POSTEST' WITH(PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=(('POSTEST2-2016POSTEST'),'POSTEST1-2016POSTEST')));GOALTER AVAILABILITY GROUP [posTestAg]MODIFY REPLICA ONN'POSTEST2-2016POSTEST' WITH(PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=(('POSTEST1-2016POSTEST'),'POSTEST2-2016POSTEST')));GO

使用“()”对只读路由列表进行分组,

List 1: 'POSTEST1-2016POSTEST'

List 2: 'POSTEST2-2016POSTEST'

按如下方式工作:

  1. 路由到第一个列表中的副本,如果第一个列表存在多个副本,则对读取连接进行轮询分发。
  2. 如果第一列表中任一副本不可用了,路由将继续到第一个列表中的其他可用副本。
  3. 如果第一个列表中的所有副本都不可访问,将会路由到下一个列表
  4. 如果第一个列表中的任一副本可用,将会恢复路由到第一个列表
  5. 测试只读路由效果,sqlcmd 使用 Readonly 指定为只读连接,
sqlcmd -S 10.98.98.231 -K Readonly -d test -Q "select @@servername" -e

只读连接被连接到辅助副本

使用 SSMS 或者 EF 等需要在连接字符串设置参数ApplicationIntent=ReadOnly

注意:

想要使用辅助副本负载读操作,必须要在连接字符串中配置为只读连接,然后在程序中指定使用只读连接进行数据库读取操作,AlwaysOn 自身不能自动负载均衡。


配置账号

为每个数据库节点配置登陆账号,然后通过监听器使用该账号登陆数据库。

  1. 主副本创建登陆账号 satest
  2. 查看主库上该账号的 sid 为库名
SELECT * FROM [test]..sysusers
  1. 在副本数据库上创建对应账号,其中 sid对应的值是主库上所查到的sid的值
CREATE LOGIN [satest] WITH PASSWORD=N'xxxxxxx',SID =0x99AD266AFD26F841B3E49EF9633B0D4B, DEFAULT_DATABASE=[test], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF

使用故障转移

建议使用 SSMS 中 AlwaysOn 进行手动故障转移。


后面会分享更多devops和运维方面的内容,感兴趣的朋友可以关注一下~

sqlserver故障转移集群和alwayson的区别_详解SQL Server 2016 + AlwaysOn 无域集群相关推荐

  1. SQL Server 2016 AlwaysOn 安装及配置介绍

    SQL Server 2016  AlwaysOn 安装及配置介绍 Always On 可用性组功能是一个提供替代数据库镜像的企业级方案的高可用性和灾难恢复解决方案. SQL Server 2012 ...

  2. SQL SERVER 2016 AlwaysOn 无域集群+负载均衡搭建与简测

    之前和很多群友聊天发现对2016的无域和负载均衡满心期待,毕竟可以简单搭建而且可以不适用第三方负载均衡器,SQL自己可以负载了.windows2016已经可以下载使用了,那么这回终于可以揭开令人憧憬向 ...

  3. SQL SERVER 2016 AlwaysOn搭建实例

    安装要求 https://docs.microsoft.com/zh-cn/sql/database-engine/availability-groups/windows/prereqs-restri ...

  4. SQL Server 2016 AlwaysOn搭建

    AlwaysOn可用性组信息 角色 节点 节点类型 同步方式 支持故障转移类型 Availability Group Primay Replica SQLC01 SQL Cluster Synchro ...

  5. list对oracle结果集排序了_详解SQL窗口函数和分组排序函数

    Mysql从8.0版本开始,也和Sql Server.Oracle一样支持在查询中使用窗口函数,本文将根据官方文档,通过实例介绍窗口函数并举例分组排序函数的使用. 英语好的大佬请移步官方文档~点我! ...

  6. Debezium系列之:使用Debezium接入SQL Server数据库数据到Kafka集群的详细技术文档

    Debezium系列之:使用Debezium接入SQL Server数据库数据到Kafka集群的详细技术文档 一.Debezium概述 二.SQL Server 连接器的工作原理 1.Snapshot ...

  7. 配置SQL Server 2016无域AlwaysOn

    Windows Server 2016 以及 SQL Server 2016出来已有一段时间了,因为Windows Server 2016可以配置无域的Windows群集,因此也能够以此来配置无域的S ...

  8. 在windows 2008 server core 上搭建sql server 2012 alwayson group

    前言 自 SQL 2005以来,MSFT在SQL server的每个版本都增加了不少令人兴奋的闪亮点,SQL Server 2012也不例外,其中SQL 2012  Alwayson group就是其 ...

  9. SQL Server 安装好后 Always On群组配置

    需要对SQL Server必要的端口打开Windows防火墙的入站规则,比如TCP- 1433端口等. 特别注意:由于AG默认需要用到TCP-5022端口,所以该端口务必保证在Windows防火墙中开 ...

最新文章

  1. 【进阶版九宫格背景图片】如何仅仅依靠background的几个属性组合搭配出酷炫的背景图片效果,并自适应任何宽高效果?
  2. Java学习总结:6
  3. charles都踩过哪些坑_那些年我学Java踩过的坑
  4. python梦幻西游4小人_梦幻西游大漠插件过鼠标漂移和四小人
  5. 算法导论——lec 10 图的基本算法及应用
  6. PAT1052---------初步了解正则表达式
  7. Java 技术篇 - 启动web服务接收浏览器请求并响应实例演示,解决socket响应浏览器显示中文乱码问题,web服务response响应设置浏览器显示字体方法
  8. spring mybatis 整合jar 包冲突问题
  9. 区块链面试过程中的40个问题
  10. 如何黑掉一台根本不联网的电脑
  11. Pathlib获取当前文件绝对路径
  12. boost::python::to_python_converter相关的测试程序
  13. python中[-1]、[-1]、[-1]、[n-1]使用方法
  14. 解决 VUE: 本地运行和服务器上运行样式不一致,run、build 运行时样式有出入
  15. python新手入门总结_写给已有编程经验的 Python 初学者的总结
  16. 传智php入学测试题,传智播客PHP 0912 基础班 入学测试题
  17. 程序员面试金典——11.2变位词排序
  18. C# 实体类的get与set
  19. Python自学教程3-英语不好,变量怎么命名
  20. 显著性检测(一)Saliency Detection: A Spectral Residual Approach

热门文章

  1. 【NOI2001】【SSL1384】 【TOI 1023】【POJ 1185】炮兵阵地
  2. Win7关闭防火墙的脚本
  3. java实现大乐透彩票
  4. matlab 动态存储图片,利用matlab创建动态图并保存为AVI格式
  5. Kvaser Memorator Professional五通道CAN/CANFD总线分析记录仪
  6. 计算机学院篮球队介绍,计算机学院研究生代表队获得篮球联赛冠军
  7. H5浪漫告白气球表白
  8. 12.20-12.21北大医药
  9. Proxy SwitchyOmega
  10. 10/9 看的何向南老师团队关于bias和debias最新综述;还可以吧