SQLSERVER2016 无域控AlwaysOn 实施步骤
SQLSERVER2016 无域控AlwaysOn 实施步骤
步骤:
一、安装3个windows server 2016系统
1)在3台机器建立具有administrators权限的相同账号密码,本例子直接使用administrator;
2)分别修改计算机名称为 sqldb1,sqldb2,sqldb3;
3)配置dns,如testag.com;
4)在3台服务器上做好hosts映射,如:
192.168.40.128 sqldb1
192.168.40.128 sqldb1.testag.com
192.168.40.129 sqldb2
192.168.40.129 sqldb2.testag.com
192.168.40.130 sqldb3
192.168.40.130 sqldb3.testag.com
192.168.40.100 testcluster
192.168.40.100 testcluster.testag.com
192.168.40.200 sqllistner
192.168.40.200 sqllistner.testag.com
二、配置故障转移群集
1)在3台机器上分别安装故障转移群集;
2)建立故障转移群集 testcluster.testag.com;
三、每台机器单独安装SQLSERVER 2016
1)在3台机器上分别安装SQLSERVER2016,独立安装,非群集安装;
2)给3台服务器的SQLSERVER配置相同的启动账号;
3)配置证书;
四、配置Alwayson
1)在另外2台辅助副本机器上恢复要加入alwayson的数据库;
2)用SSMS的GUI创建alwayson;注:我使用的SSMS按本会丢失两个关键语句,导致创建失败,https://www.cnblogs.com/double-K/p/5994166.html 该博有说明,这两个语句是:
------------这部分代码是图形化工具中缺失的步骤
:Connect sqldb2
ALTER AVAILABILITY GROUP [sqldbag] JOIN;
Go
ALTER DATABASE [testdb2] SET HADR AVAILABILITY GROUP = [sqldbag];
GO
:Connect sqldb3
ALTER AVAILABILITY GROUP [sqldbag] JOIN;
GO
ALTER DATABASE [testdb2] SET HADR AVAILABILITY GROUP = [sqldbag];
GO
3)创建侦听器 sqllistner,做好hosts映射;
4)创建只读路由,让alwayson支持读写分离;
ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb1' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY)); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb1' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'tcp://sqldb1.testag.com:1433')); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb2' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY)); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb2' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'tcp://sqldb2.testag.com:1433')); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb3' WITH (SECONDARY_ROLE (ALLOW_CONNECTIONS = READ_ONLY)); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb3' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'tcp://sqldb3.testag.com:1433')); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb1' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=('sqldb2','sqldb3','sqldb1'))); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb2' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=('sqldb3','sqldb1','sqldb2'))); ALTER AVAILABILITY GROUP sqldbag
MODIFY REPLICA ON N'sqldb3' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=('sqldb2','sqldb1','sqldb3')));
ssms要让只读路由生效,必须具备两点:
1)连接到制定数据库,而不是默认;

2)增加连接参数 ApplicationIntent=ReadOnly

参考文档:
https://www.cnblogs.com/double-K/p/5994166.html
http://www.cnblogs.com/lyhabc/p/6498712.html
----------------------------------
注意问题和事项:
1)所有sqlserver服务器创建相同密码的administrators权限的windows账号,用作sqlserver的启动账号,避免权限问题;
2)本人使用的ssms2016版本创建alwayson丢失语句,导致创建alwayson失败;
3)无域控,需要对所有资源做hosts映射,包含
sqldb1, sqldb2, sqldb3, sqldb1.testag.com, sqldb2.testag.com, sqldb3.testag.com,
群集服务器 testcluster.testag.com,
侦听器 sqllistner, sqllistner.testag.com
4)忘记创建只读路由,通过侦听器无法连接到只读副本;
5)当alwayson的辅助副本中的 可读辅助副本 设置为 仅读意向 时,ssms无法打开数据库,需要配置 ApplicationIntent=ReadOnly 连接参数才可打开

