SQL Server 2016 AlwaysON 非域部署脚本

注:搭了2次,所以代码中IP可能不一致,请自行替换下即可

    大致步骤以 --1  --2 标出,跳跃下看,因为是从主、副SSMS里复制的

    参考了宋云剑翻译的SQL SERVER 2012/14管理,ITPUB上jieyancai的贴子


1.所有成员都必须是Win Svr 2016

2.所有成员创建相同的帐号、密码,且属于本地Administrators组
3.所有SVR POWERSHELL:new-itemproperty -path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System -Name LocalAccountTokenFilterPolicy -Value 1
  重启
4.所有成员设置DNS后缀 noad.com
5.服务器都有一个共同的DNS服务器地址进行注册(或者自己添加A记录),包含DNS后缀。如果没有共同的DNS服务器进行注册,那就在每台写上host记录
6.检查防火墙响应的协议是否打开
7.安装群集角色
7.New-Cluster –Name <Cluster Name> -Node <Nodes to Cluster> -–StaticAddress <Cluster IP> -AdministrativeAccessPoint DNS
  示例:New-Cluster –Name NOADCluster -Node Node1,Node2 -NoStorage -StaticAddress 192.168.112.130 -AdministrativeAccessPoint DNS


仲裁配置:
  见证类型部队与工作组群集和多域群集建议采用云见证或磁盘见证。不支持文件共享见证。
群集验证中以下信息可以忽略:
  群集配置-验证资源状况
  系统配置-验证AD配置
建议在群集中的每一个节点都采用相同的配置,例如相同的补丁,相同的策略等。
确保群集所有节点的信息可以在权威DNS服务器上得到解析。
在工作组群集中是不支持Get-ClusterDiagnostics命令进行群集诊断的。
这时打开故障转移群集控制台可以看见创建的工作组群集。


hosts:


N1: 192.168.112.140  N1.noad.com
N2: 192.168.112.141  N2.noad.com
打开网络发现


Storage: 192.168.112.135
N1: 192.168.112.136  169.254.192.168

N2: 192.168.112.137  169.254.77.185



建群集、开防火墙
--1.
Create Database DB1
ON PRIMARY (Name='DB1',FileName='C:\Data\DB1.mdf',Size=100MB,FileGrowth=10MB)
LOG ON (Name='DB1_Log',FileName='C:\Data\DB1_Log.ldf',Size=100MB,FileGrowth=10MB);
Create Database DB2
ON PRIMARY (Name='DB2',FileName='C:\Data\DB2.mdf',Size=100MB,FileGrowth=10MB)
LOG ON (Name='DB2_Log',FileName='C:\Data\DB2_Log.ldf',Size=100MB,FileGrowth=10MB);
GO
Alter Database DB1 SET RECOVERY FULL;
Alter Database DB2 SET RECOVERY FULL;


GO
Use Master
Go
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'dba123!@#'
Go
CREATE CERTIFICATE CertA WITH SUBJECT = 'Cert A'
Go
CREATE ENDPOINT Endpoint_Mirroring
 STATE = STARTED
   AS TCP (LISTENER_PORT=7022,LISTENER_IP = ALL) 
   FOR DATABASE_MIRRORING 
   (AUTHENTICATION = CERTIFICATE CertA,
    ENCRYPTION = REQUIRED ALGORITHM AES,
    ROLE = ALL);
Go
BACKUP CERTIFICATE CertA TO FILE = '\\N2\Setup\CertA.cer';
--Copy CertA.cer 到备用机
GO


--3.
CREATE LOGIN LoginB WITH PASSWORD = 'dba123!@#';
Go
CREATE USER UserB FOR LOGIN LoginB
Go
CREATE CERTIFICATE CertB AUTHORIZATION UserB FROM FILE='\\N2\Setup\CertB.cer'
Go
GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [LoginB];
---------
Go
ALTER DATABASE DB1 SET TRUSTWORTHY ON;
ALTER DATABASE DB2 SET TRUSTWORTHY ON;


Go
--5.
Backup Database DB1 TO Disk='\\N2\Setup\DB1.Bak' With Format;
Backup Database DB2 TO Disk='\\N2\Setup\DB2.Bak' With Format;


--7
GO
CHECKPOINT;
Backup Log DB1 TO Disk='\\N2\Setup\DB1_Log.Bak';
Backup Log DB2 TO Disk='\\N2\Setup\DB2_Log.Bak';




