mysql服务器参数优化
<p><strong>skip-locking </strong>
避免MySQL的外部锁定,减少出错几率增强稳定性。</p>
<p><strong> skip-name-resolve</strong>
禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求!
<strong>back_log = 500</strong>
要求 MySQL 能有的连接数量。当主要MySQL线程在一个很短时间内得到非常多的连接请求,这就起作用,然后主线程花些时间(尽管很短)检查连接并且启动一个新线程。
back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。只有如果期望在一个短时间内有很多连接,你需要增加它,换句话说,这值对到来的TCP/IP连接的侦听队列的大小。你的操作系统在这个队列大小上有它自己的限制。试图设定back_log高于你的操作系统的限制将是无效的。当你观察你的主机进程列表,发现大量 264084 | unauthenticated user | xxx.xxx.xxx.xxx | NULL | Connect | NULL | login | NULL 的待连接进程时,就要加大 back_log 的值了。默认数值是50,我把它改为500。
<strong>key_buffer_size = 384M</strong>
key_buffer_size指定用于索引的缓冲区大小,增加它可得到更好处理的索引(对所有读和多重写),到你能负担得起那样多。如果你使它太大,系统将开始换页并且真的变慢了。对于内存在4GB左右的服务器该参数可设置为384M或512M。通过检查状态值Key_read_requests和 Key_reads,可以知道key_buffer_size设置是否合理。比例key_reads / key_read_requests应该尽可能的低,至少是1:100,1:1000更好(上述状态值可以使用SHOW STATUS LIKE ‘key_read%'获得)。注意:该参数值设置的过大反而会是服务器整体效率降低!
<strong>max_allowed_packet = 32M</strong>
增加该变量的值十分安全,这是因为仅当需要时才会分配额外内存。例如,仅当你发出长查询或mysqld必须返回大的结果行时mysqld才会分配更多内存。该变量之所以取较小默认值是一种预防措施,以捕获客户端和服务器之间的错误信息包,并确保不会因偶然使用大的信息包而导致内存溢出。
<strong>table_cache = 512</strong>(5.1之后叫做table_open_cache)
table_cache指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。通过检查峰值时间的状态值Open_tables和Opened_tables,可以决定是否需要增加table_cache的值。如果你发现 open_tables等于table_cache,并且opened_tables在不断增长,那么你就需要增加table_cache的值了(上述状态值可以使用SHOW STATUS LIKE ‘Open%tables'获得)。注意,不能盲目地把table_cache设置成很大的值。如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。
<strong>sort_buffer_size = 4M</strong>
查询排序时所能使用的缓冲区大小。注意:该参数对应的分配内存是每连接独占!如果有100个连接,那么实际分配的总共排序缓冲区大小为100 × 4 = 400MB。所以,对于内存在4GB左右的服务器推荐设置为4-8M。
<strong>read_buffer_size = 4M</strong>
读查询操作所能使用的缓冲区大小。和sort_buffer_size一样,该参数对应的分配内存也是每连接独享!
<strong>join_buffer_size = 8M</strong>
联合查询操作所能使用的缓冲区大小,和sort_buffer_size一样,该参数对应的分配内存也是每连接独享!
<strong>myisam_sort_buffer_size = 64M</strong>
MyISAM表发生变化时重新排序所需的缓冲
<strong>query_cache_size = 64M</strong>
指定MySQL查询缓冲区的大小。
如果Qcache_hits的值非常大,则表明查询缓冲使用非常频繁,如果该值较小反而会影响效率,那么可以考虑不用查询缓冲;Qcache_free_blocks,如果该值非常大,则表明缓冲区中碎片很多。
<strong>thread_cache_size = 64</strong>
可以复用的保存在中的线程的数量。如果有,新的线程从缓存中取得,当断开连接的时候如果有空间,客户的线置在缓存中。如果有很多新的线程,为了提高性能可以提高这个变量值。通过比较 Connections 和 Threads_created 状态的变量,可以看到这个变量的作用
<strong>tmp_table_size = 256M</strong>
<strong>max_connections = 1000</strong>
指定MySQL允许的最大连接进程数。如果在访问论坛时经常出现Too Many Connections的错误提示,则需要增大该参数值。
<strong>max_connect_errors = 10000000</strong>
对于同一主机,如果有超出该参数值个数的中断错误连接,则该主机将被禁止连接。如需对该主机进行解禁,执行:FLUSH HOST;
<strong>wait_timeout = 10</strong>
指定一个请求的最大连接时间,对于4GB左右内存的服务器可以设置为5-10。
<strong>thread_concurrency = 8</strong>
该参数取值为服务器逻辑CPU数量×2,在本例中,服务器有2颗物理CPU,而每颗物理CPU又支持H.T超线程,
所以实际取值为4 × 2 = 8</p>
<p><strong>slow_query_log =1</strong>
开启慢日志功能,1表示开启,0表示关闭
<strong>long_query_time = 1</strong>
慢查询时间,单位S,超过这个时间,就会启动慢日志
<strong>innodb_buffer_pool_size = 1000M</strong>
物理内存50%-80%
<strong>innodb_log_file_size = 500M</strong>
设置成innodb_buffer_pool_size的1/4
<strong>innodb_log_buffer_size = 20M</strong>
<strong>innodb_flush_log_at_trx_commit = 0</strong>
<strong>innodb_lock_wait_timeout = 50</strong></p>
<p>mysql内存计算公式
mysql used mem = key_buffer_size + query_cache_size + tmp_table_size</p>
<ul>
<li>innodb_buffer_pool_size + innodb_additional_mem_pool_size</li>
<li>innodb_log_buffer_size</li>
<li>max_connections * (
read_buffer_size + read_rnd_buffer_size</li>
<li>sort_buffer_size+ join_buffer_size</li>
<li>binlog_cache_size + thread_stack
)</li>
</ul>
<p>服务器配置:4核8G的内存
vim my.cnf
[mysqld]
default-storage-engine=INNODB
innodb_buffer_pool_size = 5000M
innodb_log_file_size = 1000M
innodb_log_buffer_size = 20M
innodb_lock_wait_timeout = 50
skip-name-resolve
key_buffer_size = 384M
max_allowed_packet = 32M
sort_buffer_size = 4M
read_buffer_size = 4M
join_buffer_size = 8M
myisam_sort_buffer_size = 64M
query_cache_size = 64M
thread_cache_size = 64
tmp_table_size = 256M
max_connect_errors = 10000000
wait_timeout = 10
slow_query_log =1
long_query_time =1</p>