欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL?Server?2022?AlwaysOn新特性之包含可用性組詳解

 更新時(shí)間:2023年04月28日 08:22:42   作者:開(kāi)始折騰吧  
這篇文章主要介紹了SQL?Server?2022?AlwaysOn新特性之包含可用性組介紹,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

SQL Server的容災(zāi)功能一直弱于Oracle和MySQL,無(wú)法自動(dòng)同步元數(shù)據(jù)(用戶、登錄名、權(quán)限、SQL 代理作業(yè)、鏈接服務(wù)器),導(dǎo)致在對(duì)鏡像庫(kù)或者AlwaysOn執(zhí)行切換之前,都要手動(dòng)同步master、msdb里面的元數(shù)據(jù)。直到2022年11月16日發(fā)布2022版本,在AlwaysOn中增加了包含可用性組功能,解決了長(zhǎng)久以來(lái)“無(wú)法自動(dòng)同步元數(shù)據(jù)”的問(wèn)題。

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

  • 在可用性組級(jí)別以及實(shí)例級(jí)別管理元數(shù)據(jù)對(duì)象(用戶、登錄名、權(quán)限、SQL 代理作業(yè)等)。
  • 可用性組中的專用包含系統(tǒng)數(shù)據(jù)庫(kù),比如master和msdb。

1 如何創(chuàng)建包含可用性組?

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

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

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

創(chuàng)建好包含一致性組后,會(huì)為該AG自動(dòng)創(chuàng)建2個(gè)數(shù)據(jù)庫(kù):[AGNAME_master]、[AGNAME_msdb],還會(huì)創(chuàng)建偵聽(tīng)器,這看起來(lái)比普通的一致性組多了兩個(gè)數(shù)據(jù)庫(kù):AGNAME_master和AGNAME_msdb。

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

要知道包含可用性組是在元數(shù)據(jù)的同步層面做了改進(jìn),就是我們前面所說(shuō)的master和msdb兩個(gè)層面做的改進(jìn),所以在使用包含可用性組進(jìn)行登錄名、作業(yè)此類的維護(hù)時(shí),需要使用偵聽(tīng)器IP連接到包含可用性組,而不是使用主實(shí)例所在的服務(wù)器IP地址。如果使用主實(shí)例所在的服務(wù)器IP地址連接到可用性組創(chuàng)建登錄名的話,只會(huì)保存在本地的數(shù)據(jù)庫(kù)實(shí)例上,不會(huì)自動(dòng)同步到包含可用性組中。

3 元數(shù)據(jù)同步驗(yàn)證

3.1 用戶、登錄名和權(quán)限

1、使用包含可用性組偵聽(tīng)器連接到主節(jié)點(diǎn),不管切換到AG01_master還是master,實(shí)際上都是使用AG01_master數(shù)據(jù)庫(kù)

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
已將數(shù)據(jù)庫(kù)上下文更改為 "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
已將數(shù)據(jù)庫(kù)上下文更改為 "master"。
1> SELECT DB_ID() AS [Database ID],DB_NAME() AS [ Database Name]
2> go
Database ID  Database Name
----------- ------------------------------
          1 master
(1 行受影響)

2、創(chuàng)建test數(shù)據(jù)庫(kù)的登錄名

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
已將數(shù)據(jù)庫(kù)上下文更改為 "test"。
1> CREATE USER [test_admin] FOR LOGIN [test_admin]
2> GO
1> USE [test]
2> GO
已將數(shù)據(jù)庫(kù)上下文更改為 "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、連接到輔助節(jié)點(diǎn),檢查包含一致性組中的元數(shù)據(jù)是否已同步(此處建議使用SSMS工具查詢,sqlcmd需要使用-Q參數(shù)提前寫(xiě)好語(yǔ)句)

  • 使用SSMS工具

  • 使用sqlcmd帶-Q參數(shù)
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用戶直接登錄到輔助節(jié)點(diǎn)來(lái)驗(yàn)證元數(shù)據(jù)是否已同步到輔助節(jié)點(diǎn)。

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,級(jí)別 16,狀態(tài) 2,服務(wù)器 2022-NODE02,第 1 行
無(wú)法更新數(shù)據(jù)庫(kù) "test",因?yàn)閿?shù)據(jù)庫(kù)是只讀的。