--8
CREATE AVAILABILITY GROUP MyAG 
   FOR DATABASE DB1, DB2 
   REPLICA ON 
      'N1' WITH 
         (ENDPOINT_URL = 'TCP://N1.noad.com:7022',
         AVAILABILITY_MODE = SYNCHRONOUS_COMMIT,
         FAILOVER_MODE = AUTOMATIC),
      'N2' WITH 
         (ENDPOINT_URL = 'TCP://N2.noad.com:7022',
         AVAILABILITY_MODE = SYNCHRONOUS_COMMIT,
         FAILOVER_MODE = AUTOMATIC); 


GO
--9
ALTER AVAILABILITY GROUP MyAG 
 MODIFY REPLICA ON 'N2' WITH (SECONDARY_ROLE  (ALLOW_CONNECTIONS = ALL));
ALTER AVAILABILITY GROUP MyAG 
 MODIFY REPLICA ON 'N2' WITH (FAILOVER_MODE=MANUAL);
ALTER AVAILABILITY GROUP MyAG 
 MODIFY REPLICA ON 'N2' WITH (AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT);


GO
--11  监听器


ALTER AVAILABILITY GROUP MyAG 
  Add Listener 'MyLT' (WITH IP (('192.168.112.120','255.255.255.0')),PORT=1433);


--副本路径
ALTER AVAILABILITY GROUP MyAG
 MODIFY REPLICA ON N'N1' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://N1.noad.com:1433'));
ALTER AVAILABILITY GROUP MyAG
 MODIFY REPLICA ON N'N2' WITH (SECONDARY_ROLE (READ_ONLY_ROUTING_URL = N'TCP://N2.noad.com:1433'));


--只读路由
ALTER AVAILABILITY GROUP MyAG
 MODIFY REPLICA ON N'N1' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=('N2','N1')));
ALTER AVAILABILITY GROUP MyAG
 MODIFY REPLICA ON N'N2' WITH (PRIMARY_ROLE (READ_ONLY_ROUTING_LIST=('N1','N2')));


GO
--TEST:
Use DB1;
Create Table T1 (ID INT,Qty INT,Constraint PK_T1 Primary key (ID));
INSERT T1 (ID,Qty) Values (1,10);
INSERT T1 (ID,Qty) Values (2,20);
INSERT T1 (ID,Qty) Values (3,30);


Use DB2;
Create Table T1 (ID INT,Qty INT,Constraint PK_T1 Primary key (ID));
INSERT T1 (ID,Qty) Values (1,10);
INSERT T1 (ID,Qty) Values (2,20);
INSERT T1 (ID,Qty) Values (3,30);





--2
Use Master
Go
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'dba123!@#';
GO
CREATE CERTIFICATE CertB WITH SUBJECT = 'CertB for Database Mirroring';
Go
CREATE ENDPOINT Endpoint_Mirroring
 STATE = STARTED
 AS TCP (LISTENER_PORT=7022,LISTENER_IP = ALL) 
 FOR DATABASE_MIRRORING 
  (AUTHENTICATION = CERTIFICATE CertB,
   ENCRYPTION = REQUIRED ALGORITHM AES,
   ROLE = ALL);
Go
BACKUP CERTIFICATE CertB TO FILE = 'C:\Setup\CertB.cer';
--Copy CertB.cer 到正式机
GO
--4
CREATE LOGIN LoginA WITH PASSWORD = 'dba123!@#';
Go
CREATE USER UserA FOR LOGIN LoginA;
Go
CREATE CERTIFICATE CertA AUTHORIZATION UserA FROM FILE = 'C:\Setup\CertA.cer';
Go
GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO [LoginA];
GO
--6
ALTER AVAILABILITY GROUP MyAG JOIN;
GO
--8
Restore Database DB1 From Disk='C:\Setup\DB1.Bak' With NORECOVERY;
Restore Database DB2 From Disk='C:\Setup\DB2.Bak' With NORECOVERY;
GO


Restore Log DB1 From Disk='C:\Setup\DB1_Log.bak' With NORECOVERY;
Restore Log DB2 From Disk='C:\Setup\DB2_Log.bak' With NORECOVERY;
GO
10
ALTER DATABASE DB1 SET HADR AVAILABILITY GROUP = MyAG;
GO


ALTER DATABASE DB2 SET HADR AVAILABILITY GROUP = MyAG;
GO

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值