http://parus.idv.tw/archives/cat_ccece.html#000147
Tuning Mysql
這兩天都把精神花在調整MY SQL SERVER上
因為是調整參數設定而不是SQL語法
所以把這篇列在這一個項目
(其實我覺得我的分類不是分的很好,但是 算了)
講到TUNGING,就要推薦一下O'reilly所出版的『High Performance MySQL』
不過這本書沒有中譯版,英文不好的人就辛苦點
OK 廢話了這麼多,該談一下這兩天的心得
就是...沒事不要隨便亂改設定值
除非你很確定你改了什麼
這是調整DB的最重要 最重要條件
MySQL的執行情況可以從三個地方觀察
LOG檔、show status;(SQL command)、show variables;
當然還有show table status;
但是,這通常都是小問題
大問題會出現在show variables;所出現的參數中
show status;則是觀察目前的SERVER狀態
會列出很長一段變數詳細內容請參考MYSQL手冊或另一本相關書籍
這裡只列出幾個觀察指標
Max_used_connection => 建立連線的最大數目,
這個數字要跟show variables;的Max_connection參數對照,
如果使用的連線數目已經到達最大,可以考慮放寬
但是每一個connection會多消耗記憶體
記憶體的消耗數量簡易計算方式是:
key_buffer + (sort_buffer + read_buffer) * max_connection
當然這只是簡單算法,省略不少比較小的項目
但是,這個等是算出來的值請保持不要超過實際記憶體
不然,MySQL會有hang住的危險
key_blocks_used使用的KEY BUFFER以BLOCK計算(1024-byte)
與key_buffer的設定相比較可以適度增減
Open_tables與Opened_tables
目前所開啟的table與曾經開啟的TABLE=>完美的情況下兩者應該相同,若Opened超出太,請放大table_cache
Table_locks_immediate與Table_locks_waited
這組數字隱含了SQL的效率,完美情況是waited=0。
但是,不太可能。
如果waited的數字很高甚至比immediate還高,就暗示了SQL寫的不好
Thread_connected與Threads_created
created高太多就表示CPU都在新增Thread,試著縮短Time out時間
調整參數最常用的方式是更改my.cnf(通常在/etc下)
但是要重新啟動MYSQL才會有效
如果是在跑得DB,而且不能restart
(就像我一樣 @@)
那就只能用set指令
set global 參數=值 (不能用文字 1M = 1*1024*1024)
set global是表示套用在所有的Thread上
set 會作用在現行的Thread上
(但是我沒辦法更改TIME OUT時間,他會自己跳回去,還不知道為什麼)
一般比較常更動的會是log的目錄與max_connect還有
key_buffer
在摸索的時候,記得一次調整一個參數就好
並留下原本的設定檔,以防萬一。
MySQL 調校-1
前往
- Software
- ↳ CodeCharge Studio
- ↳ CodeCharge
- ↳ DemoCharge
- ↳ SuperPDF
- ↳ 551einv
- ↳ E3進銷存
- 程式語言
- ↳ PHP
- ↳ CodeLobster PHP Edition
- ↳ Yii
- ↳ CodeIgniter
- ↳ Phalcon
- ↳ Symfony
- ↳ FuelPHP
- ↳ Zend Framework 2
- ↳ laravel
- ↳ WordPress
- ↳ ASP.NET/C#
- ↳ ASP/VBScript
- ↳ JSP
- ↳ Java Servlets
- ↳ ColdFusion
- ↳ Perl
- ↳ Java Script
- ↳ jQuery
- ↳ HTML + CSS
- ↳ jQuery
- ↳ nodejs
- ↳ VB6
- ↳ Git
- ↳ App Inventor 2
- ↳ bash
- ↳ C++/ VC/ OpenCV
- ↳ OpenCV
- ↳ go
- ↳ cordova
- ↳ python
- ↳ Xamarin
- ↳ Assembly
- 資料庫
- ↳ MySQL
- ↳ PostgreSQL
- ↳ ORACLE
- ↳ Access
- ↳ SQL Server
- ↳ SQLite
- ↳ MariaDB
- ↳ Mongodb
- 作業系統
- ↳ Linux
- ↳ Ubuntu
- ↳ CentOS
- ↳ Mint
- ↳ Mandriva
- ↳ Debian
- ↳ Red Hat Enterprise Linux
- ↳ Oracle Linux
- ↳ Fedora
- ↳ Kali Linux
- ↳ OpenSUSE
- ↳ Elementary OS
- ↳ Microsoft
- ↳ Server 2008 R2
- ↳ Server 2012 R2
- ↳ Server 2012
- ↳ 8
- ↳ 10
- ↳ System Center 2016
- ↳ NOVELL
- ↳ FreeBSD
- ↳ VMware
- ↳ VirtualBox
- ↳ Mac OS X
- ↳ Solaris
- ↳ iOS
- ↳ Android
- ↳ Cloud
- ↳ OpenStack
- ↳ Docker
- ↳ Proxmox VE
- ↳ CloudReady
- ↳ chrome
- 網頁伺服器
- ↳ apache
- ↳ tomcat
- ↳ nginx
- ↳ IIS
- ↳ JBoss
- ↳ weblogic
- ↳ WebHosting
- 硬體
- ↳ 硬體及週邊
- ↳ RouterOS
- ↳ LEGO NXT
- ↳ Arduino
- ↳ MSP430
- ↳ Raspberry Pi
- ↳ OpenERP
- ↳ Storage
- ↳ Server
- ↳ Brocade
- ↳ MODELS
- ↳ FortiGate
- 軟體
- ↳ sublime
- ↳ LibreNMS