linux 下的java gate服务断掉的原因及解决思路

一.查询断掉的原因

1.查看gate日志,发现没有报错信息,突然就断了

2.查看是不是OOM导致

dmesg | grep java

发现确实Out of Memory了

3.发生问题的原因:

默认情况下, Linux kernels(内核)允许进程申请的量超过系统可用内存. 这是因为,在大多数情况下, 很多进程申请了很多内存, 但实际使用的量并没有那么多.

有个简单的类比, 宽带租赁的服务商, 可能他的总带宽只有 10Gbps, 但却卖出远远超过100份以上的 100Mbps 带宽, 原因是多数时候, 宽带用户之间是错峰的, 而且不可能每个用户都用满服务商所承诺的带宽。

4.解决思路

法1:保护我们重要的进程,避免被处理掉实例

1.获得重要进程的PID

复制代码
ps -ef|grep java

2.(输入-17,禁止被OOM机制处理)

复制代码
echo -17 > /proc/PID/oom_score_adj

法2:改变vm.overcommit_memory的参数

默认值为:0

从内核文档里得知,该参数有三个值,分别是:

0:当用户空间请求更多的的内存时,内核尝试估算出剩余可用的内存。

1:当设这个参数值为1时,内核允许超量使用内存直到用完为止,主要用于科学计算

2:当设这个参数值为2时,内核会使用一个决不过量使用内存的算法,即系统整个内存地址空间不能超过swap+50%的RAM值,50%参数的设定是在overcommit_ratio中设定。

默认是0,如果法1之后还崩,那就看情况选择1或者2

相关推荐
志栋智能1 分钟前
超自动化巡检:构筑业务连续性的第一道智能防线
大数据·运维·网络·人工智能·自动化
llkk星期五2 分钟前
ubuntu(24.04)下wayland显示界面带来的影响
linux·ubuntu
1104.北光c°2 分钟前
Leetcode146 LRU缓存的三种写法 【hot100算法个人笔记】【java写法】
java·开发语言·笔记·算法·leetcode·hot100·lru缓存
2301_792674863 分钟前
java学习day25
java
语戚5 分钟前
Nginx vs Ribbon:负载均衡的两种核心范式(反向代理 vs 客户端负载)
java·nginx·spring·spring cloud·面试·ribbon·负载均衡
sp42a5 分钟前
安卓原生 MQTT 通讯 Java 实现
android·java·mqtt
花千树-0106 分钟前
用 Java 实现 RAG 组件化:从 PDF 加载到智能问答全流程
java·开发语言·人工智能·langchain·pdf·aigc·ai编程
赫瑞8 分钟前
Java中的进制转换
java·开发语言
2601_949816226 小时前
Redis 配置日志
java
高梦轩6 小时前
MySQL高可用
android·运维·数据库