Mysql cannot allocate memory for the buffer pool 解决方法

问题出现原因

昨晚我修改了数据库,为字段添加了”FULLTEXT”索引,结果今天早上发现数据库连不上了,也没法重启,于是查看日志文件:

cat /var/log/mysqld.log

发现如下错误日志:

130728  6:50:14 InnoDB: Initializing buffer pool, size = 128.0M
InnoDB: mmap(137363456 bytes) failed; errno 12
130728  6:50:14 InnoDB: Completed initialization of buffer pool
130728  6:50:14 InnoDB: Fatal error: cannot allocate memory for the buffer pool

简单解释就是没法为mysql的buffer pool分配128M的内存。
原因很明显了,内存不足呗,查找资料后发现,原来这个参数主要作用是缓存innodb表的索引,数据,插入数据时的缓冲。我的服务器只有1G内存,所以这个参数开始为索引分配缓存的时候把mysql弄崩溃了。

解决方法

mysql的配置都在/ect/mysql.cnf里面(Ubuntu目录有稍微的差别,用whereis my.cnf就能找到了)。

vim /etc/my.cnf

可以看到第四行:

#innodb_buffer_pool_size = 128M

这里显示默认配置是128M,是注释状态,我们只需要把注释去掉,把128改小一点(根据个人情况修改),我改为:

innodb_buffer_pool_size = 50M

就感觉差不多了。

进一步优化

一般出现这种问题的同学,内存肯定都不大,所以我们可以设置swap分区,也就是通常所说的虚拟内存。
swap的作用具体这里就不做说明了,简单点说就是可以辅助Mem内存。
直接上代码:

dd if=/dev/zero of=/swapfile bs=1M count=1024
mkswap /swapfile
swapon /swapfile

最后添加代码/swapfile swap swap defaults 0 0/etc/fstab文件里面。

free

能看到Mem和swap信息就说明成功了。
最后重启mysql就可以了。

参考文档

http://hongjiang.info/aliyun-vps-mysql-aborting/

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:技术黑板 设计师:CSDN官方博客 返回首页
评论

打赏作者

Mr_OOO

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值