电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:148日期:2023-05-02 10:03:18
目錄
  • 1 如何創建包含可用性組?
  • 2 如何使用包含可用性組?
  • 3 元數據同步驗證
    • 3.1 用戶、登錄名和權限
    • 3.2 鏈接服務器
    • 3.3 SQL代理作業
  • 4 包含可用性組總結

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

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

    • 在可用性組級別以及實例級別管理元數據對象(用戶、登錄名、權限、SQL 代理作業等)。
    • 可用性組中的專用包含系統數據庫,比如master和msdb。

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

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

    也可以使用命令行創建包含一致性組,在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。

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

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

    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_master2> go已將數據庫上下文更改為 "master"。1> SELECT DB_ID() AS [Database ID],DB_NAME() AS [ Database Name]2> goDatabase ID  Database Name----------- ------------------------------  1 master(1 行受影響)1> use master2> go已將數據庫上下文更改為 "master"。1> SELECT DB_ID() AS [Database ID],DB_NAME() AS [ Database Name]2> goDatabase 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=OFF2> GO1> USE [test]2> GO已將數據庫上下文更改為 "test"。1> CREATE USER [test_admin] FOR LOGIN [test_admin]2> GO1> USE [test]2> GO已將數據庫上下文更改為 "test"。1> ALTER ROLE [db_owner] ADD MEMBER [test_admin]2> GO1> select name,dbname,sid,createdate from sys.syslogins where loginname="test_admin"2> goname   dbname sid    createdate------------------------------ ------------------------------ ------------------------------ -----------------------test_admin     test   0x8CEFB4D480A8E54F97C86ADF9E6934FD 2022-10-18 14:40:02.913

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

    • 使用SSMS工具

    • 使用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 @@servername2> go------------------------------2022-NODE02(1 行受影響)1> select * from Foo2> goBar-----------  1(1 行受影響)1> insert into Foo values(2)2> go消息 3906,級別 16,狀態 2,服務器 2022-NODE02,第 1 行無法更新數據庫 "test",因為數據庫是只讀的。

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

    3.2 鏈接服務器

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

    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"密碼:輸入密碼

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

    3.3 SQL代理作業

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

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

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

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

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

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

    4 包含可用性組總結

    1、對于包含可用性組來說,它的元數據全部都存放在?可用性組名稱_master??和?可用性組名稱_msdb??這兩個數據庫中。

    2、對于數據庫實例來說,包含可用性組的?可用性組名稱_master??和?可用性組名稱_msdb??這兩個數據庫就是普通的用戶數據庫,可讀可寫,但不建議存放用戶的生產數據;

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

    這種設計就解決了SQL Server一直以來被詬病的元數據對象同步問題。使得用戶、登錄名、鏈接服務器和作業都能夠在包含一致性組中的主節點和輔助節點同步。?

    到此這篇關于SQL Server 2022 AlwaysOn新特性之包含可用性組介紹的文章就介紹到這了,更多相關SQL Server 2022 AlwaysOn內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

    標簽: MsSQL
    主站蜘蛛池模板: 中国产业发展研究网 - 提供行业研究报告 可行性研究报告 投资咨询 市场调研服务 | 齿轮减速马达一体式_蜗轮蜗杆减速机配电机-德国BOSERL齿轮减速电动机生产厂家 | 盐城网络公司_盐城网站优化_盐城网站建设_盐城市启晨网络科技有限公司 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 柴油机_柴油发电机_厂家_品牌-江苏卡得城仕发动机有限公司 | 施工电梯_齿条货梯_烟囱电梯_物料提升机-河南大诚机械制造有限公司 | 杭州成人高考_浙江省成人高考网上报名 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 撕碎机,撕破机,双轴破碎机-大件垃圾破碎机厂家 | 高清视频编码器,4K音视频编解码器,直播编码器,流媒体服务器,深圳海威视讯技术有限公司 | 哈尔滨发电机,黑龙江柴油发电机组-北方星光 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | 油罐车_加油机_加油卷盘_加油机卷盘_罐车人孔盖_各类球阀_海底阀等车用配件厂家-湖北华特专用设备有限公司 | 国产频谱分析仪-国产网络分析仪-上海坚融实业有限公司 | 天津电机维修|水泵维修-天津晟佳机电设备有限公司 | 高楼航空障碍灯厂家哪家好_航空障碍灯厂家_广州北斗星障碍灯有限公司 | 广州办公室设计,办公室装修,写字楼设计,办公室装修公司_德科 | 防堵吹扫装置-防堵风压测量装置-电动操作显示器-兴洲仪器 | 北京三友信电子科技有限公司-ETC高速自动栏杆机|ETC机柜|激光车辆轮廓测量仪|嵌入式车道控制器 | 比士亚-专业恒温恒湿酒窖,酒柜,雪茄柜的设计定制| POS机官网 - 拉卡拉POS机免费办理|官网在线申请入口 | BHK汞灯-百科|上海熙浩实业有限公司 | 刹车盘机床-刹车盘生产线-龙口亨嘉智能装备 | 厂厂乐-汇聚海量采购信息的B2B微营销平台-厂厂乐官网 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 房屋质量检测-厂房抗震鉴定-玻璃幕墙检测-房屋安全鉴定机构 | 办公室家具_板式办公家具定制厂家-FMARTS福玛仕办公家具 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 无锡不干胶标签,卷筒标签,无锡瑞彩包装材料有限公司 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 济南玻璃安装_济南玻璃门_济南感应门_济南玻璃隔断_济南玻璃门维修_济南镜片安装_济南肯德基门_济南高隔间-济南凯轩鹏宇玻璃有限公司 | 多功能真空滤油机_润滑油全自动滤油机_高效真空滤油机价格-重庆润华通驰 | 车间除尘设备,VOCs废气处理,工业涂装流水线,伸缩式喷漆房,自动喷砂房,沸石转轮浓缩吸附,机器人喷粉线-山东创杰智慧 | 雄松华章(广州华章MBA)官网-专注MBA/MPA/MPAcc/MEM辅导培训 | 淄博不锈钢,淄博不锈钢管,淄博不锈钢板-山东振远合金科技有限公司 | 折弯机-刨槽机-数控折弯机-数控刨槽机-数控折弯机厂家-深圳豐科机械有限公司 | 磁粉制动器|张力控制器|气胀轴|伺服纠偏控制器整套厂家--台灵机电官网 | 辐射仪|辐射检测仪|辐射巡测仪|个人剂量报警仪|表面污染检测仪|辐射报警仪|辐射防护网 | 珠海白蚁防治_珠海灭鼠_珠海杀虫灭鼠_珠海灭蟑螂_珠海酒店消杀_珠海工厂杀虫灭鼠_立净虫控防治服务有限公司 | 胀套-锁紧盘-风电锁紧盘-蛇形联轴器「厂家」-瑞安市宝德隆机械配件有限公司 | 包装盒厂家_纸盒印刷_礼品盒定制-济南恒印包装有限公司 |