SQL Server AlwaysOn 集群 關於主Server IP與Listener IP調換的詳細測試

来源:https://www.cnblogs.com/xuliuzai/archive/2019/04/21/10747343.html
-Advertisement-
Play Games

1. 背景 SQL Server 搭建AlwaysOn後,我們就希望程式連接時使用虛擬的偵聽IP(Listener IP),而不再是主Server 的IP。如果我們有採用中間件,則可以在配置中,直接用Listener IP 替換掉 Server IP,可有時候,我們不太確定,是否有些舊程式、不太常用 ...


1. 背景

SQL Server 搭建AlwaysOn後,我們就希望程式連接時使用虛擬的偵聽IP(Listener IP),而不再是主Server 的IP。如果我們有採用中間件,則可以在配置中,直接用Listener IP 替換掉 Server IP,可有時候,我們不太確定,是否有些舊程式、不太常用的程式在使用。甚至在很多公司根本就沒有使用中間件,這時候去修改每個應用、APP、程式的資料庫連接配置,太難了。

那麼有沒有其它好的方案呢?有一個---調換主Server IP與Listener IP,即將Server IP與Listener IP互換。

2. 測試目的

為減少因使用AlwaysOn的Listener IP而必須調整現有程式的工作,考慮測試把Listener IP改成原主Server IP。

對調的好處:

1)減少應用、APP、程式的資料庫連接配置的修改。

2) 外部介面(廠商、SAP、ETL、xDS、BI、MIS, etc)不用修改;如修改,溝通成本大。

3) 不用擔心有老舊程式未修改為調用Listener IP。

3. 測試環境

Node1 Node2 Node3 Cluster IP Listener IP
168.172.40.112 168.172.40.113 168.172.40.114 168.172.40.115 168.172.40.117

Role:Primary

 Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

SSMS 連接登入各IP顯示如下:

4. 測試步驟

(第一部分更新主節點的server IP為臨時IP,即將40.112-->40.118

Step 1 通過控制面板更新主Server IP

Step 2 更新前為40.112

Step 3 更新後為40.118

Step 4  更新後查看狀態如下(更新後,短暫不可訪問,AG狀態resolving。約15S自動恢復正常)

此時環境調整為:

Node1 Node2 Node3 Cluster IP Listener IP
168.172.40.118 168.172.40.113 168.172.40.114 168.172.40.115 168.172.40.117

Role:Primary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

 

(第二部分更新listener IP為原主server IP,即將 40.117--->40.112

 

Step 5 打開FailOver管理器--->Role--->Resources--->AGName--->Properties

Step 6  選中地址IP,單擊,使Edit欄位變成活躍狀態,點擊Edit。

 

Step 7 彈出警告,單擊Yes選項。

Step 8  修改Listener IP

 修改前:

修改後:

Step 9 修改完畢,點擊OK。

 

Step 10 彈出警告,單擊Yes選項

Step 11 修改後可用組Stop, AG狀態為Resolving。

Step 12 重啟AG Role。

Step 13  listener 修改完畢(117—>112)

此時環境調整為:

 

Node1 Node2 Node3 Cluster IP Listener IP
168.172.40.118 168.172.40.113 168.172.40.114 168.172.40.115 168.172.40.112

Role:Primary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

 

 (第三部分更新原主的server的 IP由臨時IP調整為Listener IP,即將 40.118--->40.112

 

Step 14 參照step 1—>step 5,可把原主server IP由臨時IP調整為Listener IP (118-->117)

此時環境調整為:

 

Node1 Node2 Node3 Cluster IP Listener IP
168.172.40.117 168.172.40.113 168.172.40.114 168.172.40.115 168.172.40.112

Role:Primary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

Role:Secondary

Availability Mode:Asynchronous Commit

5. 總結

可以成功實現調換主Server IP與Listener IP。

測試環境下:

  1. 更改主Server IP為temp IP時,AG自動恢復正常狀態需要耗時約15秒。
  2. 更改Listener IP為原主Server IP時,需要手動重啟一次AG Role,耗時約3~4秒。
  3. 更改temp IP為原Listener IP,AG自動恢復正常狀態需要耗時約15秒。

正式環境下,可能需時要長一些,可能需要1~2分鐘,甚至更長。

所以,請在周末或假期等業務線操作不繁忙的時候進行調換作業,避免出現異常時無足夠的處理時間。

切換完成後,建議做兩次auto-failover切換(最後恢復到輔Server還是輔Server),同時請支持部門的同學配合測試程式,確保真正發生Auto-failover時不出現問題。

 

 本文版權歸作者所有,未經作者同意不得轉載,謝謝配合!!!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • mysql優化二之鎖機制 mysql提供了鎖機制和MVCC機制來保證併發操作的安全性,這裡主要討論鎖機制, MVCC見下篇文章 mysql的鎖按照鎖粒度可分為行鎖與表鎖,按照操作類型劃分可讀鎖和寫鎖 InnoDB存儲引擎支持表鎖和行鎖,預設鎖為行鎖,MyIsam只支持表鎖 鎖粒度越高則併發性越好 表 ...
  • SQL中只有兩列數據(欄位1,欄位2),將其相同欄位1的行轉列 轉換前: 轉換後: 轉自:https://bbs.csdn.net/topics/392320974 ...
  • 一.Spark2.0的新特性Spark讓我們引以為豪的一點就是所創建的API簡單、直觀、便於使用,Spark 2.0延續了這一傳統,併在兩個方面凸顯了優勢: 1、標準的SQL支持; 2、數據框(DataFrame)/Dataset (數據集)API的統一。 在SQL方面,我們已經對Spark的SQL ...
  • 前言 關於資料庫鎖,是一個很重要的知識點; 不少人在開發的時候,應該 很少會註意到 這些鎖的問題,也很少會給程式加鎖(除了 庫存 這些對數量準確性要求極高的情況下); 一般也就聽過常說的樂觀鎖和悲觀鎖,瞭解過基本的含義之後就沒了,沒有去實際的操作過,本文將簡單的整理一下資料庫鎖的知識,希望對大家有所 ...
  • 數據導出時,出現錯誤: 一臉懵逼,百度了下,是導出數量有格式有限制。一開始導出為excel表格式,後改為文本格式,不會報錯。 ...
  • 在in\not in\except這種查詢結構時,如果涉及到的數據量較大,建議堅決用連接left join/inner join等替換掉,否則查詢效率十分低下。 ...
  • 更改表結構: alter TABLE 表1 ALTER COLUMN 列名1 NCHAR(40) ...
  • 一、常用sql 1.1幫助命令 1.2SQL語言分類 1.3普通常用命令 1.4TRUNCATE與DELTE區別 二、備份與恢復 2.1mysqldump進行資料庫備份 2.2備份表 2.3備份資料庫表結構(不包含數據) 2.4備份資料庫表數據(不包含表結構) 2.5同時將數據和表結構分離導出 2. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...