元數(shù)據(jù):用戶、登錄名、權(quán)限正常同步

3.2 鏈接服務(wù)器

1、通過(guò)ssms工具在包含可用性組的主節(jié)點(diǎn)中創(chuàng)建了一個(gè)鏈接服務(wù)器

2、查詢輔助節(jié)點(diǎn)的鏈接服務(wù)器情況,從視圖中看到該鏈接服務(wù)器已經(jīng)同步,并且可用

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、故障轉(zhuǎn)移包含可用性組切換到輔助節(jié)點(diǎn),使用SSMS工具連接到包含可用性組,確定數(shù)據(jù)是正常同步的。

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

元數(shù)據(jù):鏈接服務(wù)器正常同步

3.3 SQL代理作業(yè)

將兩個(gè)節(jié)點(diǎn)的代理服務(wù)更改為自動(dòng)啟動(dòng)模式,在主節(jié)點(diǎn)創(chuàng)建作業(yè),驗(yàn)證是否自動(dòng)同步作業(yè)到輔助節(jié)點(diǎn)

1、主節(jié)點(diǎn)創(chuàng)建作業(yè),每間隔10秒鐘往test數(shù)據(jù)庫(kù)的msdb_test表插入當(dāng)前服務(wù)器名和時(shí)間戳。

2、輔助節(jié)點(diǎn)檢查作業(yè)同步情況:輔助節(jié)點(diǎn)自動(dòng)同步作業(yè),作業(yè)id一致,但其originating_server(初始服務(wù)器)為所在節(jié)點(diǎn)的主機(jī)名

3、測(cè)試主節(jié)點(diǎn)故障轉(zhuǎn)移到輔助節(jié)點(diǎn),驗(yàn)證作業(yè)能否正常執(zhí)行,如果能夠正常執(zhí)行,msdb_test表的server列會(huì)改為故障轉(zhuǎn)移后的節(jié)點(diǎn)主機(jī)名:此處由2022-NODE01自動(dòng)更改為2022-NODE02

4、將AlwaysOn主節(jié)點(diǎn)切換后,作業(yè)僅在主節(jié)點(diǎn)運(yùn)行,不會(huì)在輔助節(jié)點(diǎn)執(zhí)行。

元數(shù)據(jù):SQL代理作業(yè)正常同步,切換后作業(yè)僅在主節(jié)點(diǎn)執(zhí)行

4 包含可用性組總結(jié)

1、對(duì)于包含可用性組來(lái)說(shuō),它的元數(shù)據(jù)全部都存放在?可用性組名稱_master??和?可用性組名稱_msdb??這兩個(gè)數(shù)據(jù)庫(kù)中。

2、對(duì)于數(shù)據(jù)庫(kù)實(shí)例來(lái)說(shuō),包含可用性組的?可用性組名稱_master??和?可用性組名稱_msdb??這兩個(gè)數(shù)據(jù)庫(kù)就是普通的用戶數(shù)據(jù)庫(kù),可讀可寫(xiě),但不建議存放用戶的生產(chǎn)數(shù)據(jù);

3、要連接到包含可用性組,必須使用?包含可用性組的偵聽(tīng)器??連接,其他連接參數(shù)與舊版本一樣。

這種設(shè)計(jì)就解決了SQL Server一直以來(lái)被詬病的元數(shù)據(jù)對(duì)象同步問(wèn)題。使得用戶、登錄名、鏈接服務(wù)器和作業(yè)都能夠在包含一致性組中的主節(jié)點(diǎn)和輔助節(jié)點(diǎn)同步。?

