手把手介紹如何在 Google Platform 上面建立 Windows Server 容錯移轉叢集並達到IIS Web Application HA 的效果。此篇為下集從叢集容錯管理設定到如何在 GCP 中達成 IIS 的請求移轉。
本篇架構參考 Google 官方文件的 Running Windows Server Failover Clustering。主要針對整體操作完整的手把手教學並針對細節描述。而針對讀者在閱讀上更能融入整體教學,稍微調整了原文的順序。
在上篇已建置完 GCP 主機並加入至 AD 內做管理,這邊將接手完成叢集容錯的安裝與設定
Setting up failover clustering
接著在 wsfc-1 與 wsfc-2 完成以下動作
- 遠端登入主機
- 安裝 Failover Clustering*,安裝時要用 *WSFC.TEST\clusteruser 進行操作,不然會無法完成安裝。這邊要注意不用安裝該功能在 wsfc-dc 主機上。
- 將 wsfc-1 與 wsfc-2 設為叢集內的節點(node)
- 透過驗證步驟就可以知道當前設定是否正確,並透過 Create the cluster now using the validated nodes 這個按鈕即可立即為當前驗測過的步驟建立叢集。
- 在 Create Cluster Wizard 中的 Access point 內設定叢集名稱為 testcluster
- 將位置設定為 10.0.0.8
首先完成 Failover Clustering 安裝:
data:image/s3,"s3://crabby-images/c0557/c05575ff2faab094f6d98c30a13d01c0e349767f" alt="Image 061.jpg"
接著開始加入節點:
data:image/s3,"s3://crabby-images/5fbd3/5fbd3a132041291068e73792ea8ff3741cb9bfa4" alt="Image 062.jpg"
data:image/s3,"s3://crabby-images/a2fba/a2fbae5ce16658c7b49342dfb822c02ce2eebd25" alt="Image 063.jpg"
data:image/s3,"s3://crabby-images/20989/209899e82791ccd15731010b81cb21b9bfffbe5a" alt="Image 064.jpg"
data:image/s3,"s3://crabby-images/5630a/5630a5a553e6669698706baea37a3a37bf19509c" alt="Image 065.jpg"
data:image/s3,"s3://crabby-images/c0ae3/c0ae3594990a521d3ecdd65c6cbe17d4189bbf43" alt="Image 066.jpg"
data:image/s3,"s3://crabby-images/29058/290586d1a777869adfe09c254ebdd5fe5284594d" alt="Image 068.jpg"
data:image/s3,"s3://crabby-images/3a541/3a5410c8243bfed886e9f72ef05e16c58df9091b" alt="Image 069.jpg"
完成後即可看到當前節點出現兩台新增的主機與當前配置狀態(Assigned Vote 與 Current Vote):
data:image/s3,"s3://crabby-images/3891b/3891b9b90e39f51885a8e20c2a35bdb9fb4d0fc5" alt="Image 067.jpg"
詳細步驟可以參考微軟官方的 Create a Failover Cluster
Creating the file share witness
而當成將兩台主機都加入叢集內作為可使用節點時,我們需要透過一個公平的投票機制選出誰為當前主要運作節點接手服務處理,為此我們需要建立一個 quorum 制度來做仲裁。
這部分很簡單的透過一個sharefolder的方式來傳給 AD ,告知當前哪一台主機離線則需要將判斷是否要將工作交給另外一台接手。 GCP 目前是相信可透過 Live Migration 與 automatic restart 來提供可信賴的 Share Witness 服務。
這邊透過以下步驟可以透過檔案分享建立起見證機制來控制當前叢集處理的角色分配:
建立檔案分享路徑
- 遠端連線進入 wsfc-dc
- 設定檔案分享的資料於該台主機上 C:\shares\ ,透過滑鼠右鍵選擇分享。
- 分享成功後並在裡面再建立一個資料夾 clusterwitness-testcluster
data:image/s3,"s3://crabby-images/37d4f/37d4fdb4d305f02b349f03e5d7b80c45672ce9db" alt="Image 072.jpg"
data:image/s3,"s3://crabby-images/2d7f1/2d7f1e905b6d15b28349fbe6eb7d2d235bb13710" alt="Image 073.jpg"
data:image/s3,"s3://crabby-images/e8fbe/e8fbe513ddab16dd7795668f437b65cc8f3cd8dc" alt="Image 074.jpg"
data:image/s3,"s3://crabby-images/1d6ff/1d6ff224659e334940587566ad6a5c3f9c4f56b8" alt="Image 075.jpg"
data:image/s3,"s3://crabby-images/046d4/046d4124eeb027f2daa9a5ddc946e91ba0ad2ba6" alt="Image 071.jpg"
在叢集容錯處理中加入見證判斷的分享檔案配置
- 在叢集節點上的 wsfc-1 或 wsfc-2, 開啟 Failover Cluster Manager.
- 於左側用滑鼠右鍵點選當前叢集 (testcluster.WSFC.TEST) 並移動至 More Actions 並點選 Configure Cluster Quorum Settings.
- 接著透過設定精靈,一步步按下一步確認.
- 當設定 quorum configuration option, 選擇 quorum witness 並選擇 Configure a file share witness.
- 在路徑上選擇剛剛設定好的分享路徑(即可 “\10.0.0.6\clusterwitness-testcluster”). 這裡 10.0.0.6 的 IP 就是 wsfc-dc VM所設定配置的.
- 按下確認完成所有配置
data:image/s3,"s3://crabby-images/14c06/14c06a2cfcf1ba4441f7886edbf1725e987e42e6" alt="Image 076.jpg"
data:image/s3,"s3://crabby-images/3af6c/3af6cf7044485ef948699d8ab6871acecbd89aae" alt="Image 077.jpg"
data:image/s3,"s3://crabby-images/4b857/4b8573305608d490972d67e086651a274e8e5caf" alt="Image 078.jpg"
data:image/s3,"s3://crabby-images/8d444/8d4446927979fd463f61ac99655e2b6041a7c61e" alt="Image 079.jpg"
data:image/s3,"s3://crabby-images/578cf/578cf8a954477a84ecb397dcd3e52c1018746292" alt="Image 080.jpg"
data:image/s3,"s3://crabby-images/c709b/c709b8fb26ea80ed4fa5ec6e09bb1dc70d07ad9d" alt="Image 081.jpg"
data:image/s3,"s3://crabby-images/fd9c0/fd9c0e07a8bb5318880008190180686a2f70ebca" alt="Image 082.jpg"
data:image/s3,"s3://crabby-images/9308b/9308bfc9abef84d7ad4e0652c0d7d435a10a1e91" alt="Image 083.jpg"
Testing the failover cluster
到目前為止的配置已經成功完成了叢集處理的設定,這邊我們可以手動測試一下當前配置是否生效。
在 wsfc-1 與 wsfc-2 以 clusteruser 身分運行 Windows PowerShell
在 PowerShell 輸入下方指令
Move-ClusterGroup -Name "Cluster Group"
如果看到以下畫面則代表設定成功:
data:image/s3,"s3://crabby-images/d1d80/d1d8005f45c52e5d1c78121dd2d18684aca2d702" alt="Image 085.jpg"
data:image/s3,"s3://crabby-images/eb64b/eb64bcb92a915fc67d0efb6e0a294bafa8932653" alt="Image 084.jpg"
Adding a role For IIS
接著開始針對叢集處理新增一個角色,該角色負責處裡 IIS 的工昨指派:
- 在 Failover Cluster Manager 的 Actions 中選擇 Configure Role.
- 在 Select Role 頁面中選擇 Other Server.
- 在 Client Access Point 頁面中輸入 “IIS”.
- 設定分配進入的 IP 為 “10.0.0.9”.
- 跳過 Select Storage 與 Select Resource Types.
- 確定當前配置並完成新增.
data:image/s3,"s3://crabby-images/f9b9f/f9b9f19a01ffe954c34a78e00e7836e09106bbb5" alt="Image 086.jpg"
data:image/s3,"s3://crabby-images/55cf8/55cf8de738cb3bb3dc2ae23c63d26ce4e4f409e3" alt="Image 087.jpg"
data:image/s3,"s3://crabby-images/4e5a5/4e5a53a6feab81e53afc155d7db7f70926bd1e14" alt="Image 088.jpg"
data:image/s3,"s3://crabby-images/e1a53/e1a53172fa31a7fdaa47c2cc136cd26eb8a9311f" alt="Image 089.jpg"
Creating the internal load balancer
接著必須回去 Google Cloud Platform 上面建立一個內部使用的 Load Balancer 處理剛剛配置的 10.0.0.9 成為一個請求入口與後面分流。這邊配置分為前端(frotnend)負責處理進入的請求與後端(backend)負責處理真實請求的機器配置,設定時請記得同時配置才可使整體生效:
- 進入 GCP Console 並前往 Load balancing 頁面. OPEN LOAD BALANCING
- 選擇建立一個新的 Load Balancer.
- 選擇 TCP Load Balancing card 並選 Only between my VMs ,最後設定名稱為 wsfc-lb.
data:image/s3,"s3://crabby-images/01787/01787c3976490051ede54a80163f63fb063cc3f1" alt="Image 090.jpg"
data:image/s3,"s3://crabby-images/232a7/232a7c0b5c253fff94a74aacc3cc6dfa7c539b9b" alt="Image 091.jpg"
data:image/s3,"s3://crabby-images/637cb/637cb1d677fdc1074922f39a5a9cb4433f27030d" alt="Image 092.jpg"
到此先別按下建立,我們需要切換至 Backend 區域給予其相關設定值。
配置 Backend
- 點選 Backend configuration.
- 選擇 Region.
- 選擇 wsfcnet.
- 選擇 wsfc-group 並建立 新的 health check.
- 名稱處輸入 wsfc-hc.
- 設定預設 cluster host agent 的回應接口 port 為 59998.
- 設定 Request, 輸入 10.0.0.9.
- 設定 Response, 輸入 1.
- 設定 Check interval, 輸入 2.
- 設定 Timeout 輸入 1.
data:image/s3,"s3://crabby-images/70690/70690c8d0905931252ceac9df69282fdd5f9e7eb" alt="Image 093.jpg"
data:image/s3,"s3://crabby-images/55dd9/55dd9d64ec268da0806990404ed2e0668ce2ee07" alt="Image 094.jpg"
data:image/s3,"s3://crabby-images/3c196/3c19666f5af553dba3a3b0d6353664bcf9323f0d" alt="Image 095.jpg"
儲存以上設定後繼續 frontend 配置。
配置 frontend
- 點選 Frontend configuration.
- 設定名稱 Name, 輸入 wsfc-lb-fe.
- 選擇 subnetwork (wsfcnetsub1).
- 設定 IP, 選擇 Ephemeral (Custom) 並輸入 10.0.0.9.
- 設定 Ports, 輸入 80.
- 點選完成.
data:image/s3,"s3://crabby-images/97d70/97d70658c0aa156f7a2db63eabb6a05e1e9ed3e6" alt="Image 096.jpg"
重新檢視全部設定並完成配置
在完成前可以再確認一下當前配置是否無誤:
data:image/s3,"s3://crabby-images/f5b4a/f5b4af29aea5d1999b34a10f1ecb4870e5a742ea" alt="Image 097.jpg"
Create firewall rules for the health check
這邊要注意的是,後端配置上的主機必須要在 OS 防火牆內開啟相對的 port 號,否則無法生效。目前的配置為:
cluster node (wsfc-1 and wsfc-2) 必須允許 inbound 可透過 TCP connections 來接收至 59998 Port 的訊息.
data:image/s3,"s3://crabby-images/306ba/306ba0afa03b9d77dab516ad42eec55d268a6a86" alt="Image 098.jpg"
data:image/s3,"s3://crabby-images/7807d/7807de95ffa15a6ecbe4d82a86b621f97948d465" alt="Image 099.jpg"
data:image/s3,"s3://crabby-images/c8745/c87450102e8e35ce0d5e17a9c0152f1f5eaf9a76" alt="Image 100.jpg"
data:image/s3,"s3://crabby-images/234e7/234e7ed5b0f04ca4aac55fb2f8c40975f009cd14" alt="Image 101.jpg"
data:image/s3,"s3://crabby-images/c96ef/c96efc787ab1ebb380f5fd7128c0782f5ed72516" alt="Image 102.jpg"
透過 Cloud Shell 我們可以為當前的 Load Balancer 建立 Heathy Check 的機制來確認服務正常運行:
gcloud compute firewall-rules create allow-health-check --network wsfcnet --source-ranges 130.211.0.0/22,35.191.0.0/16 --allow tcp:59998
data:image/s3,"s3://crabby-images/4ce9c/4ce9c10199cdab2b53837db5559ca364f3401741" alt="Image 103.jpg"
Validating the load balancer
目前的主機叢集的容錯檢查已經建立了,我們可以看到整個 GCP Load Balancing 服務當前只有一個 cluster-node 會是啟動的:
data:image/s3,"s3://crabby-images/def81/def819b6d6a7ed304ce2881d6c5cd15163b7e94e" alt="Image 104.jpg"
如果要進行測試,可以前往 Failover Cluster Manager 將其當下的 IIS Role 透過滑鼠右鍵選擇 Move*,再點選 *Best Possible Node 即可看到 Owner Node 在進行切換:
data:image/s3,"s3://crabby-images/ad2b2/ad2b28b6803accdb8986fd82e487fcb4052a3fc8" alt="Image 105.jpg"
data:image/s3,"s3://crabby-images/f0d9c/f0d9cfde4db4e67f322703b3bd4194df5734fd82" alt="Image 106.jpg"
data:image/s3,"s3://crabby-images/4af4a/4af4aa7e561befcb578e15e144f75b24719d7dcf" alt="Image 107.jpg"
以上這個測試是模擬原先運作節點發生問題由叢集判斷需要其他節點接手時所會發生的行為。由此可以看到網站已經快速地將其從有問題的節點導入至其他正常運作的節點接手請求(request)的處理。
我們也可以透過 Cloud Shell 下面的指令進行確認:
gcloud compute backend-services get-health wsfc-lb --region=[REGION]
data:image/s3,"s3://crabby-images/b663d/b663d1f1ee59b04e2ecd7f97057fab57a7727948" alt="Image 108.jpg"
接下來我們就只需要將兩台 cluster-node 安裝好 IIS 並啟動對應的網頁應用程式即可。
Installing your application
這邊我們從 Add Roles and Features Wizard 可以快速地建立 IIS 服務與其角色:
data:image/s3,"s3://crabby-images/357a2/357a2ea5d4064a3b1dd95de7c77a664aef2ec701" alt="Image 109.jpg"
data:image/s3,"s3://crabby-images/0e190/0e19002e6d181a0f3ffcecc69109a735028b1bc7" alt="Image 110.jpg"
這邊我們建立一個簡單的網頁應用程式並將 IP 顯示在網頁上面:
data:image/s3,"s3://crabby-images/e63a4/e63a4dcf3915e13a9a31a0ebbfaef021ac0b2d45" alt="Image 111.jpg"
從 wsfc-1 本機檢查:
data:image/s3,"s3://crabby-images/0e8a1/0e8a1b6045ef5944250a679f4f7f2f8bc64c895f" alt="Image 112.jpg"
同樣的步驟我們也安裝在 wsfc-2 ,並從本機檢查:
data:image/s3,"s3://crabby-images/2cc25/2cc25452a445739920bbc4d636a43a29b43b32ae" alt="Image 113.jpg"
而當配置都完成後我們從 wsfc-dc 去找 10.0.0.9 (即我們區網內的 Load Balancer) 則可以看到出現的網頁是當前 Owner Cluster-Node 的頁面,即 wsfc-2:
data:image/s3,"s3://crabby-images/0115b/0115b152457a1a108234c326920edcf00f6efea1" alt="Image 114.jpg"
data:image/s3,"s3://crabby-images/ca108/ca108b121a2076a0174caedef458abc97961faa2" alt="Image 115.jpg"
到此,我們的設定教學已經完全結束。
Costs
接下來讓我們看一下花費:
data:image/s3,"s3://crabby-images/0ae90/0ae9070be6622b139d122205539dfefc1cd205ff" alt="Image 116.jpg"
data:image/s3,"s3://crabby-images/b2ec6/b2ec629df0abe76317e48e6224ae8594bd0b026d" alt="Image 117.jpg"
這個 POC 專案總共開了五天(5/27-5/31),一天約 $10 美金的花費。開銷多半是花費在 Windows 的 VM 比較貴….
最後提醒大家記得要將已經不用的專案測底刪除避免 Comupted Engine 持續對你的 GCP 帳戶扣款…如何清除當前這個 POC 則參考原文的Cleaning up步驟吧
結語
整個範例其實展示的結果很簡單但對於企業內部再使用雲端服務的幫助則是非常大的,以往要自行建立這樣的叢集容錯機制是具有相當大的難度與複雜度,但如今透過 GCP 的指令與 Windows UI 上面的設定精靈,我們可以很快速地完成相關設定,提供網頁應用程式更好的高可用性(High availability)。
而這個機制也不只用於內網,其實對外公開網站也可以用其方法建立叢集處理提供更佳的可用性!