1、表变化修复排序缓冲区

myisam_sort_buffer_size = 64M

MyISAM设置恢复表之时使用的缓冲区的尺寸,当在REPAIR TABLE或用CREATE INDEX创建索引或ALTER TABLE过程中排序MyISAM索引分配的缓冲区.

2、限制重建索引时,临时文件的大小

myisam_max_sort_file_size = 10G

如果临时文件会变得超过索引,不要使用快速排序索引方法来创建一个索引。注释:这个参数以字节的形式给出

3、修复索引线程

myisam_repair_threads = 1

如果该值大于1,在Repair by sorting过程中并行创建MyISAM表索引(每个索引在自己的线程内) 。

4、Key Buffer大小

key_buffer_size=54M 

Key Buffer大小,用于缓存MyISAM表的索引块。决定数据库索引处理的速度(尤其是索引读)(1G 内存->256M)

5、读缓冲区大小

read_buffer_size=64K

用于对MyISAM表全表扫描时使用的缓冲区大小。针对每个线程进行分配(前提是进行了全表扫描)。进行排序查询时,MySql会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但MySql会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大。

6、排序缓冲区大小

sort_buffer_size=256K 

connection级参数(为每个线程配置),500个线程将消耗500*256K的sort_buffer_size。