1

statsd-jvm-profiler是etsy开发的一个 JVM 代理 Profiler,其将Profile数据发送到 StatsD.

-javaagent加载

-javaagent:/usr/etsy/statsd-jvm-profiler/statsd-jvm-profiler.jar=server=statsdHost,port=statsdPort

运行时动态加载

将该jar包拷贝到spring boot工程的main resource目录下,然后

@Bean
    public CommandLineRunner loadProfilerAgent(){
        return new CommandLineRunner() {
            @Override
            public void run(String... strings) throws Exception {
                ApplicationPid pid = new ApplicationPid();
                try{
                    com.sun.tools.attach.VirtualMachine vm = com.sun.tools.attach.VirtualMachine.attach(pid.toString());
                    ClassLoader classLoader = getClass().getClassLoader();
                    String profilerJarPath = classLoader.getResource("statsd-jvm-profiler-2.0.0.jar").getPath();
                    String agentArgs = "server="+statsdHost+",port="+statsdPort;
                    vm.loadAgent(profilerJarPath, agentArgs);
                    vm.detach();
                    System.out.println("Dynamically loaded StatsD JVM Profiler Agent...");
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        };
    }

内置httpServer

该agent内置了一个http server,默认端口为5005,可以访问如下几个path
http://localhost:5005/errors
http://localhost:5005/isRunning
http://localhost:5005/profilers
http://localhost:5005/disable...
http://localhost:5005/status/...

graphite

在graphite里头,statsd-jvm-profiler前缀的gauges就是了。

doc


codecraft
11.9k 声望2k 粉丝

当一个代码的工匠回首往事时,不因虚度年华而悔恨,也不因碌碌无为而羞愧,这样,当他老的时候,可以很自豪告诉世人,我曾经将代码注入生命去打造互联网的浪潮之巅,那是个很疯狂的时代,我在一波波的浪潮上留下...