搜尋
首頁資料庫mysql教程聊聊為什麼不要依賴MySQL高可用性來維護

聊聊為什麼不要依賴MySQL高可用性來維護

在企業環境中的停機成本迅速增加。在一項調查中,40% 的受訪者表示,僅僅一個小時的停機就使得他們的組織損失了 100 萬美金以上。確保資料庫服務持續可用顯然是值得的。

它為你的組織節省了大量資金,更不用說與各種形式和規模的利害關係人的關係。

那麼你如何確保持續可用性?持續可用性背後的概念稱為 高可用性 。在本文中,我們將概述什麼是高可用性以及如何為你的 MySQL 叢集實現高可用。

我們也指出高可用性的黑暗一面,即使系統管理員錯誤地依賴高可用性來執行維護任務 - 並解釋為什麼這麼做會破壞高可用性的目標,使你的企業運營面臨風險。

1. 高可用性介紹


讓我們先來談談可用性。如果一個服務(如資料庫)在大多數時間內對使用者是不可用的,那麼運行它就沒什麼意義了。因此當我們談論可用性時,我們是指服務的可訪問程度。

對於任何正常運行的服務,人們有理由期待它總是在被需要時是可用的- 但是也會有一些停機時間,一年中有一兩天,或者每月有幾個小時。

一個普遍的可用的服務對於許多用例場景來說可能是很好的,但是如果服務本質上是至關重要的,或者大量用戶依賴與一個服務,僅僅依靠「可用性」是不夠的。

這就是高可用性的意義所在。在最基本的條件下,高可用性確保比通常預期的水平更高的可用性,更具體的說,在允許維護、修補和一般錯誤以及故障的情況下,也能達到約定的水平。

2. 什麼等級的可用性是高可用性?


對於什麼是高可用性還沒有達成一致的定義,只是為了滿足特定的(更高的)可用性需求,它通常超過被護接受的「可用性」。事實上,你的組織可能會根據營運的需求來定義所需的可用性 - 權衡高可用性的成本與停機相關的損失的成本。

你需要的可用性等級可以用百分比來表示。例如 99.99% 或「4 個 9」的可用性意味著一年中最多有 52.06 分鐘的停機時間,而「6 個 9」或 99.9999% 的可用性則限制一年有 31.56 分鐘的停機時間。

從本質上來說,選擇權在你手上 - 但是,同樣,這也是一種權衡。維持高可用性的成本將是昂貴的 - 需要額外的實體資源和軟體許可,並耗費你的人力資源。但是,你可能會發現這是一個值得付出的代價,為了避免中斷帶來的連鎖成本,或是因客戶不滿意而損失收入的風險。

3. 高可用性在實務上是如何運作的?


你的高可用性基礎架構的確切性質取決於你的工作負載。然而,從廣義上來講,當有容錯性時,就可以實現高可用性,這樣即使一個服務或設備出現故障,工作負載也不會中斷。通常情況下,這意為著沒有單點故障 - 所有服務和設備都在網路和應用層級是完全冗餘的。

根據服務的不同,這通常可能涉及一些節點 - 例如,你的 MySQL 叢集將多包含幾個節點,資料儲存在這上面。然後將多個節點和負載平衡工具結合,這樣如果一個節點失敗,請求將被引導發送到另一個節點。用戶仍然可以存取可用的服務,即使效能稍微下降。

4. 在 MySQL 中設定高可用性


當然,你通往高可用 MySQL 資料庫的途徑將取決於你對 MySQL 的實作。概括的說,你需要創建具有多個節點的某種類型的 MySQL 叢集 - 換句話說,你的資料必須是儲存在多個 MySQL 伺服器上。

接下來,你需要一個可以在這些節點上複製資料的服務,確保每個節點都有你的資料庫中包含的資料的精確備份。最後,你需要一個負載平衡器,確保任何資料庫請求被均勻地引導到資料庫節點 - 是的, 一個平衡負載 - 但是請確保即使有一個節點離線,請求也能得到滿足。

例如, MySQL 提供了一個高可用的商業產品 - Te MySQL InnoDB Cluster. 。它基於 MySQL 群組複製,這是確保 MySQL 資料庫環境中高可用性的一種流行的方式。

