记录MySQL启动失败/宕机-Cannot allocate memory for the buffer pool

记录MySQL启动失败/宕机-Cannot allocate memory for the buffer pool

场景是服务使用的过程中,发现tomcat都起不起来,查看tomcat日志发现是数据库连接异常。接着就是一顿操作了

  • 排查思路:
  1. 用本地工具尝试连接,看看是不是web环境有问题或者MySQL驱动问题。
    结果很显然不会是我的代码和环境问题。用工具连接也显示失败,那就会是MySQL服务本身问题了
  2. 查看f服务器MySQL服务是否存在/启动
	ps -ef|grep mysql

发现也没有启动(前两分钟还能连接,估计是自动宕机了)
3. 尝试直接重启mysql服务

	service mysqld start

结果就是大家想的那样,依旧顽强的拒绝重启。那就只能查看mysql启动日志了
4. 查看mysql启动错误日志,一般在安装路径下面的log文件夹下,错误日志如下:

2020-04-22T13:42:31.887235Z 0 [Note] InnoDB: Initializing buffer pool, total size = 128M, instances = 1, chunk size = 128M
2020-04-22T13:42:31.887269Z 0 [ERROR] InnoDB: mmap(137428992 bytes) failed; errno 12
2020-04-22T13:42:31.887278Z 0 [ERROR] InnoDB: Cannot allocate memory for the buffer pool
2020-04-22T13:42:31.887284Z 0 [ERROR] InnoDB: Plugin initialization aborted with error Generic error
2020-04-22T13:42:31.887289Z 0 [ERROR] Plugin 'InnoDB' init function returned error.
2020-04-22T13:42:31.887293Z 0 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2020-04-22T13:42:31.887297Z 0 [ERROR] Failed to initialize builtin plugins.
2020-04-22T13:42:31.887301Z 0 [ERROR] Aborting

在这个日志中发现个很显眼的ERROR

InnoDB: Cannot allocate memory for the buffer pool

意思就是InnoDB的缓冲池内存不够分配了,所以我们需要去设置他得大小
5. 设置InnoDB缓冲池大小
找到my.cnf文件,我的是在 /etc 下面,一般出现这个问题都是使用的默认设置,所以直接新增就好

[mysqld]
#innodb缓冲池大小
innodb_buffer_pool_size = 50M
  1. 设置完之后,在重新启动mysql服务。然后就能看到
    在这里插入图片描述
    至此,MySQL有重新开始站岗了。。。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当nacos在Linux系统中启动时出现"Cannot allocate memory"的错误,这通常意味着系统内存不足以满足nacos的要求。根据引用中的信息,可以看到启动日志中显示内存剩余为52M,而nacos在启动时指定了最小堆内存为2G。因此,当系统内存不足以满足nacos的内存需求时,会出现该错误。 为解决这个问题,可以尝试以下步骤: 1. 检查系统内存使用情况,确保有足够的空闲内存可供nacos使用。可以通过命令"free -h"查看系统内存使用情况,特别关注可用内存空间是否足够。 2. 调整nacos的内存配置参数。根据引用中的信息,在nacos启动脚本startup.sh中的JVM Configuration部分修改jvm启动参数,将分配给jvm的内存大小调小。可以尝试减小最小堆内存(-Xms)、最大堆内存(-Xmx)或新生代内存(-Xmn)的大小,以适应当前系统的内存情况。 3. 如果以上方法仍然无法解决问题,考虑增加系统的内存资源。可以通过增加物理内存或调整虚拟机的内存限制来提供更多的内存给nacos使用。 总之,nacos在Linux启动时出现"Cannot allocate memory"错误通常是由于系统内存不足导致的。通过检查系统内存使用情况并调整nacos的内存配置,可以尝试解决这个问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [nacos的 standalone模式启动bat](https://download.csdn.net/download/woodAstone2008/85709572)[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_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [nacos启动报错内存不足“failed; error=‘Cannot allocate memory‘ (errno=12)](https://blog.csdn.net/weixin_43667414/article/details/109277097)[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_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值