java进程老挂掉_JAVA进程突然挂掉

JVM内存不足导致进程死掉. Native memory allocation (mmap) failed to map

一台服务器上部署很多JAVA进程已经是微服务的常态,但也有些坑。

背景,测试服务器上的一些JAVA进程突然挂掉,查看call back的日志发现如下:

# There is insufficient memory for the Java Runtime Environment to continue. # Native memory allocation (mmap) failed to map 1786867712 bytes for committing reserved memory. # Possible reasons: # The system is out of physical RAM or swap space # In 32 bit mode, the process size limit was hit # Possible solutions: # Reduce memory load on the system # Increase physical memory or swap space # Check if swap backing store is full # Use 64 bit Java on a 64 bit OS # Decrease Java heap size (-Xmx/-Xms) # Decrease number of Java threads # Decrease Java thread stack sizes (-Xss) # Set larger code cache with -XX:ReservedCodeCacheSize= # This output file may be truncated or incomplete. # # Out of Memory Error (os_linux.cpp:2673), pid=28610, tid=139813184919296 #

在shell脚本中监控和自动重启挂掉Java服务,通常会涉及以下几个步骤: 1. **检测服务状态**: 使用`ps -ef | grep [service_name]`命令检查Java进程是否存在,如果进程ID(PID)为空或者返回非零值表示服务已停止。 2. **设置检查间隔**: 使用`sleep`命令定义一段时间,比如每5秒或10秒检查一次,确保有足够的频率来及时发现服务异常。 3. **监控和判断**: 写一个循环,检查服务状态。如果服务未运行(例如进程不存在),则继续执行下一步。 4. **重启服务**: 如果服务挂掉,使用`nohup java -jar your_service.jar &> /dev/null &`这样的命令重启服务,并将日志重定向到/dev/null以避免干扰监控信息。 5. **记录日志**: 可以考虑记录下服务重启的原因和时间,以便于后期分析。 6. **异常处理**: 加入错误处理机制,比如检查重启操作是否成功,以及防止无限次重启导致的资源耗尽。 7. **循环监控**: 将整个过程封装在一个while循环中,直到用户手动结束或者满足特定的退出条件。 以下是一个简单的示例脚本结构: ```bash #!/bin/bash SERVICE_NAME=your_service LOG_FILE=restart_log.txt while true; do if ! ps aux | grep -v "grep" | grep "$SERVICE_NAME"; then echo "Java service $SERVICE_NAME is down. Restarting..." nohup java -jar your_service.jar &> /dev/null & echo "$(date) - Service restarted." >> $LOG_FILE sleep 5 else echo "Service running." sleep 5 fi done #
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值