另一個替代的選擇是 Galera ,它多年來一直提供 MySQL 高可用性。如果你使用的是 MySQL 的 MariaDB 分支,你可以透過你用 Galera 叢集運行多個節點來配置 MariaDB 環境的高可用性  - 同時依靠 HAProxy 進行負載平衡。另外,你也可以研究一下 MariaDB 自己的
MaxScale 產品。

5. 依賴高可用性好的理由…


企業規模的工作負載越來越多地使用高可用性原則,因為從長遠來看,它提供了最好的結果。以下是你應該考慮在你的操作中設定高可用性的幾個好的理由:

  • 極其重要的應用. 有些應用程式根本無法承受任何停機時間,想一想軍事應用或能源網路。在這些情況下,高可用性是必須的,你沒有什麼選擇,只能確保極高的可用性 - 儘管你可以做風險評估,並決定你到底需要多大的高可用性保證。
  • 連鎖效應. 如果系統是一個工作負載的核心,即使短暫的停機也會導致廣泛的問題,因為連接和同步的系統將會連帶失敗。值得考慮在幾個核心的領域投入高可用性 - 如資料庫 - 因為考慮到可能很難恢復的更大連帶問題的成本,這可能是值得的。
  • 收入損失. 高可用性,即使是數量不多的 9 ,也可以防止收入損失。對於一個主要的線上零售商來說,僅僅幾個小時的銷售損失,加上相關名譽損失,就會對底線產生非常重要的影響。
  • 客戶的期望和服務等級協定. 你的業務操作可能會受到服務等級協定的約束,保證你的客戶端有一定的正常運作時間。如果是這種情況,你需要確保你的客戶端工作負載的服務具有正常運行時間的水平 - 你將透過高可用性來實現。如果做不到這一點會導致合約的終止,或根據你的合約進行賠償懲罰。

這是高可用性的幾個好的有效理由 - 而且,這今天這個技術至上的世界裡,有許多工作負載在沒有高可用性平台的情況下根本無法運行。

6. … 和依賴高可用性錯誤的理由


不幸的是,高可用的日益盛行導致了它的濫用。因為高可用性使得系統變得異常健壯,技術團隊在執行系統管理任務的時候(如打補丁)可能會傾向走捷徑,因為那些團隊認為高可用性基礎設施將會簡單承擔一台機器脫機的負擔。

實際上,它很快就會變得更加複雜。以 MySQL 叢集為例。是的,如果你重啟一台機器給它打補丁,由於高可用性,你的 MySQL 叢集將繼續運作。但是,請記住,當你為了打補丁而關閉一個節點,然後重新啟動它時,會導致需要輸入的資料積壓。這個過程可能需要花費長時間才能完成。

不用說,每個資料庫主機都需要看到相同的資料。危險來自於重新同步的過程:如果在你已經關閉的一個節點並對其打補丁的情況下,另一個節點出現故障,這可能導致失去最終有效的法定人數。換句話說,保存關於資料「真相」的伺服器數量可能低於可接受的水平。從這種狀態下恢復可能是困難和複雜的,甚至可能導致資料遺失。

7. 不要依賴高可用性進行維護


#高可用性是為了在故障時保證系統的正常運作。這種針對故障的固有保護並不是一個免費通行證,可以依賴高可用性的健壯,以不負責的方式執行的系統維護,並沒有人會注意到它。

相反,技術團隊應該依靠其他解決方案 - 例如,為正在打補丁的系統設置完全的冗餘,而不是簡單地希望高可用性基礎設施能夠來抵擋壓力。或者,在可能的情況下,依靠即時打補丁的方式來取代,透過這樣的做來消除需要重新啟動服務來安裝修補程式的效果。

儘管如此,依賴高可用性進行維護工作的顯示出令人擔憂的跡象。仔細觀察一下,你甚至會發現供應商的官方指導,指示用戶依靠高可用性來執行打補丁的任務,用戶只需希望在一個節點離線打補丁時,其他節點不要出現任何問題。

8. 結束


高可用性對於許多應用來說都至關重要 - 對於許多其他應用來說也是十分有益。配置正確, MySQL 資料庫可以提供幾乎完美的可用性,但這並不意味著技術團隊可以把可用性視為理所當然。

濫用高可用性架構來維護走捷徑是不可取的 - 風險比乍看之下更大。

相反,系統管理員應該尋找可以久經考驗的替代方案 - 包括冗餘和即時修補程式 - 來執行維護操作,而不傷害高可用性解決方案的能力。

