天天看點

Docker部署SQL Server 2019 Always On叢集

Docker部署Always on叢集

SQL Server在2016年開始支援Linux。随着2017和2019版本的釋出,它開始支援Linux和容器平台上的HA/DR、Kubernetes和大資料叢集解決方案。

在本文中,我們将在3個節點的Docker容器上安裝SQL Server 2019,并建立AlwaysOn可用性組。

我們的目标是使用單個配置檔案快速準備好環境。是以,開發人員或測試團隊可以快速執行諸如相容性、連通性、代碼功能等測試。

在本節中,我們将首先準備一個基于Ubuntu的映像,以便能夠在容器上安裝可用性組。然後我們将執行必要的安裝。

重要提示:不建議在生産環境中執行操作。安裝是在Ubuntu 18.04上執行的。

安裝Docker

安裝Docker就不介紹了,自行安裝即可.

架構

主機名 IP 端口 角色
sqlNode1 主控端IP 1501:1433
sqlNode2 主控端IP 1502:1433 副本
sqlNode3 主控端IP 1503:1433 副本
端口表示:外網端口:内網端口

準備相關容器鏡像

拉取作業系統和資料庫的Docker鏡像,如下

作業系統

docker pull ubuntu:18.04      

SQL Server 2019

docker pull mcr.microsoft.com/mssql/server:2019-latest      

可通過​

​docker images​

​來檢視已下載下傳的鏡像資訊。

鏡像位址:https://hub.docker.com/_/microsoft-mssql-server

開始配置-容器

環境準備完畢後,開始正式的配置安裝。

步驟1:建立Dockerfile

建立目錄用于存放dockerfile、docker-compose.yml等檔案。

mkdir /sql2019ha
cd /sql2019ha
touch dockerfile
vi dockerfile      
  • dockerfile内容如下
FROM ubuntu:18.04
 
RUN apt-get update
 
RUN apt install sudo wget curl gnupg gnupg1 gnupg2 -y
RUN apt install software-properties-common systemd vim -y
RUN wget -qO- https://packages.microsoft.com/keys/microsoft.asc | sudo apt-key add -
 
RUN add-apt-repository "$(wget -qO- https://packages.microsoft.com/config/ubuntu/18.04/mssql-server-2019.list)"
RUN apt-get update
RUN apt-get install -y mssql-server
 
RUN /opt/mssql/bin/mssql-conf set hadr.hadrenabled  1
RUN /opt/mssql/bin/mssql-conf set sqlagent.enabled true
 
EXPOSE 1433
 
ENTRYPOINT /opt/mssql/bin/sqlservr      

說明:

FROM:表示基于什麼鏡像進行安裝的

RUN:在鏡像中進行的操作

EXPOSE:指定服務端口

ENTRYPOINT:運作指令

步驟2:編譯鏡像

通過dockerfile來編譯鏡像,用于後面的安裝,指令:​

​docker build -t sqlag2019:ha .​

其中​

​sqlag2019​

​​為鏡像名稱,​

​ha​

​​是鏡像标簽,​

​.​

​表示在目前目錄下編譯,因為dockerfile就在目前目錄下。

以下輸出是精簡的,實際上輸出非常多…也需要一定時間(安裝一些包、資料庫等),由網速決定

$ docker build -t sqlag2019:ha .
Sending build context to Docker daemon   2.56kB
Step 1/12 : FROM ubuntu:18.04
 ---> c3c304cb4f22
Step 2/12 : RUN apt-get update
 ---> Running in 950e50f80f00
Get:1 http://archive.ubuntu.com/ubuntu bionic InRelease [242 kB]
Get:2 http://security.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]
Get:3 http://security.ubuntu.com/ubuntu bionic-security/main amd64 Packages [932 kB]
Get:4 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]...
Step 3/12 : RUN apt install sudo wget curl gnupg gnupg1 gnupg2 -y
 ---> Running in edc9d15b2383
..
..
Step 8/12 : RUN sudo apt-get install -y mssql-server
 ---> Running in 43d82a503f8a
Reading package lists...
Building dependency tree...
Reading state information...
The following additional packages will be installed:
Step 9/12 : RUN sudo /opt/mssql/bin/mssql-conf set hadr.hadrenabled  1
 ---> Running in 166c6596d2dd
SQL Server needs to be restarted in order to apply this setting. Please run
'systemctl restart mssql-server.service'.
Removing intermediate container 166c6596d2dd
 ---> bcdb057fed43
Step 10/12 : RUN sudo /opt/mssql/bin/mssql-conf set sqlagent.enabled true
 ---> Running in 22dd6a93d1ef
SQL Server needs to be restarted in order to apply this setting. Please run
'systemctl restart mssql-server.service'.
Removing intermediate container 22dd6a93d1ef
 ---> 6b90afbaf94e
Step 11/12 : EXPOSE 1433
 ---> Running in bcc14f3b0bad
Removing intermediate container bcc14f3b0bad
 ---> 4aae1563aa74
Step 12/12 : ENTRYPOINT /opt/mssql/bin/sqlservr
 ---> Running in 68b6ed45ff6a