SQLSERVER2016 无域控AlwaysOn 实施步骤的更多相关文章
- 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)
从0开始搭建SQL Server AlwaysOn 第一篇(配置域控) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www.cnb ...
- (转)从0开始搭建SQL Server AlwaysOn 第一篇(配置域控+域用户DCADMIN)
原文地址: http://www.cnblogs.com/lyhabc/p/4678330.html 实验环境: 准备工作 软件准备 (1) SQL Server 2012 (2) Windows S ...
- 服务器搭建域控与SQL Server的AlwaysOn环境过程(四)配置AlwaysOn
0 引言 这一篇才真正开始搭建AlwaysOn,前三篇是为搭建AlwaysOn 做准备的. 步骤 1.3 配置AlwaysOn 请先使用本地用户Administrator登录这两个集群节点并执行下面的 ...
- (转载) 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)
安装完之后别忘了还需要安装SSMS,这是坑爹的地方之二,干嘛不集成到SQL Server安装包里还要用户自己单独下载 下载地址:https://msdn.microsoft.com/en-us/lib ...
- SQL SERVER 2016 AlwaysOn 无域集群+负载均衡搭建与简测
之前和很多群友聊天发现对2016的无域和负载均衡满心期待,毕竟可以简单搭建而且可以不适用第三方负载均衡器,SQL自己可以负载了.windows2016已经可以下载使用了,那么这回终于可以揭开令人憧憬向 ...
- 服务器搭建域控与SQL Server的AlwaysOn环境过程(三)配置故障转移
0 引言 主要讲述如何搭建故障转移集群,因为AlwaysOn是基于Windows的故障转移集群的. 在讲解步骤之前需要了解一下故障转移集群仲裁配置 下面图片来自<Windows Server20 ...
- sql server 2016 AlwaysOn实现无域高可用全教程
一.简介环境:小编使用的服务器是windows server 2016(系统服务器) + sql server 2016(数据库服务器)(windows server 2016 + sql serve ...
- 配置SQL Server 2016无域AlwaysOn(转)
Windows Server 2016 以及 SQL Server 2016出来已有一段时间了,因为Windows Server 2016可以配置无域的Windows群集,因此也能够以此来配置无域的S ...
- 服务器搭建域控与SQL Server的AlwaysOn环境过程(一) 搭建域控服务器
0 准备阶段 1. Windows Server 服务器 3台(其中域控服务器配置可降低一个水准,目前博主试用的是:域控服务器--2核4G 数据库服务器(节点)--4核8G ) 2. SQL Serv ...
随机推荐
- 【BZOJ】1061: [Noi2008]志愿者招募(费用流+数学)
http://www.lydsy.com/JudgeOnline/problem.php?id=1061 好神的一题! 学会了一种建模方式: 当方程组内的任意变量都在其中两个方程出现且一正一负,可以建 ...
- 目标检测YOLO算法-学习笔记
算法发展及对比: 17年底,mask-R CNN YOLO YOLO最大的优势就是快 原论文中流程,可以检测出20类物体. 红色网格-张量,在这样一个1×30的张量中保存的数据 横纵坐标中心点缩放到0 ...
- Dynamics CRM 2015 Update 1 系列(3): API的那些事 - Old APIs VS New APIs
今天我们来看看API的变化.新系统中,去掉了一些经常使用的数据处理API,比如:SetStateRequest, SetBusinessUnitRequest, SetParentBusinessUn ...
- open() 函数以 w+ 模式打开文件
这种模式打开文件时,会先清空文件,然后才执行读写操作,当我们要执行读操作时,需要通过 seek() 方法将读取指针移到前面,才能读取内容 [root@localhost ~]$ cat 1.txt # ...
- Android无线测试之—UiAutomator UiScrollable API介绍五
滑动区域校准常量设置与获取 一.校准概念 校准常量指的是:滑动操作坐标时的偏移量,用来取偏移比例 二.相关API 返回值 API 描述 double getSwipeDeadZonePercentag ...
- Zabbix-3.0.0 安装Graphtree
导读 Zabbix中,想要集中展示图像,唯一的选择是screen,后来zatree解决了screen的问题,但性能不够好.Graphtree 由OneOaaS开发并开源出来,用来解决Zabbix的图形 ...
- Linux删除oracle数据库
手动的删除ORACLE数据库. 本人的做法: su - root lsnrctl stop kill -9 `ps -ef |grep oracle |grep -v grep |awk '{prin ...
- 【BZOJ3442】学习小组 费用流
[BZOJ3442]学习小组 Description [背景] 坑校准备鼓励学生参加学习小组. [描述] 共有n个学生,m个学习小组,每个学生有一定的喜好,只愿意参加其中的一些学习小组,但是校领导为学 ...
- [LintCode] 寻找缺失的数
class Solution { public: /** * @param nums: a vector of integers * @return: an integer */ int findMi ...
- dede标签:arclist标签使用大全
特别提示:arclist是织梦建站系统中最重要的标签,同时也是最基础的标签,希望大家熟练掌握,可以说是学习织梦必备知识. 标签名称:arclist标记简介:织梦常用标记,也称为自由列表标记,其中img ...