到此這篇關(guān)于SQL Server 2022 AlwaysOn新特性之包含可用性組介紹的文章就介紹到這了,更多相關(guān)SQL Server 2022 AlwaysOn內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SQL Server數(shù)據(jù)庫(kù)重命名、數(shù)據(jù)導(dǎo)出的方法說(shuō)明

    SQL Server數(shù)據(jù)庫(kù)重命名、數(shù)據(jù)導(dǎo)出的方法說(shuō)明

    這篇文章主要介紹了SQL Server數(shù)據(jù)庫(kù)重命名、數(shù)據(jù)導(dǎo)出、更改數(shù)據(jù)庫(kù)所有者的方法說(shuō)明,大家參考使用吧
    2013-11-11
  • 安裝MSDE2000提示為了安全起見(jiàn),要求使用強(qiáng) SA 密碼的解決方法

    安裝MSDE2000提示為了安全起見(jiàn),要求使用強(qiáng) SA 密碼的解決方法

    今天下載了一個(gè)msde2000A,本想按照平時(shí)的安裝習(xí)慣,找到了setup.exe安裝程序,錯(cuò)誤提示彈出一個(gè)對(duì)話框:為了安全起見(jiàn),要求使用強(qiáng) SA 密碼。請(qǐng)使用SAPWD開(kāi)關(guān)提供同一密碼。有關(guān)詳細(xì)信息,請(qǐng)參閱自述文件。安裝程序?qū)⒘⒓赐顺?/div> 2013-08-08
  • 數(shù)據(jù)庫(kù)表的查詢操作(實(shí)驗(yàn)二)

    數(shù)據(jù)庫(kù)表的查詢操作(實(shí)驗(yàn)二)

    這篇文章主要介紹了表的查詢操作,包括單表查詢、多表連接及查詢、嵌套查詢、集合查詢等,需要的朋友可以參考下
    2015-08-08
  • sql?server2022徹底卸載全過(guò)程

    sql?server2022徹底卸載全過(guò)程

    這篇文章主要給大家介紹了關(guān)于sql?server2022徹底卸載的相關(guān)資料,按照下面的文章操作可以完全卸載 SQL Server的現(xiàn)有實(shí)例,并對(duì)系統(tǒng)進(jìn)行準(zhǔn)備以便可以重新安裝 SQL Server,需要的朋友可以參考下
    2023-10-10
  • SQl 跨服務(wù)器查詢語(yǔ)句

    SQl 跨服務(wù)器查詢語(yǔ)句

    SQl跨服務(wù)器查詢的二種實(shí)現(xiàn)方法,一般情況如果安全設(shè)置好了,根本無(wú)法用,不過(guò)內(nèi)部網(wǎng)絡(luò)還是不錯(cuò)的。
    2009-10-10
  • 淺析SQL Server中包含事務(wù)的存儲(chǔ)過(guò)程

    淺析SQL Server中包含事務(wù)的存儲(chǔ)過(guò)程

    數(shù)據(jù)庫(kù)事務(wù)(Database Transaction) ,是指作為單個(gè)邏輯工作單元執(zhí)行的一系列操作,要么完整地執(zhí)行,要么完全地不執(zhí)行。那么在存儲(chǔ)過(guò)程里添加事務(wù),則可以保證該事務(wù)里的所有sql代碼要么完全執(zhí)行要么完全不執(zhí)行。
    2014-08-08
  • SQL Server實(shí)現(xiàn)顯示每個(gè)類別最新更新數(shù)據(jù)的方法

    SQL Server實(shí)現(xiàn)顯示每個(gè)類別最新更新數(shù)據(jù)的方法

    這篇文章主要介紹了SQL Server實(shí)現(xiàn)顯示每個(gè)類別最新更新數(shù)據(jù)的方法,涉及SQL Server數(shù)據(jù)庫(kù)Select查詢操作使用技巧,需要的朋友可以參考下
    2017-03-03
  • sqlserver中操作主從關(guān)系表的sql語(yǔ)句

    sqlserver中操作主從關(guān)系表的sql語(yǔ)句

    在項(xiàng)目開(kāi)發(fā)中,經(jīng)常出現(xiàn)這樣的需求。在新增或修改一個(gè)主表數(shù)據(jù)時(shí),對(duì)應(yīng)的從表也要進(jìn)行同步,此時(shí)我們是怎么操作的了?
    2011-07-07
  • sql?server如何去除數(shù)據(jù)中的一些無(wú)用的空格

    sql?server如何去除數(shù)據(jù)中的一些無(wú)用的空格

    這篇文章主要介紹了sql?server去除數(shù)據(jù)中的一些無(wú)用的空格,本文給大家提到了一些常用的函數(shù),結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • SQLServer數(shù)據(jù)庫(kù)誤操作恢復(fù)的方法

    SQLServer數(shù)據(jù)庫(kù)誤操作恢復(fù)的方法

    本文主要介紹了SQLServer數(shù)據(jù)庫(kù)誤操作恢復(fù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01

最新評(píng)論