本篇內容主要講解“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后熱數據的加載方法是什么”有了更深的了解,不妨來實際操作一番吧!這里是創新互聯網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
網頁標題:mysql5.6后熱數據的加載方法是什么
URL網址:http://m.2m8n56k.cn/article30/jdsgso.html
成都網站建設公司_創新互聯,為您提供電子商務、網站內鏈、自適應網站、ChatGPT、標簽優化、企業建站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