Removing intermediate container 68b6ed45ff6a
 ---> b7467618c371
Successfully built b7467618c371
Successfully tagged sqlag2019:ha      

最後出現​

​Successfully​

​表示編譯成功,否則根據錯誤資訊進行解決。

步驟3:建立容器

現在鏡像編譯好了,下面再通過​

​docker-compose​

​檔案來建立、配置3個容器,具體内容如下:

$ touch docker-compose.yml
$ vi      
version: '3'
 
services:
  db1:
    container_name: sqlNode1
    image: sqlag2019:ha
    hostname: sqlNode1
    domainname: lab.local
    environment:
      SA_PASSWORD: "MyPassWord123"
      ACCEPT_EULA: "Y"
    ports:
    - "1501:1433"
    extra_hosts:
      sqlNode2.labl.local: "172.16.238.22"
      sqlNode3.labl.local: "172.16.238.23"
    networks:
        internal:
                ipv4_address: 172.16.238.21
 
  db2:
    container_name: sqlNode2
    image: sqlag2019:ha
    hostname: sqlNode2
    domainname: lab.local
    environment:
      SA_PASSWORD: "MyPassWord123"
      ACCEPT_EULA: "Y"
    ports:
    - "1502:1433"
    extra_hosts:
      sqlNode1.lab.local: "172.16.238.21"
      sqlNode3.lab.local: "172.16.238.23"
    networks:
        internal:
                ipv4_address: 172.16.238.22
 
  db3:
    container_name: sqlNode3
    image: sqlag2019:ha
    hostname: sqlNode3
    domainname: lab.local
    environment:
      SA_PASSWORD: "MyPassWord123"
      ACCEPT_EULA: "Y"
    ports:
    - "1503:1433"
    extra_hosts:
      sqlNode1.lab.local: "172.16.238.21"
      sqlNode2.lab.local: "172.16.238.22"
    networks:
        internal:
                ipv4_address: 172.16.238.23
 
networks:
    internal:
      ipam:
            driver: default
            config:
                - subnet: 172.16.238.0/24      

步驟4:啟動容器

然後通過​

​docker-compose up -d​

​​指令啟動三個容器,其中​

​-d​

​表示在背景運作。

$ docker-compose up -d
Creating network "sql2019hademo_internal" with the default driver
Creating sqlNode2 ...
Creating sqlNode1 ...
Creating sqlNode2
Creating sqlNode3 ...
Creating sqlNode1
Creating sqlNode2 ... done      
注意:docker-compose是需要單獨安裝的,就是一個可執行檔案。可通過apt、yum來安裝。

檢視容器狀态

$ docker-compose ps
Name                Command               State           Ports
--------------------------------------------------------------------------
sqlNode1   /bin/sh -c /opt/mssql/bin/ ...   Up      0.0.0.0:1501->1433/tcp
sqlNode2   /bin/sh -c /opt/mssql/bin/ ...   Up      0.0.0.0:1502->1433/tcp
sqlNode3   /bin/sh -c /opt/mssql/bin/ ...   Up      0.0.0.0:1503->1433/tcp      

至此容器已經啟動完成,下面通過SSMS連接配接資料庫進行相關檢查和配置ALWAYSON。

步驟5:SSMS連接配接MSSQL

通過主控端的外網IP+端口連接配接相應的資料庫,如下:

Docker部署SQL Server 2019 Always On叢集
注意:IP和端口之間是逗号
Docker部署SQL Server 2019 Always On叢集

可以看到資料庫的圖示也是Linux的圖示。

配置-資料庫

這部分就是在資料庫中進行相關配置,如:建立KEY加密檔案,管理使用者、可用組等。

步驟1:連接配接主庫-sqlNode1

主庫也就是節點1,端口是1501,連接配接方法如上圖。

我們将證書和私鑰提取到​

​/tmp/dbm_certificate.cer​

​​和​

​/tmp/dbm_certificate.pvk​

​檔案中。

我們将這些檔案複制到其他節點,并根據以下檔案建立主密鑰和證書:執行以下腳本

USE master
GO
 
CREATE LOGIN dbm_login WITH PASSWORD = 'MyStr0ngPa$w0rd';
CREATE USER dbm_user FOR LOGIN dbm_login;
GO
 
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'MyStr0ngPa$w0rd';
go
CREATE CERTIFICATE dbm_certificate WITH SUBJECT = 'dbm';
BACKUP CERTIFICATE dbm_certificate
TO FILE = '/tmp/dbm_certificate.cer'
WITH PRIVATE KEY (
        FILE = '/tmp/dbm_certificate.pvk',
        ENCRYPTION BY PASSWORD = 'MyStr0ngPa$w0rd'
    );
GO      

将檔案拷貝到其他兩個節點:

$ docker cp sqlNode1:/tmp/dbm_certificate.cer .
$ docker cp sqlNode1:/tmp/dbm_certificate.pvk .
$ docker cp dbm_certificate.cer sqlNode2:/tmp/
$ docker cp dbm_certificate.pvk sqlNode2:/tmp/
$ docker cp dbm_certificate.cer sqlNode3:/tmp/
$ docker cp      

