您好,登錄后才能下訂單哦!
本篇內容主要講解“mysql 5.6后熱數據的加載方法是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“mysql 5.6后熱數據的加載方法是什么”吧!
故障現象:在數據庫重啟后,碰巧遇到業務高峰期,連接數滿,導致用戶登錄一直等待,此時數據庫處于無響應狀態.
故障分析:當數據庫重啟后,在數據庫buffer中的熱數據需要innodb本身去預熱.如果buffer太大,依靠innodb自己去預熱,將會有很長一個周期才能實現.此時熱數據就需要到磁盤去尋找,就給磁盤的I/O帶來很大的壓力.遇到瓶頸,就會一直等待,導致數據無響應.
解決方法:5.6版本之前,重啟mysql后,手工把熱數據加載到buffer里面去.如:select count(*) from table_name(熱數據表);
5.6版本之后,提供了一個新特性來快速預熱buffer_pool緩沖池.在my.cnf里面加入幾個參數:#innodb_buffer_pool_load_at_startup = on 默認為關閉OFF。如果開啟該參數,啟動MySQL服務時,MySQL將本地熱數據加載到InnoDB緩沖池中。
#innodb_buffer_pool_load_now =off 默認為關閉OFF。以手動方式加載到InnoDB緩存池中。
#innodb_buffer_pool_filename =ib_buffer_pool 如果開啟InnoDB預熱功能,停止MySQL服務時,MySQL將InnoDB緩沖池中的熱數據保存到數據庫根目錄中,默認文件名ib_buffer_pool.
#innodb_buffer_pool_load_aborr =off 默認為關閉OFF。如果開啟該參數,即便開啟InnoDB預熱功能, MySQL也不會將本地硬盤的熱數據加載到InnoDB緩沖池中。
innodb_buffer_pool_dump_at_shutdown=on #5.7.7以后默認就是on,在數據庫關閉的時候,將熱數據刷新到磁盤
#innodb_buffer_pool_dump_now = off 默認為off,手動將innodb緩沖池中的熱數據導出到磁盤;
#innodb_buffer_pool_dump_pct = 40 默認為關閉OFF。如果開啟該參數,停止MySQL服務時,InnoDB將InnoDB緩沖池中的熱數據的百分比保存到本地硬盤,5.7.6以前是100,5.7.7開始是25,也就是保存緩存中的25%熱數據。
特別說明的是innodb_buffer_pool_load_now和innodb_buffer_pool_dump_now這兩個參數是可以在命令行直接執行的,直接手工導入導出熱數據,可以根據業務環境,自定義執行.如在執行的過程中可以直接執行 innodb_buffer_pool_load_aborr中止;
如: set global innodb_buffer_pool_load_now=1;--直接加載熱數據;
set global innodb_buffer_pool_load_aborr=1;---中止加載;
在關閉mysql時,會把內存中的熱數據保存在磁盤的ib_buffer_pool文件中,該文件位于數據目錄下.
ps:只有正常關閉mysql服務,或者pkill mysql時,才會把熱數據導出到磁盤.機器宕機或者pkill -9 mysql,是不會導出的.
到此,相信大家對“mysql 5.6后熱數據的加載方法是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。