1、back_log:要求MySQL能有的连接数量。当主要MySQL线程在一个很短时间内得到非常多的连接请求,这就起作用,然后主线程花些时间尽管很短检查连接并且启动一个新线程。back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。只有如果期望在一个短时间内有很多连接,你需要增加它,换句话说,这值对到来的TCPIP连接的侦听队列的大小。你的操作系统在这个队列大小上有它自己的限制。试图设定back_log高于你的操作系统的限制将是无效的。当你观察你的主机进程列表,发现大量264084u
authe
ticateduserxxxxxxxxxxxxNULLCo
ectNULLlogi
NULL的待连接进程时,就要加大back_log的值了。默认数值是50,我把它改为500。2、i
teractive_timeout:服务器在关闭它前在一个交互连接上等待行动的秒数。一个交互的客户被定义为对mysql_real_co
ect使用CLIENT_INTERACTIVE选项的客户。默认数值是28800,我把它改为7200。3、key_buffer_size:索引块是缓冲的并且被所有的线程共享。key_buffer_size是用于索引块的缓冲区大小,增加它可得到更好处理的索引对所有读和多重写,到你能负担得起那样多。如果你使它太大,系统将开始换页并且真的变慢了。默认数值是83886008M,我的MySQL主机有2GB内存,所以我把它改为402649088400MB。4、max_co
ectio
s:允许的同时客户的数量。增加该值增加mysqld要求的文件描述符的数量。这个数字应该增加,否则,你将经常看到Tooma
yco
ectio
s错误。默认数值是100,我把它改为1024。5、record_buffer:每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。如果你做很多顺序扫描,你可能想要增加该值。默认数值是131072128K,我把它改为1677312016M6、sort_buffer:每个需要进行排序的线程分配该大小的一个缓冲区。增加这值加速ORDERBY或GROUPBY操作。默认数值是20971442M,我把它改为1677720816M。7、table_cache:为所有线程打开表的数量。增加该值能增加mysqld要求的文件描述符的数量。MySQL对每个唯一打开的表需要2个文件描述符。默认数值是64,我把它改为512。、thread_cache_size:可以复用的保存在中的线程的数量。如果有,新的线程从缓存中取得,当断开连接的时候如果有空间,客户的线置在缓存中。如果有很多新的线程,为了提高性能可以这个变量值。通过比较Co
ectio
s和Threads_created状态的变量,可以看到这个变量的作用。我把它设置为80。10、wait_timeout:服务器在关闭它之前在一个连接上等待r