当前位置: 代码迷 >> JavaScript >> java性能调优工具引见-Jstatd
  详细解决方案

java性能调优工具引见-Jstatd

热度:449   发布时间:2012-06-30 17:20:12.0
java性能调优工具介绍-Jstatd

收藏了

?

jstatd是一个rmi的server应用,用于监控jvm的创建和结束,并且提供接口让监控工具(如visualvm)可以远程连接到本机的jvms 。注意是jvms,就是说运行jstatd命令后可以用监控工具监控本用户(运行jstatd命令的用户)所有已经启动的java程序。原理应该也是同jps一样,读取/tmp/hsperfdata_userName/这样目录下的java程序信息,具体可以查看http://trinea.iteye.com/blog/1196400

?

比如我们想监控10.20.149.7这台机器上admin用户所有启动的java程序的信息,则

?

1、在服务器上新建文件,命名为jstatd.all.policy

内容为:

grant codebase "file:${java.home}/../lib/tools.jar" {
permission java.security.AllPermission;
};

?2、在服务器上 jstatd.all.policy所在目录下执行下面的命令

其中 /usr/local/java/bin/jstatd为jstatd所在路径,为${JAVA_HOME}/bin/jstatd

/usr/local/java/bin/jstatd -J-Djava.security.policy=jstatd.all.policy
?

3、在客户端用visualvm连接10.20.149.7,显示如下:

?

详细可参考:http://download.oracle.com/javase/1.5.0/docs/tooldocs/share/jstatd.html

?

若出现

Could not create remote object
access denied (java.util.PropertyPermission java.rmi.server.ignoreSubClasses write)
java.security.AccessControlException: access denied (java.util.PropertyPermission java.rmi.server.ignoreSubClasses write)
        at java.security.AccessControlContext.checkPermission(AccessControlContext.java:323)
        at java.security.AccessController.checkPermission(AccessController.java:546)
        at java.lang.SecurityManager.checkPermission(SecurityManager.java:532)
        at java.lang.System.setProperty(System.java:725)
        at sun.tools.jstatd.Jstatd.main(Jstatd.java:122)

?是因为没有给jstatd指定安全策略,如上新建安全策略文件后运行指定文件即可

?

1 楼 puhaier 2012-05-28  
我根据你的配置,可是还是报错
access denied (java.util.PropertyPermission java.rmi.server.ignoreSubClasses write)
java.security.AccessControlException: access denied (java.util.PropertyPermission java.rmi.server.ignoreSubClasses write)
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:374)
at java.security.AccessController.checkPermission(AccessController.java:546)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:532)
at java.lang.System.setProperty(System.java:725)
at sun.tools.jstatd.Jstatd.main(Jstatd.java:122)

非常郁闷。求帮助
2 楼 comeonbabye 2012-06-22  
你看看是不是防火墙的问题啊
  相关解决方案