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/

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
"Cannot allocate memory"是一个常见的错误消息,它表示系统无法分配足够的内存来执行所需的操作。这种错误通常出现在系统资源不足或内存泄漏的情况下。根据引用,在编译过程中出现"virtual memory exhausted Cannot allocate memory"错误可能意味着编译器尝试分配的内存超出了系统的可用内存限制。 另一方面,根据引用,如果在终端中出现"-bash: fork: Cannot allocate memory"错误,则可能是由于系统进程数过多导致的。这可能意味着系统资源不足,无法再创建更多的进程。 为了解决这个问题,可以尝试以下方法: 1. 增加系统的可用内存:可以通过增加服务器的物理内存或调整虚拟内存设置来增加可用内存。 2. 优化进程和资源使用:检查系统中运行的进程和服务,确保它们的资源使用合理。关闭不必要的进程可以释放内存和其他资源。 3. 优化代码和程序:对于编译过程中出现的错误,可以尝试优化代码、减少内存使用或使用更高效的算法来降低内存消耗。 综上所述,"cannot allocate memory"错误通常是由系统资源不足或内存泄漏引起的。通过增加可用内存、优化进程和资源使用以及优化代码和程序,可以解决这个问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [编译时virtual memory exhausted Cannot allocate memory 内存增加.docx](https://download.csdn.net/download/zhangao_fengg/75990874)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [-bash: fork: Cannot allocate memory问题,进程数满了的解决办法](https://blog.csdn.net/weixin_30517001/article/details/98797194)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值