4G記憶體伺服器的MySQL配置優化

来源:http://www.cnblogs.com/whiterock/archive/2017/07/24/7227534.html
-Advertisement-
Play Games

MySQL對於web架構性能的影響最大,也是關鍵的核心部分。MySQL的設置是否合理優化,直接影響到web的速度和承載量!同時,MySQL也是優化難度最大的一個部分,不但需要理解一些MySQL專業知識,同時還需要長時間的觀察統計並且根據經驗進行判斷,然後設置合理的參數。 ...


公司網站訪問量越來越大(日均超10萬PV),MySQL自然成為瓶頸,關於 MySQL 的優化,最基本的是 MySQL 系統參數的優化。

MySQL對於web架構性能的影響最大,也是關鍵的核心部分。MySQL的設置是否合理優化,直接影響到web的速度和承載量!同時,MySQL也是優化難度最大的一個部分,不但需要理解一些MySQL專業知識,同時還需要長時間的觀察統計並且根據經驗進行判斷,然後設置合理的參數。 下麵我們瞭解一下MySQL優化的一些基礎,MySQL自身(my.cnf)的優化。

我們介紹一些對性能影響較大的參數。 由於my.cnf文件的優化設置是與伺服器硬體配置息息相關的,因而我們指定一個常見2U的伺服器硬體環境:CPU: 2顆Intel Xeon 2.4GHz 記憶體: 4GB DDR 硬碟: SCSI

下麵,我們根據以上硬體配置結合一份已經優化好的my.cnf進行說明:

[mysqld]
 port = 3306
 serverid = 1
 socket = /tmp/mysql.sock
 skip-locking
#避免MySQL的外部鎖定,減少出錯幾率增強穩定性。
skip-name-resolve
#禁止MySQL對外部連接進行DNS解析,使用這一選項可以消除MySQL進行DNS解析的時間。但需要註意,如果開啟該選項,則所有遠程主機連接授權都要使用IP地址方式,否則MySQL將無法正常處理連接請求!
back_log = 384
#back_log參數的值指出在MySQL暫時停止響應新請求之前的短時間內多少個請求可以被存在堆棧中。 如果系統在一個短時間內有很多連接,則需要增大該參數的值,該參數值指定到來的TCP/IP連接的偵聽隊列的大小。不同的操作系統在這個隊列大小上有它自己的限制。 試圖設定back_log高於你的操作系統的限制將是無效的。預設值為50。對於Linux系統推薦設置為小於512的整數。
key_buffer_size = 256M
#key_buffer_size指定用於索引的緩衝區大小,增加它可得到更好的索引處理性能。對於記憶體在4GB左右的伺服器該參數可設置為256M或384M。註意:該參數值設置的過大反而會是伺服器整體效率降低!
max_allowed_packet = 4M
 thread_stack = 256K
 table_cache = 128K
 sort_buffer_size = 6M
#查詢排序時所能使用的緩衝區大小。註意:該參數對應的分配記憶體是每連接獨占,如果有100個連接,那麼實際分配的總共排序緩衝區大小為100 × 6 = 600MB。所以,對於記憶體在4GB左右的伺服器推薦設置為6-8M。
read_buffer_size = 4M
#讀查詢操作所能使用的緩衝區大小。和sort_buffer_size一樣,該參數對應的分配記憶體也是每連接獨享。
join_buffer_size = 8M
#聯合查詢操作所能使用的緩衝區大小,和sort_buffer_size一樣,該參數對應的分配記憶體也是每連接獨享。
myisam_sort_buffer_size = 64M
 table_cache = 512
 thread_cache_size = 64
 query_cache_size = 64M
#指定MySQL查詢緩衝區的大小。可以通過在MySQL控制台觀察,如果Qcache_lowmem_prunes的值非常大,則表明經常出現緩衝不夠的情況;如果Qcache_hits的值非常大,則表明查詢緩衝使用非常頻繁,如果該值較小反而會影響效率,那麼可以考慮不用查詢緩衝;Qcache_free_blocks,如果該值非常大,則表明緩衝區中碎片很多。
tmp_table_size = 256M
 max_connections = 768
