溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

發布時間:2023-04-28 16:29:17 來源:億速云 閱讀:239 作者:iii 欄目:開發技術

這篇文章主要介紹“SQL Server 2022 AlwaysOn新特性之包含可用性組怎么用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“SQL Server 2022 AlwaysOn新特性之包含可用性組怎么用”文章能幫助大家解決問題。

    SQL Server的容災功能一直弱于Oracle和MySQL,無法自動同步元數據(用戶、登錄名、權限、SQL 代理作業、鏈接服務器),導致在對鏡像庫或者AlwaysOn執行切換之前,都要手動同步master、msdb里面的元數據。直到2022年11月16日發布2022版本,在AlwaysOn中增加了包含可用性組功能,解決了長久以來“無法自動同步元數據”的問題。

    包含可用性組是 Always On 可用性組在SQL Server 2022版本發布的新特性,它支持:

    • 在可用性組級別以及實例級別管理元數據對象(用戶、登錄名、權限、SQL 代理作業等)。

    • 可用性組中的專用包含系統數據庫,比如master和msdb。

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    1 如何創建包含可用性組?

    包含可用性組是在普通故障轉移群集(可以是工作組、也可以是域)搭建好的基礎上,創建包含可用性組時,選擇"Contained"或“包含”,其它操作與之前版本的一致性組無差別。

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    也可以使用命令行創建包含一致性組,在WITH中增加了CONTAINED選項

    CREATE AVAILABILITY GROUP MRROBOTO   
       WITH (  
          AUTOMATED_BACKUP_PREFERENCE = SECONDARY,  
          FAILURE_CONDITION_LEVEL  =  3,   
          HEALTH_CHECK_TIMEOUT = 600000,
    	  CLUSTER_TYPE = WSFC,
    	  CONTAINED   --包含一致性組
           )  
       FOR   
          DATABASE  TEST  
       REPLICA ON   
          '2022-NODE01' WITH   
             (  
             ENDPOINT_URL = 'TCP://2022-NODE01:5022',  
             AVAILABILITY_MODE = SYNCHRONOUS_COMMIT,  
             FAILOVER_MODE = AUTOMATIC,  
             BACKUP_PRIORITY = 30,  
             SECONDARY_ROLE (ALLOW_CONNECTIONS = NO,   
                READ_ONLY_ROUTING_URL = 'TCP://2022-NODE01:1433' ),
             PRIMARY_ROLE (ALLOW_CONNECTIONS = READ_WRITE,   
                READ_ONLY_ROUTING_LIST = ('2022-NODE01') ),  
             SESSION_TIMEOUT = 10,
    		 SEEDING_MODE = AUTOMATIC
             ),   
          '2022-NODE02' WITH   
             (  
             ENDPOINT_URL = 'TCP://2022-NODE02:5022',  
             AVAILABILITY_MODE = SYNCHRONOUS_COMMIT,  
             FAILOVER_MODE = AUTOMATIC,  
             BACKUP_PRIORITY = 30,  
             SECONDARY_ROLE (ALLOW_CONNECTIONS = NO,   
                READ_ONLY_ROUTING_URL = 'TCP://2022-NODE02:1433' ),  
             PRIMARY_ROLE (ALLOW_CONNECTIONS = READ_WRITE,   
                READ_ONLY_ROUTING_LIST = ('2022-NODE01') ),  
             SESSION_TIMEOUT = 10,
    		 SEEDING_MODE = AUTOMATIC
             );
    GO  
    ALTER AVAILABILITY GROUP MRROBOTO
      ADD LISTENER 'MRROBOTO_LSNR' ( WITH IP ( ('192.168.1.128'),('255.255.255.0') ) , PORT = 1433 );   
    GO

    創建好包含一致性組后,會為該AG自動創建2個數據庫:[AGNAME_master]、[AGNAME_msdb],還會創建偵聽器,這看起來比普通的一致性組多了兩個數據庫:AGNAME_master和AGNAME_msdb。

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    2 如何使用包含可用性組?

    要知道包含可用性組是在元數據的同步層面做了改進,就是我們前面所說的master和msdb兩個層面做的改進,所以在使用包含可用性組進行登錄名、作業此類的維護時,需要使用偵聽器IP連接到包含可用性組,而不是使用主實例所在的服務器IP地址。如果使用主實例所在的服務器IP地址連接到可用性組創建登錄名的話,只會保存在本地的數據庫實例上,不會自動同步到包含可用性組中。

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    3 元數據同步驗證

    3.1 用戶、登錄名和權限

    1、使用包含可用性組偵聽器連接到主節點,不管切換到AG01_master還是master,實際上都是使用AG01_master數據庫

    C:\Users\Administrator>sqlcmd -H 192.168.1.128 -U sa -Y 30
    密碼:
    1> select @@servername;
    2> go
    ------------------------------
    2022-NODE01
    (1 行受影響)
    1> use AG01_master
    2> go
    已將數據庫上下文更改為 "master"。
    1> SELECT DB_ID() AS [Database ID],DB_NAME() AS [ Database Name]
    2> go
    Database ID  Database Name
    ----------- ------------------------------
              1 master
    (1 行受影響)
    1> use master
    2> go
    已將數據庫上下文更改為 "master"。
    1> SELECT DB_ID() AS [Database ID],DB_NAME() AS [ Database Name]
    2> go
    Database ID  Database Name
    ----------- ------------------------------
              1 master
    (1 行受影響)

    2、創建test數據庫的登錄名

    1> CREATE LOGIN [test_admin] WITH PASSWORD=N'test.123', DEFAULT_DATABASE=[test], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF
    2> GO
    1> USE [test]
    2> GO
    已將數據庫上下文更改為 "test"。
    1> CREATE USER [test_admin] FOR LOGIN [test_admin]
    2> GO
    1> USE [test]
    2> GO
    已將數據庫上下文更改為 "test"。
    1> ALTER ROLE [db_owner] ADD MEMBER [test_admin]
    2> GO
    1> select name,dbname,sid,createdate from sys.syslogins where loginname='test_admin'
    2> go
    name                           dbname                         sid                            createdate
    ------------------------------ ------------------------------ ------------------------------ -----------------------
    test_admin                     test                           0x8CEFB4D480A8E54F97C86ADF9E6934FD 2022-10-18 14:40:02.913

    3、連接到輔助節點,檢查包含一致性組中的元數據是否已同步(此處建議使用SSMS工具查詢,sqlcmd需要使用-Q參數提前寫好語句)

    • 使用SSMS工具

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    • 使用sqlcmd帶-Q參數

    C:\Users\Administrator>sqlcmd -S 192.168.1.128 -U sa -d AG01_master -Y 30 -K ReadOnly -Q "select @@servername;select name,dbname,sid,createdate from AG01_master.sys.syslogins where loginname='test_admin'"
    密碼:
    ------------------------------
    2022-NODE02
    (1 行受影響)
    name                           dbname                         sid                            createdate
    ------------------------------ ------------------------------ ------------------------------ -----------------------
    test_admin                     test                           0x8CEFB4D480A8E54F97C86ADF9E6934FD 2022-10-18 14:40:02.913
    (1 行受影響)

    也可以使用test_admin用戶直接登錄到輔助節點來驗證元數據是否已同步到輔助節點。

    C:\Users\Administrator>sqlcmd -S 192.168.1.128 -U test_admin -d test -Y 30 -K readonly
    密碼:
    1> select @@servername
    2> go
    ------------------------------
    2022-NODE02
    (1 行受影響)
    1> select * from Foo
    2> go
    Bar
    -----------
              1
    (1 行受影響)
    1> insert into Foo values(2)
    2> go
    消息 3906,級別 16,狀態 2,服務器 2022-NODE02,第 1 行
    無法更新數據庫 "test",因為數據庫是只讀的。

    元數據:用戶、登錄名、權限正常同步

    3.2 鏈接服務器

    1、通過ssms工具在包含可用性組的主節點中創建了一個鏈接服務器

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    2、查詢輔助節點的鏈接服務器情況,從視圖中看到該鏈接服務器已經同步,并且可用

    C:\Users\Administrator>sqlcmd -S 192.168.1.128 -U sa -Y 30 -d AG01_master  -K ReadOnly -Q "select @@servername;select name,data_source from AG01_master.sys.servers where is_linked=1;SELECT Bar FROM [NODE02-FROM125].test.dbo.Foo"
    密碼:
    ------------------------------
    2022-NODE02
    (1 行受影響)
    name                           data_source
    ------------------------------ ------------------------------
    NODE02-FROM125                 192.168.1.126
    (1 行受影響)
    Bar
    -----------
              1
    (1 行受影響)

    3、故障轉移包含可用性組切換到輔助節點,使用SSMS工具連接到包含可用性組,確定數據是正常同步的。

    C:\Users\Administrator>sqlcmd -S 192.168.1.126 -U sa -Y 30 -Q "ALTER AVAILABILITY GROUP [AG01] FAILOVER"
    密碼:輸入密碼

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    元數據:鏈接服務器正常同步

    3.3 SQL代理作業

    將兩個節點的代理服務更改為自動啟動模式,在主節點創建作業,驗證是否自動同步作業到輔助節點

    1、主節點創建作業,每間隔10秒鐘往test數據庫的msdb_test表插入當前服務器名和時間戳。

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    2、輔助節點檢查作業同步情況:輔助節點自動同步作業,作業id一致,但其originating_server(初始服務器)為所在節點的主機名

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    3、測試主節點故障轉移到輔助節點,驗證作業能否正常執行,如果能夠正常執行,msdb_test表的server列會改為故障轉移后的節點主機名:此處由2022-NODE01自動更改為2022-NODE02

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    4、將AlwaysOn主節點切換后,作業僅在主節點運行,不會在輔助節點執行。

    SQL?Server?2022?AlwaysOn新特性之包含可用性組怎么用

    元數據:SQL代理作業正常同步,切換后作業僅在主節點執行

    關于“SQL Server 2022 AlwaysOn新特性之包含可用性組怎么用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女