系统信息:
操作系统: CentOS5.4 X64
系统内存: 1G
MySQL配置文件: /etc/my.cnf
MyISAM引擎配置项:
default-storage-engine=MyISAM
loose-skip-innodb
skip-external-locking
跳过外部锁定,external-locking用于多进程条件下为MyISAM数据表进行锁定。如果有多台服务器使用同一个数据库目录,每台服务器都需要开启external locking。
key_buffer_size
指定索引缓冲区的大小,它决定索引处理的速度,尤其是索引读的速度。
key_buffer设置为物理内存的1/4(针对MyISAM引擎),甚至是物理内存的30%到40%,如果key_buffer_size设置太大,系统就会频繁的换页,降低系统性能。因为MySQL使用操作系统的缓存来缓存数据,所以我们得为系统留够足够的内存;在很多情况下数据要比索引大得多。
配置:key_buffer_size = 128M(内存1G)
max_allowed_packet
限制server接受的数据包大小,如果插入或者更新被max_allowed_packet参数限制掉,就会导致失败。
查看当前配置: show variables like '%max_allowed_packet%';
配置:max_allowed_packet = 1M(内存1G)
table_open_cache
tabl