步驟2:連接配接從庫-sqlNode2和sqlNode3

兩個從庫的端口分别是:1502和1503.然後重複主庫執行的操作,如下:

CREATE LOGIN dbm_login WITH PASSWORD = 'MyStr0ngPa$w0rd';
CREATE USER dbm_user FOR LOGIN dbm_login;
GO
 
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'MyStr0ngPa$w0rd';
GO
CREATE CERTIFICATE dbm_certificate   
    AUTHORIZATION dbm_user
    FROM FILE = '/tmp/dbm_certificate.cer'
    WITH PRIVATE KEY (
    FILE = '/tmp/dbm_certificate.pvk',
    DECRYPTION BY PASSWORD = 'MyStr0ngPa$w0rd'
);
GO      

步驟3:所有節點

在所有節點上執行以下指令

CREATE ENDPOINT [Hadr_endpoint]
    AS TCP (LISTENER_IP = (0.0.0.0), LISTENER_PORT = 5022)
    FOR DATA_MIRRORING (
        ROLE = ALL,
        AUTHENTICATION = CERTIFICATE dbm_certificate,
        ENCRYPTION = REQUIRED ALGORITHM AES
        );
ALTER ENDPOINT [Hadr_endpoint] STATE = STARTED;
GRANT CONNECT ON ENDPOINT::[Hadr_endpoint] TO [dbm_login];      

啟用開機自啟動ALWAYON,在所有節點執行以下指令

ALTER EVENT SESSION  AlwaysOn_health ON SERVER WITH (STARTUP_STATE=ON);
GO      

步驟4:建立高可用組

可以用SSMS工具和T-SQL兩種方式,下面以T-SQL為例:

運作以下腳本在​

​主節點​

​​中建立一個可用性組。 請注意,選擇​

​CLUSTER_TYPE = NONE​

​選項是因為它是在沒有諸如Pacemaker或Windows Server故障轉移群集之類的群集管理平台的情況下安裝的。

如果要在Linux上安裝AlwaysOn AG,則應為Pacemaker選擇CLUSTER_TYPE = EXTERNAL:

CREATE AVAILABILITY GROUP [AG1]
        WITH (CLUSTER_TYPE = NONE)
        FOR REPLICA ON
        N'sqlNode1'
            WITH (
            ENDPOINT_URL = N'tcp://sqlNode1:5022',
            AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
                SEEDING_MODE = AUTOMATIC,
                FAILOVER_MODE = MANUAL,
            SECONDARY_ROLE (ALLOW_CONNECTIONS = ALL)
                ),
        N'sqlNode2'
            WITH (
            ENDPOINT_URL = N'tcp://sqlNode2:5022',
            AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
                SEEDING_MODE = AUTOMATIC,
                FAILOVER_MODE = MANUAL,
            SECONDARY_ROLE (ALLOW_CONNECTIONS = ALL)
                ),
        N'sqlNode3'
            WITH (
            ENDPOINT_URL = N'tcp://sqlNode3:5022',
            AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
                SEEDING_MODE = AUTOMATIC,
                FAILOVER_MODE = MANUAL,
            SECONDARY_ROLE (ALLOW_CONNECTIONS = ALL)
                );
GO      

在從庫中執行以下指令,将從庫加入到AG組中

ALTER AVAILABILITY GROUP [ag1] JOIN WITH (CLUSTER_TYPE = NONE);
ALTER AVAILABILITY GROUP [ag1] GRANT CREATE ANY DATABASE;
GO      

至此在Docker容器中安裝SQL Server Alwayson叢集已經完成了!

注意:當指定​

​CLUSTER_TYPE = NONE​

​建立可用組時,在執行故障轉移時需執行以下指令

​ALTER AVAILABILITY GROUP [ag1] FORCE_FAILOVER_ALLOW_DATA_LOSS​

測試

CREATE DATABASE agtestdb;
GO
ALTER DATABASE agtestdb SET RECOVERY FULL;
GO
BACKUP DATABASE agtestdb TO DISK = '/var/opt/mssql/data/agtestdb.bak';
GO
ALTER AVAILABILITY GROUP [ag1] ADD DATABASE [agtestdb];
GO      

參考連接配接

  1. ​​https://docs.microsoft.com/en-us/sql/linux/quickstart-install-connect-docker?view=sql-server-ver15​​
  2. ​​https://docs.microsoft.com/en-us/sql/linux/quickstart-install-connect-ubuntu?view=sql-server-ver15​​
  3. ​​https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-create-availability-group?view=sql-server-ver15​​
  4. ​​https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-configure-mssql-conf?view=sql-server-ver15​​
  5. ​​https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-configure-environment-variables?view=sql-server-ver15​​
  6. ​​https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-availability-group-cluster-ubuntu?view=sql-server-linux-ver15​​
  7. ​​https://docs.docker.com/engine/install/ubuntu/​​
  8. ​​https://docs.docker.com/compose/​​