新安裝的MySQL必須調整的10項配置
還在為新安裝的mysql服務,不知道修改哪些預設配置而發愁嗎?mysql可調整引數有100多個,到底要立即!馬上!調整哪些最重要的引數?
這篇文章主要介紹了MySQL最佳化必須調整的10項配置,使用這些方法可以讓你快速地獲得一個穩健的MySQL配置,需要的朋友可以參考下:
當我們被人僱來監測MySQL效能時,人們希望我們能夠檢視一下MySQL配置然後給出一些提高建議。許多人在事後都非常驚訝,因為我們建議他們僅僅改動幾個設定,即使是這裡有好幾百個配置項。這篇文章的目的在於給你一份非常重要的配置項清單。
我們曾在幾年前在部落格裡給出了這樣的建議,但是MySQL的世界變化實在太快了!
寫在開始前…
即使是經驗老道的人也會犯錯,會引起很多麻煩。所以在盲目的運用這些推薦之前,請記住下面的內容:
一次只改變一個設定!這是測試改變是否有益的唯一方法。
大多數配置能在執行時使用SET GLOBAL改變。這是非常便捷的方法它能使你在出問題後快速撤銷變更。但是,要永久生效你需要在配置檔案裡做出改動。
一個變更即使重啟了MySQL也沒起作用?
請確定你使用了正確的配置檔案。請確定你把配置放在了正確的區域內(所有這篇文章提到的配置都屬於 [mysqld])
伺服器在改動一個配置後啟不來了:請確定你使用了正確的單位。
例如,innodb_buffer_pool_size的單位是MB而max_connection是沒有單位的。
不要在一個配置檔案裡出現重複的配置項。如果你想追蹤改動,請使用版本控制。
不要用天真的計算方法,例如”現在我的伺服器的記憶體是之前的2倍,所以我得把所有數值都改成之前的2倍“。
一、?基本配置
你需要經常察看以下3個配置項。不然,可能很快就會出問題。
innodb_buffer_pool_size:
這是你安裝完InnoDB後第一個應該設定的選項。
緩衝池是資料和索引快取的地方:這個值越大越好,這能保證你在大多數的讀取操作時使用的是記憶體而不是硬碟。典型的值是5-6GB(8GB記憶體),20-25GB(32GB記憶體),100-120GB(128GB記憶體)。
innodb_log_file_size:
這是redo日誌的大小。redo日誌被用於確保寫操作快速而可靠並且在崩潰時恢復。
一直到MySQL 5.1,它都難於調整,因為一方面你想讓它更大來提高效能,另一方面你想讓它更小來使得崩潰後更快恢復。幸運的是從MySQL 5.5之後,崩潰恢復的效能的到了很大提升,這樣你就可以同時擁有較高的寫入效能和崩潰恢復效能了。一直到MySQL 5.5,redo日誌的總尺寸被限定在4GB(預設可以有2個log檔案)。這在MySQL 5.6裡被提高。
一開始就把innodb_log_file_size設定成512M(這樣有1GB的redo日誌)會使你有充裕的寫操作空間。如果你知道你的應用程式需要頻繁的寫入資料並且你使用的時MySQL 5.6,你可以一開始就把它這是成4G。
max_connections:
如果你經常看到‘Too many connections'錯誤,是因為max_connections的值太低了。這非常常見因為應用程式沒有正確的關閉資料庫連線,你需要比預設的 151連線數更大的值。max_connection值被設高了(例如1000或更高)之後一個主要缺陷是當伺服器執行1000個或更高的活動事務時會變的沒有響應。在應用程式裡使用連線池或者在MySQL裡使用程式池有助於解決這一問題。
二、InnoDB配置
從MySQL 5.5版本開始,InnoDB就是預設的儲存引擎並且它比任何其他儲存引擎的使用都要多得多。那也是為什麼它需要小心配置的原因。
innodb_file_per_table:
這項設定告知InnoDB是否需要將所有表的資料和索引存放在共享表空間裡(innodb_file_per_table = OFF) 或者為每張表的資料單獨放在一個.ibd檔案(innodb_file_per_table = ON)。每張表一個檔案允許你在drop、truncate或者rebuild表時回收磁碟空間。這對於一些高階特性也是有必要的,比如資料壓縮。但是它不會帶來任何效能收益。你不想讓每張表一個檔案的主要場景是:有非常多的表(比如10k+)。
MySQL 5.6中,這個屬性預設值是ON,因此大部分情況下你什麼都不需要做。對於之前的版本你必需在載入資料之前將這個屬性設定為ON,因為它只對新建立的表有影響。
innodb_flush_log_at_trx_commit:
預設值為1,表示InnoDB完全支援ACID特性。當你的主要關注點是資料安全的時候這個值是最合適的,比如在一個主節點上。但是對於磁碟(讀寫)速度較慢的系統,它會帶來很巨大的開銷,因為每次將改變flush到redo日誌都需要額外的fsyncs。將它的值設定為2會導致不太可靠(reliable)因為提交的事務僅僅每秒才flush一次到redo日誌,但對於一些場景是可以接受的,比如對於主節點的備份節點這個值是可以接受的。如果值為0速度就更快了,但在系統崩潰時可能丟失一些資料:只適用於備份節點。
innodb_flush_method:
這項配置決定了資料和日誌寫入硬碟的方式。一般來說,如果你有硬體RAID控制器,並且其獨立快取採用write-back機制,並有著電池斷電保護,那麼應該設定配置為O_DIRECT;否則,大多數情況下應將其設為fdatasync(預設值)。sysbench是一個可以幫助你決定這個選項的好工具。
innodb_log_buffer_size:
這項配置決定了為尚未執行的事務分配的快取。其預設值(1MB)一般來說已經夠用了,但是如果你的事務中包含有二進位制大物件或者大文字欄位的話,這點快取很快就會被填滿並觸發額外的I/O操作。看看Innodb_log_waits狀態變數,如果它不是0,增加innodb_log_buffer_size。
三、其他設定
query_cache_size:
query cache(查詢快取)是一個眾所周知的瓶頸,甚至在併發並不多的時候也是如此。
最佳選項是將其從一開始就停用,設定query_cache_size = 0(現在MySQL 5.6的預設值)並利用其他方法加速查詢:最佳化索引、增加複製分散負載或者啟用額外的快取(比如memcache或redis)。如果你已經為你的應用啟用了query cache並且還沒有發現任何問題,query cache可能對你有用。這是如果你想停用它,那就得小心了。
log_bin:
如果你想讓資料庫伺服器充當主節點的備份節點,那麼開啟二進位制日誌是必須的。如果這麼做了之後,還別忘了設定server_id為一個唯一的值。就算只有一個伺服器,如果你想做基於時間點的資料恢復,這(開啟二進位制日誌)也是很有用的:從你最近的備份中恢復(全量備份),並應用二進位制日誌中的修改(增量備份)。二進位制日誌一旦建立就將永久儲存。所以如果你不想讓磁碟空間耗盡,你可以用 PURGE BINARY LOGS 來清除舊檔案,或者設定 expire_logs_days 來指定過多少天日誌將被自動清除。
記錄二進位制日誌不是沒有開銷的,所以如果你在一個非主節點的複製節點上不需要它的話,那麼建議關閉這個選項。
skip_name_resolve:
當客戶端連線資料庫伺服器時,伺服器會進行主機名解析,並且當DNS很慢時,建立連線也會很慢。因此建議在啟動伺服器時關閉 skip_name_resolve選項而不進行DNS查詢。唯一的侷限是之後GRANT語句中只能使用IP地址了,因此在新增這項設定到一個已有系統中必須格外小心。
總結
當然還有其他的設定可以起作用,取決於你的負載或硬體:在慢記憶體和快磁碟、高併發和寫密集型負載情況下,你將需要特殊的調整。然而這裡的目標是使得你可以快速地獲得一個穩健的MySQL配置,而不用花費太多時間在調整一些無關緊要的MySQL設定或讀文件找出哪些設定對你來說很重要上。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/500314/viewspace-1787937/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 安裝MySQL後,需要調整的10個效能配置項MySql
- 必須懂的mysql知識MySql
- 娛樂圈的娘炮文化必須整頓
- mysql主從配置,主從伺服器都是全新安裝myql的情景MySql伺服器
- 必須掌握的10個Linux命令!Linux
- 面試前必須知道的MySQL命令【explain】面試MySqlAI
- windows10如何重新安裝系統_win10重新安裝系統的方法WindowsWin10
- win10重新安裝xbox的方法_如何把win10上解除安裝的xbox重新安裝回去Win10
- 超詳細maven的解除安裝、重新安裝與配置Maven
- solaris10中安裝oracle核心引數的調整Oracle
- 小白學Web前端必須掌握的4項基礎技能!Web前端
- 對於MySQL你必須要了解的鎖知識MySql
- python呼叫方法必須例項化麼Python
- C語言必須掌握的判斷題 | 10C語言
- 鍵盤驅動怎麼重新安裝 win10鍵盤驅動重新安裝的方法Win10
- python必須安裝pip嗎Python
- 企業使用ERP系統必須瞭解的注意事項
- 在深入 Web 開發之前您必須瞭解的事項Web
- 【必知必會的MySQL知識】mysql5.7安裝教程MySql
- 老司機也必須掌握的MySQL最佳化指南MySql
- MAC下的homebrew安裝及映象調整Mac
- 你必須知道的 SmartSql !SQL
- MySQL多例項配置MySql
- 高階 Java 必須突破的 10 個知識點!Java
- 高階Java必須突破的10個知識點!Java
- 這10款好用的Windows軟體,你必須知道!Windows
- mysql建表必須使用主鍵嗎MySql
- 前端設計師必須知道的10個重要的CSS技巧前端CSS
- win10怎麼重新安裝音效卡驅動 win10重新安裝音效卡驅動的方法Win10
- Mysql安裝與配置_win10MySqlWin10
- Mysql系列第三講 管理員必備技能(必須掌握)MySql
- 教程:MySQL 8安裝與配置及注意事項MySql
- LAMP全新安裝 Linux+Apache+MySQL+PHP+phpLAMPLinuxApacheMySqlPHP
- MySQL - 安裝時的安全配置MySql
- 10個必須掌握的PHP關聯陣列使用技巧PHP陣列
- go中Slice的一些使用方式與必須要懂的使用事項Go
- Java程式設計師在2021年必須學習的幾項技能。Java程式設計師
- 你必須做到的 3 件事
- Git中~你必須掌握的!Git