#指定MySQL允許的最大連接進程數。如果在訪問論壇時經常出現Too Many Connections的錯誤提 示,則需要增大該參數值。
max_connect_errors = 10000000
 wait_timeout = 10
#指定一個請求的最大連接時間,對於4GB左右記憶體的伺服器可以設置為5-10。
thread_concurrency = 8
#該參數取值為伺服器邏輯CPU數量*2,在本例中,伺服器有2顆物理CPU,而每顆物理CPU又支持H.T超線程,所以實際取值為4*2=8
 skip-networking
#開啟該選項可以徹底關閉MySQL的TCP/IP連接方式,如果WEB伺服器是以遠程連接的方式訪問MySQL資料庫伺服器則不要開啟該選項!否則將無法正常連接!
table_cache=1024
#物理記憶體越大,設置就越大.預設為2402,調到512-1024最佳
innodb_additional_mem_pool_size=4M
#預設為2M
 innodb_flush_log_at_trx_commit=1
#設置為0就是等到innodb_log_buffer_size列隊滿後再統一儲存,預設為1
 innodb_log_buffer_size=2M
#預設為1M
 innodb_thread_concurrency=8
#你的伺服器CPU有幾個就設置為幾,建議用預設一般為8
 key_buffer_size=256M
#預設為218,調到128最佳
tmp_table_size=64M
#預設為16M,調到64-256最掛
read_buffer_size=4M
#預設為64K
 read_rnd_buffer_size=16M
#預設為256K
 sort_buffer_size=32M
#預設為256K
 thread_cache_size=120
#預設為60
 query_cache_size=32M

  

註意:

一、如果Key_reads太大,則應該把my.cnf中Key_buffer_size變大,保持Key_reads/Key_read_requests至少1/100以上,越小越好。

二、如果Qcache_lowmem_prunes很大,就要增加Query_cache_size的值。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • gulp前端自動化常用插件彙總 ...
  • 具體代碼如下: ...
  • 常用包 框架: yarn add express 資料庫鏈接: yarn add sequelize yarn add mysql2 處理 favicon: yarn add "serve favicon" 紀錄日誌: yarn add "morgan" 生成文檔: yarn add dev "ap ...
  • 恢復內容開始 純html5+css+js實現噠 運行效果: 實現功能: 按鍵W,S,A,D,J分別控制坦克上下左右移動和發射子彈,由於水平有限,還在努力中~目前只實現了對自己坦克行為的控制,只畫了一顆子彈,記錄這顆子彈的坐標軌跡 源碼: 源碼在這裡啦~,只用了兩個文件,眾多不足,還望指出謝謝~~~~ ...
  • 1.首先確定發佈app的所必要選中或者切換的弄好 比如切換環境到 由測試環境切換到正式環境。 2.打發佈包 首先選中Product 然後選中Archive。 3.等待編譯。 4.打包成功 會進入到下麵這個界面。 5.我一般都是選中export 打一個發佈包 然後用application loader ...
  • 第一步:安裝Java 1.下載JDK,選擇適應自己的機型;官網地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 2.配置環境,問度娘:http://jingyan.baidu. ...
  • Android安裝過程出現問題 一、Eclipse 中 Emulator Control 不能用問題 在官方文檔中發現問題所在(官方文檔說明),在最後一行“The Emulator Control tab, shown in Figure 1, is no longer supported. Use ...
  • 出處:kelvin19840813 的博客 http://www.cnblogs.com/kelvin19840813/ 您的支持是對博主最大的鼓勵,感謝您的認真閱讀。本文版權歸作者所有,歡迎轉載,但請保留該聲明。 發現decode行轉列之後 , 小數, 負數都會自動抹去 , 需要to_char加工 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...