IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 系统内存超过比例打印JVM日志 -> 正文阅读

[Java知识库]系统内存超过比例打印JVM日志

import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextRefreshedEvent;
import org.springframework.stereotype.Component;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.lang.management.ManagementFactory;
import java.lang.management.RuntimeMXBean;
import java.nio.charset.StandardCharsets;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;

/**
 * @author: guanglai.zhou
 * @date: 2022/4/28 18:49
 */
@Component
public class JvmMonitor implements ApplicationListener<ContextRefreshedEvent> {

    private static final Logger logger = LoggerFactory.getLogger(JvmMonitor.class);

    @Override
    public void onApplicationEvent(ContextRefreshedEvent event) {
        int pid = getProcessID();
        String[] cmds = new String[]{
                "jps -lvm",
                "jmap -heap " + pid,
                "jmap -histo " + pid + " |head -20",
                "jcmd " + pid + " GC.class_histogram | head -20",
                "jstack " + pid
        };
        ScheduledExecutorService scheduledExecutorService = Executors.newSingleThreadScheduledExecutor(new ThreadFactory() {
            @Override
            public Thread newThread(Runnable r) {
                Thread thread = new Thread(r);
                thread.setName("jvm-schedule-monitor");
                return thread;
            }
        });
        scheduledExecutorService.scheduleWithFixedDelay(new Runnable() {
            @Override
            public void run() {
                // 单位为M
                long freeMemory = Runtime.getRuntime().freeMemory();
                // 最大内存
                long maxMemory = Runtime.getRuntime().maxMemory();

                String printRatio = System.getProperty("jvm.print.memory.ratio");
                if (StringUtils.isBlank(printRatio) || printRatio.matches("\\d+\\.\\d+")) {
                    // 默认值为0.2 如果JVM内存只剩余了20% 就会打印日志
                    printRatio = "0.2";
                }
                double jvmPrintRatio = Double.parseDouble(printRatio);
                if (freeMemory < maxMemory * 0.2) {
                    monitorSystem(cmds);
                }
            }
        }, 1, 10 * 60, TimeUnit.SECONDS);
    }

    public static void monitorSystem(String[] cmds) {
        for (String cmd : cmds) {
            try {
                String result = execCmd(cmd);
                logger.info("{}[root@60 ~]#{}{}{}", System.lineSeparator(), cmd, System.lineSeparator(), result);
            } catch (IOException | InterruptedException e) {
                logger.error("执行系统命令" + cmd + "报错:" + e.getMessage(), e);
            }
        }
    }


    private static String execCmd(String cmd) throws IOException, InterruptedException {
        Process ps = Runtime.getRuntime().exec(cmd);
        BufferedReader br = new BufferedReader(new InputStreamReader(ps.getInputStream(), StandardCharsets.UTF_8));
        StringBuilder result = new StringBuilder();
        String line;
        while ((line = br.readLine()) != null) {
            result.append(line).append(System.lineSeparator());
        }
        br.close();
        ps.waitFor();
        return result.toString();
    }

    private static int getProcessID() {
        RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean();
        return Integer.valueOf(runtimeMXBean.getName().split("@")[0]);
    }
}

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-04-30 08:33:07  更:2022-04-30 08:34:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:52:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码