centos启动tomcat报错 failed; error=‘Cannot allocate memory‘ (errno=12)服务器内存不足

centos启动tomcat报错 failed; error=‘Cannot allocate memory’ (errno=12)服务器内存不足

1. 问题

Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=256m; support was removed in 8.0
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=512m; support was removed in 8.0
Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c0000000, 358088704, 0) failed; error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 358088704 bytes for committing reserved memory.
# An error report file with more information is saved as:
# /usr/platform/tomcat/apache-tomcat-9.0.31/bin/hs_err_pid21205.log
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=256m; support was removed in 8.0
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=512m; support was removed in 8.0
Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c0000000, 358088704, 0) failed; error='Cannot allocate memory' (errno=12)
报错信息显示项目配置的启动内存比服务器空闲内存更大。

2. 解决方法

(1)杀死没有用的进程
使用命令ps -ef查看正在运行的进程,如果确定无用,使用命令kill -9 pid杀死进程

一次性杀死多个java进程:pkill java

(2)扩大内存
① 使用命令sysctl -a|grep vm.max_map_count查询内存大小
在这里插入图片描述
② 调整内存大小为默认的4倍

临时修改:
[root@localhost ~]# sysctl -w vm.max_map_count=262144
永久修改:

直接写到/etc/sysctl.conf中,然后执行sysctl -p

[root@localhost ~]# vim /etc/sysctl.conf
 vm.max_map_count=262144
[root@localhost ~]# sysctl -p

③ 查看修改结果

[root@localhost ~]# sysctl -a|grep vm.max_map_count
vm.max_map_count = 262144
当出现"fork failed: cannot allocate memory"错误时,这通常表示系统内存不足以执行所需的操作。有几种方法可以解决这个问题。 首先,你可以通过运行"free -m"命令来查看系统内存的使用情况。关注"Mem"的"total"指标,表示总内存大小,"Used"表示已使用的内存,"buff/cache"表示缓存使用的内存,"swap"的"used"表示交换分区的使用情况。如果"swap"的"used"为0,表示未使用交换分区,这是正常情况。\[1\] 如果发现系统内存不足,你可以尝试创建一个swap分区来增加可用内存。可以按照以下步骤进行操作: 1. 运行"dd if=/dev/zero of=/var/swap.1 bs=1M count=1024"命令创建一个1GB大小的swap文件。 2. 运行"mkswap /var/swap.1"命令格式化swap文件。 3. 运行"swapon /var/swap.1"命令将swap分区挂载到文件系统中。\[2\] 创建swap分区后,再次运行"free -m"命令查看内存使用情况。然后尝试重新执行你的操作,例如"composer update"。 另外,如果问题是由于进程数过多导致的,你可以尝试修改最大进程数。可以按照以下步骤进行操作: 1. 运行"echo 1000000 > /proc/sys/kernel/pid_max"命令修改最大进程数。 2. 运行"echo 'kernel.pid_max=1000000' >> /etc/sysctl.conf"命令使修改永久生效。 3. 运行"sysctl -p"命令重新加载sysctl配置。\[3\] 这些方法应该能够解决"fork failed: cannot allocate memory"错误。如果问题仍然存在,请进一步检查系统资源使用情况,例如CPU和磁盘空间,并确保系统配置符合你的需求。 #### 引用[.reference_title] - *1* [centos7无法远程和登录,在线用户命令执行报错 fork failed :Cannot allocate memory](https://blog.csdn.net/edgar_t/article/details/107912328)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [安装composer后报错proc_open(): fork failed - Cannot allocate memory](https://blog.csdn.net/zhemejinnameyuanxc/article/details/90245502)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [fork failed: cannot allocate memory问题](https://blog.csdn.net/weixin_34112208/article/details/92394973)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值