uProfiler使用指南

介:

uProfiler Community是面向主题的一种JVM监控工具,它通过JVMTI和bytecode技术,在JVM运行期间把相关的bytecode精确的注入到当前JVM所载入class字节合适的地方,不修改原class文件,从而达到监控JVM的目的。完整的uProfiler Community版本有两大部分组成,其整体结构如下图。

其中,Agent在class被JVM执行之前,通过JVMTI来拦截被载入的class,分析其bytecode指令,对符合我们感兴趣的bytecode指令附件,插入收集bytecode指令,并且启动一个MXBean,以JMX接口的形势,供外部调用。目前,uProfiler Community版本只支持JMX远程方式调用,因此,启动JVM的时候,需要启动JMX服务,才能让client收集到。未来的后续版本中会引入及时启动Agent的功能。

uProfiler Client通过调用JMX接口,定期收集主题元数据,经过一定的加工,以图形化、表格化的方式显示 出来。

Agent在启动的过程中,会读取Agent Config文件,这个文件中指定了Agent感兴趣的内容所在的class范围。

配置:

Agent Config文件主要有6个配置项,但目前使用的只有前4项,默认情况下,只要配置qualified.name这项即可,详细的配置如下,发行版本的example工程里有agent.properties这个文件,供参考。

  1. ### uAgent在扫瞄类名的过程中,发现类名以qualified.name开头,才注入字节码,   
  2. ### qualified.name既可以是一个package的名字,也可以是一个类的全名,   
  3. ### 若有多个qualified.name,逗号分割   
  4. qualified.name=net.sf.fastupload.multipart.resolver.mvc   
  5.   
  6. ### 打印每次收集信息,默认不打印,打印收集信息对线上的APP有一定的性能影响   
  7. verbose=false  
  8.   
  9. ### 调试模式,打印出扫瞄类和字节码注入的信息,并且把注入了字节码的类写入文件系统,   
  10. ### 这些文件位于启动java进程的目录下的dump文件夹内   
  11. debug=false  
  12.   
  13. ### 当一个方法中调用了其他类的函数时,是否收集这些函数的执行时间。默认情况下,是不收集的,   
  14. ### 如果此项配置为true, 仍然检查被调用的函数名是否以qualified.name开头   
  15. drill.through.method=true  

启动:
使用uProfiler Agent时,需要为JVM增加几个启动参数,指定agent和JMX服务配置,对于对立的java app而言,其命令如下,

  1. java -javaagent:/path/to/uAgent-1.0.0.jar -Dagent.config=/path/to/agent.properties \   
  2. -Dcom.sun.management.jmxremote.port=9999 \   
  3. -Dcom.sun.management.jmxremote.authenticate=false \   
  4. -Dcom.sun.management.jmxremote.local.only=false \   
  5.  -Dcom.sun.management.jmxremote.ssl=false  your.main.class  

对于web app而言,以tomcat为例,则首先要设置JAVA_OPTS这个shell环境变量,

  1. $ export JAVA_OPTS=”-javaagent:/path/to/uAgent-1.0.0.jar -Dagent.config=/path/to/agent.properties -Dcom.sun.management.jmxremote.port=9999 -Dcom.sun.management.jmxremote.authenticate=false  
  2. -Dcom.sun.management.jmxremote.local.only=false    
  3.  -Dcom.sun.management.jmxremote.ssl=false”   
  4.   
  5. ### in tomcat home directory   
  6. $ bin/startup.sh  

启动uProfiler Agent后,使用uProfiler Client连接到9999 JMX远程端口,观察结果。client的使用方法清参考http://www.oschina.net/p/uprofiler

  1. da shang
    donate-alipay
               donate-weixin weixinpay

发表评论↓↓