用MySQL實例管理器來啟動服務器。
創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設、高性價比江城網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式江城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設找我們,業(yè)務覆蓋江城地區(qū)。費用合理售后完善,10余年實體公司更值得信賴。
在這種情況下,Instance Manager的行為取決于MySQL配置文件中的選項。如果沒有配置文件,MySQL實例管理器創(chuàng)建mysqld實例并試圖用默認(編譯嵌入的)配置來啟動。這說明如果mysqld沒有安裝到 默認位置,IM不能猜出它的位置。如果你已經(jīng)在非標準位置安裝了MySQL服務器,你應使用配置文件。參見2.1.5節(jié),“安裝布局”。
如果有配置文件,IM將分析配置文件搜索[mysqld]部分(例如[mysqld]、[mysqld1]、[mysqld2]等)。每個部分指定一個實例。啟動時IM將啟動所有找到的實例。IM關閉時默認停止所有實例。
請注意有一個特殊選項mysqld-path(mysqld-path = path-to-mysqld- binary),只能用IM識別。使用該變量讓IM知道m(xù)ysqld二進制駐留在哪兒。你還應該為服務器設置basedir和datadir選項。
啟用MySQL實例管理器的典型MySQL服務器啟動/關閉循環(huán)為:
· 用/etc/init.d/mysql腳本啟動MySQL實例管理器。
· MySQL實例管理器啟動所有實例并監(jiān)視它們。
· 如果某個服務器實例失敗,MySQL實例管理器重啟它。
· 如果MySQL實例管理器被關閉(例如用/etc/init.d/mysql stop命令),所有實例被MySQL實例管理器關閉。
大多情況下,需要可靠而有效地克隆 MySQL 實例數(shù)據(jù)。這包括 MySQL 高可用的解決方案,其中需要在將實例加入組復制集群之前配置實例,或者在經(jīng)典復制模型中將其添加為 Slave。
為復制拓撲而創(chuàng)建 MySQL 副本一直很麻煩。涉及的步驟很多,首先要備份 MySQL 服務器,通過網(wǎng)絡將備份傳輸?shù)轿覀兿胍砑拥綇椭萍男?MySQL 節(jié)點,然后在該節(jié)點上恢復備份并手動啟動 MySQL 服務器。為了高可用,最好還要將其正確設置備份的 GTID,并啟動并運行群集。涉及的手動步驟數(shù)量過多不利于高可用。CLONE 插件解決了這個問題并簡化了副本配置。使您可以使用 MySQL 客戶端(和 SQL 命令)來配置新節(jié)點并在發(fā)生時觀察克隆進度。無需手動處理多個步驟并維護自己的基礎架構來配置新的 MySQL 節(jié)點。
MySQL 8.0.17 引入了 CLONE SQL 語句,使當前的 MySQL 服務器成為另一個運行在不同節(jié)點的 MySQL 服務器的“克隆”。我們將執(zhí)行 clone 語句的服務器實例稱為“受體”??寺〉脑捶掌鲗嵗Q為“供體”。供體克隆以一致的快照存儲在 InnoDB 存儲引擎中的所有數(shù)據(jù)和元數(shù)據(jù),以替換受體中的數(shù)據(jù)。
成功執(zhí)行 CLONE SQL 語句后,將自動重新啟動受體服務器。重新啟動涉及恢復克隆的快照數(shù)據(jù),就像用老方法復制數(shù)據(jù)一樣?;謴屯瓿珊?,受體就是供體的克隆版,隨時可以使用!
這里有一些關于克隆過程的重要注意事項。
不克隆 MySQL 配置參數(shù),并且受體保留所有原始配置參數(shù),如克隆之前。這樣做是因為許多配置可能特定于節(jié)點(例如 PORT),因此保留它們似乎是一個不錯的選擇。另一方面,一些存儲配置確實需要在供體和受體之間匹配(例如 innodbpagesize),如果這樣的配置參數(shù)不匹配,CLONE 將報告錯誤。
CLONE?插件不會克隆二進制日志。
CLONE?插件目前僅支持 InnoDB 存儲引擎。在其他存儲引擎(如 MyISAM 和 CSV)中創(chuàng)建的表將被克隆為空表??寺』A架構的設計允許克隆 MySQL 支持的任何存儲引擎。但是,只有 InnoDB 序列化和反序列化方法已經(jīng)實現(xiàn)并經(jīng)過測試。
克隆會阻止供體中的所有并發(fā) DDL。
需要注意的事實是受體放棄所有數(shù)據(jù)以及任何二進制日志,以便成為供體實例的克隆。在執(zhí)行 CLONE 之前,如果認為有必要,需要備份當前受體數(shù)據(jù)。
MySQL 5.5引入了緩沖實例作為減小內部鎖爭用來提高MySQL吞吐量的手段。在5.5版本這個對提升吞吐量幫助很小,然后在MySQL 5.6版本這個提升就非常大了,所以在MySQL5.5中你可能會保守地設置innodb_buffer_pool_instances=4,在MySQL 5.6和5.7中你可以設置為8-16個緩沖池實例。設置后觀察會覺得性能提高不大,但在大多數(shù)高負載情況下,它應該會有不錯的表現(xiàn)。對了,不要指望這個設置能減少你單個查詢的響應時間。這個是在高并發(fā)負載的服務器上才看得出區(qū)別。比如多個線程同時做許多事情。
5.7、8.0 下INNODB_BUFFER_POOL_INSTANCES默認為1,若mysql存在高并發(fā)和高負載訪問,設置為1則會造成大量線程對BUFFER_POOL的單實例互斥鎖競爭,這樣會消耗一定量的性能的。
pool_instances 可以設置為cpu核心數(shù),它的作用是:
1)對于緩沖池在數(shù)千兆字節(jié)范圍內的系統(tǒng),通過減少爭用不同線程對緩存頁面進行讀寫的爭用,將緩沖池劃分為多個單獨的實例可以提高并發(fā)性??梢灶惐葹?java中的 ThreadLocal 線程本地變量 就是為每個線程維護一個buffer pool實例,這樣就不用去爭用同一個實例了。相當于減少高并發(fā)下mysql對INNODB_BUFFER緩沖池的爭用。
2)使用散列函數(shù)將存儲在緩沖池中或從緩沖池讀取的每個頁面隨機分配給其中一個緩沖池實例。每個緩沖池管理自己的空閑列表, 刷新列表, LRU和連接到緩沖池的所有其他數(shù)據(jù)結構,并受其自己的緩沖池互斥量保護。