2

我正在尝试使用 jvisualvm 来查看 Play Framework 应用程序。

环境:Windows 7 位,Java 7 64 位。

步骤

1) 添加-Dcom.sun.management.jmxremote_JAVA_OPTIONS环境变量。

播放输出

拿起_JAVA_OPTIONS:-Xms800m -Xmx1500m -XX:PermSize=64m -XX:MaxPermSize=256m -Dcom.sun.manageme nt.jmxremote

2) 运行 jvisual vm(来自C:\Program Files\java\jdk1.7.0_03\bin)。

3) 我在本地进程列表中没有看到 Play 进程。

我错过了什么?

4

2 回答 2

4

我的环境

  • 开发者 PC:Windows 8,JDK1.6 中的 VisualVM
  • 服务器:Ubuntu,JDK1.6,玩1.2.2

要连接到本地 Play 应用程序,唯一的选项“-Dcom.sun.management.jmxremote”就可以了。

但是要连接到远程 Play 应用程序,JVM 需要更多选项。

由于设置_JAVA_OPTIONS环境会影响所有Java程序,所以我更改了播放启动脚本:framework/pym/play/application.py

def java_cmd(self, java_args, cp_args=None, className='play.server.Server', args = None):
  ...
  java_args.append('-Dcom.sun.management.jmxremote')
  java_args.append('-Dcom.sun.management.jmxremote.port=5678')
  java_args.append('-Dcom.sun.management.jmxremote.ssl=false')
  java_args.append('-Dcom.sun.management.jmxremote.authenticate=false')
  java_args.append('-Dcom.sun.management.jmxremote.local.only=false')
  java_args.append('-Djava.rmi.server.hostname=192.168.0.10')

  java_cmd = [self.java_path(), '-javaagent:%s' % self.agent_path()] + java_args + ['-classpath', cp_args, '-Dapplication.path=%s' % self.path, '-Dplay.id=%s' % self.play_env["id"], className] + args
  return java_cmd

然后重新启动 Play 应用程序,并从 VisualVM 重新连接它。

于 2012-07-12T13:00:19.073 回答
4

如果进程指定了 java.io.tmpdir,则存在阻止进程在 jvisualvm(或 jps)中显示的错误。请参阅http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=7009828

此外,从 Java 6 开始就不需要设置 com.sun.management.jmxremote(至少不需要连接到同一台机器上的进程)。请参阅http://docs.oracle.com/javase/6/docs/technotes/guides/management/agent.html

于 2012-07-12T18:13:35.157 回答