原文網址:https://tuxcare.com/understanding-mysql-high-availability-good-and-bad-reasons-to-use-it/

譯文地址:https://learnku.com/mysql/t/71681

【相關推薦:mysql影片教學

以上是聊聊為什麼不要依賴MySQL高可用性來維護的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
MySQL:世界上最受歡迎的數據庫的簡介MySQL:世界上最受歡迎的數據庫的簡介Apr 12, 2025 am 12:18 AM

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

MySQL的重要性:數據存儲和管理MySQL的重要性:數據存儲和管理Apr 12, 2025 am 12:18 AM

MySQL是一個開源的關係型數據庫管理系統,適用於數據存儲、管理、查詢和安全。 1.它支持多種操作系統,廣泛應用於Web應用等領域。 2.通過客戶端-服務器架構和不同存儲引擎,MySQL高效處理數據。 3.基本用法包括創建數據庫和表,插入、查詢和更新數據。 4.高級用法涉及復雜查詢和存儲過程。 5.常見錯誤可通過EXPLAIN語句調試。 6.性能優化包括合理使用索引和優化查詢語句。

為什麼要使用mysql?利益和優勢為什麼要使用mysql?利益和優勢Apr 12, 2025 am 12:17 AM

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

描述InnoDB鎖定機制(共享鎖,獨家鎖,意向鎖,記錄鎖,間隙鎖,下一鍵鎖)。描述InnoDB鎖定機制(共享鎖,獨家鎖,意向鎖,記錄鎖,間隙鎖,下一鍵鎖)。Apr 12, 2025 am 12:16 AM

InnoDB的鎖機制包括共享鎖、排他鎖、意向鎖、記錄鎖、間隙鎖和下一個鍵鎖。 1.共享鎖允許事務讀取數據而不阻止其他事務讀取。 2.排他鎖阻止其他事務讀取和修改數據。 3.意向鎖優化鎖效率。 4.記錄鎖鎖定索引記錄。 5.間隙鎖鎖定索引記錄間隙。 6.下一個鍵鎖是記錄鎖和間隙鎖的組合,確保數據一致性。

MySQL查詢性能差的常見原因是什麼?MySQL查詢性能差的常見原因是什麼?Apr 12, 2025 am 12:11 AM

MySQL查询性能不佳的原因主要包括没有使用索引、查询优化器选择错误的执行计划、表设计不合理、数据量过大和锁竞争。1.没有索引导致查询缓慢,添加索引后可显著提升性能。2.使用EXPLAIN命令可以分析查询计划,找出优化器错误。3.重构表结构和优化JOIN条件可改善表设计问题。4.数据量大时,采用分区和分表策略。5.高并发环境下,优化事务和锁策略可减少锁竞争。

您什麼時候應該使用複合索引與多個單列索引?您什麼時候應該使用複合索引與多個單列索引?Apr 11, 2025 am 12:06 AM

在數據庫優化中,應根據查詢需求選擇索引策略:1.當查詢涉及多個列且條件順序固定時,使用複合索引;2.當查詢涉及多個列但條件順序不固定時,使用多個單列索引。複合索引適用於優化多列查詢,單列索引則適合單列查詢。

如何識別和優化MySQL中的慢速查詢? (慢查詢日誌,performance_schema)如何識別和優化MySQL中的慢速查詢? (慢查詢日誌,performance_schema)Apr 10, 2025 am 09:36 AM

要優化MySQL慢查詢,需使用slowquerylog和performance_schema:1.啟用slowquerylog並設置閾值,記錄慢查詢;2.利用performance_schema分析查詢執行細節,找出性能瓶頸並優化。

MySQL和SQL:開發人員的基本技能MySQL和SQL:開發人員的基本技能Apr 10, 2025 am 09:30 AM

MySQL和SQL是開發者必備技能。 1.MySQL是開源的關係型數據庫管理系統,SQL是用於管理和操作數據庫的標準語言。 2.MySQL通過高效的數據存儲和檢索功能支持多種存儲引擎,SQL通過簡單語句完成複雜數據操作。 3.使用示例包括基本查詢和高級查詢,如按條件過濾和排序。 4.常見錯誤包括語法錯誤和性能問題,可通過檢查SQL語句和使用EXPLAIN命令優化。 5.性能優化技巧包括使用索引、避免全表掃描、優化JOIN操作和提升代碼可讀性。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器