核心提示:检查mysqld配置my.conf,着重看key_buffer_size, max_heap_table_size, tmp_table_size几个参数,推荐设置key_buffer_size值为max_heap_table_size的1/4.
因为服务器内存而大富余比较多,前些天把my.conf里的好几个参数调得相当大,1G甚至2G,但并不稳定,mysqld报出过几次Out of memory (Needed xxx bytes)这样的错误,分析原因时,想到是32位linux系统上的linux不支持PAE,不能使用超过3G以上的内存,所以把改大的几个参数适当改小了点,最大也只有几百M的样子,但还是出现过几次Out of memory错误。于是网上多方查询,后来受到公式
key_buffer_size + (read_buffer_size + sort_buffer_size)*max_connections
的启发,两次检查了key_buffer_size, max_heap_table_size, tmp_table_size几个参数,发现这三个值的设置是一样的,竟然都是512M!
于是改小key_buffer_size到128M,重启mysqld接下来5个小时的监测,没有再发生类似错误。
延伸阅读
- mysql join查询时,参与join的字段字符集编码不同,对性能影响是巨大的
- mysql 值/表达式判断函数ifnull()与if() [类似ms sql server的isnull()]
- 用mysqldumpslow分析mysql的slow query log/my.ini/my.cnf记录耗时查询日志
- MySQL数据库备份命令的几个实际应用
- MySQL数据库分区Partition基础及应用
- mysql常用命令及使用技巧
- mysql分表,分区的区别和联系
- MySQL(csv,text)数据导入到mssql方法参考
- MySQL下limit和join的优化
- MySQL TIMESTAMP时间戳的使用/简介用法
- yum依赖错误处理:清理重复的rpm包
- 不用“维护计划”实现mssql定期备份并压缩存档
- MySQL问题和常见错误/mysql官方文档
- 安装VMWare Server 时 error 1718 与 error 2755 的解决方法
- yum更新遇到依赖错误的处理经验总结
评论关闭。