{"id":953,"date":"2011-08-23T15:12:39","date_gmt":"2011-08-23T07:12:39","guid":{"rendered":"http:\/\/leegorous.net\/blog\/?p=953"},"modified":"2012-03-03T19:08:47","modified_gmt":"2012-03-03T11:08:47","slug":"run-maven-build-with-jmx-agent","status":"publish","type":"post","link":"http:\/\/leegorous.net\/blog\/2011\/08\/23\/run-maven-build-with-jmx-agent\/","title":{"rendered":"Maven build \u4e2d\u542f\u52a8 JMX Agent"},"content":{"rendered":"<p>\u4e3a\u4e86\u76d1\u63a7 JVM\uff0c\u7814\u7a76\u4e86\u4e0b <a href=\"http:\/\/visualvm.java.net\/\" target=\"_blank\">VisualVM<\/a>\uff0c\u4f46\u662f\u4e0d\u77e5\u9053\u600e\u4e48\u5bfc\u51fa\u91cc\u9762\u7684\u6570\u636e\uff0c\u53ef\u5bfc\u51fa\u5c31\u6bd4\u8f83\u65b9\u4fbf\u505a\u6570\u636e\u6bd4\u5bf9\uff0c\u800c\u4e14\u4e5f\u4e0d\u77e5\u9053\u600e\u4e48\u63a7\u5236\u663e\u793a\u7684\u5386\u53f2\u4fe1\u606f\u8de8\u5ea6\u3002\u800c\u8fd9\u4e24\u70b9\u5728 <a href=\"http:\/\/download.oracle.com\/javase\/6\/docs\/technotes\/guides\/management\/jconsole.html\" target=\"_blank\">JConsole<\/a> \u4e2d\u90fd\u53ef\u4ee5\u3002\u4e8e\u662f\u8981\u6298\u817e JConsole\uff0c\u4e00\u5f00\u59cb\u8fd8\u4e0d\u600e\u4e48\u987a\u5229\uff0c\u867d\u7136\u770b\u4e0a\u53bb\u53ea\u662f\u51e0\u9879\u914d\u7f6e\u3002<br \/>\n\u56e0\u4e3a\u5728\u5f00\u53d1\u8fc7\u7a0b\u5f53\u4e2d\u90fd\u662f\u4f7f\u7528 mvn jetty:run \u542f\u52a8\u7684\u3002\u539f\u6765\u4ee5\u4e3a\u662f\u8fd9\u6837\uff1a<\/p>\n<pre class=\"brush: bash\">\r\nmvn jetty:run -Dcom.sun.management.jmxremote.port=9410 \\\r\n    -Dcom.sun.management.jmxremote.authenticate=false \\\r\n    -Dcom.sun.management.jmxremote.ssl=false\r\n<\/pre>\n<p>\u7136\u540e\u4f7f\u7528 <strong>jconsole 127.0.0.1:9410<\/strong> \uff0c\u63d0\u793a\u662f Connection refused<\/p>\n<p>\u540e\u6765\u4e86\u89e3\u5230\uff0c\u5982\u679c JMX Agent \u542f\u52a8\u6210\u529f\u7684\u8bdd\uff0c\u4f1a\u4ea7\u751f\u4e00\u4e2a\u7aef\u53e3\u76d1\u542c\u3002<br \/>\n\u518d\u6267\u884c <strong>netstat -a | grep 9410<\/strong> \uff0c\u6beb\u65e0\u53cd\u5e94\u3002<\/p>\n<p>\u7f51\u4e0a\u4e71 google jconsole, jmx agent, jmx remote, jmx connection refused \u7b49\u5173\u952e\u5b57\u90fd\u6ca1\u4ec0\u4e48\u5934\u7eea\u3002<br \/>\n\u627e\u5230\u4e00\u7bc7 <a href=\"http:\/\/blogs.oracle.com\/jmxetc\/entry\/troubleshooting_connection_problems_in_jconsole\" target=\"_blank\">\u5173\u4e8e jconsole \u7684\u9519\u8bef\u6392\u67e5<\/a> \u7684\u4e0d\u9519\u7684\u6587\u7ae0\uff0c\u4f46\u662f\u60c5\u51b5\u4e0d\u543b\u5408\uff0c\u8fd9\u91cc\u552f\u4e00\u533a\u522b\u7684\u662f\u4e0d\u662f\u76f4\u63a5 java \u542f\u52a8\uff0c\u800c\u662f\u901a\u8fc7 mvn \uff0c\u66fe\u7ecf\u4f7f\u7528\u8fc7\u8c03\u8bd5\uff0c\u9700\u8981<!--more-->\u6dfb\u52a0 MAVEN_OPTS \u7684\u53c2\u6570\u7684\u3002\u4e00\u8bd5\u6210\u529f\u3002<\/p>\n<pre name=\"code\" class=\"brush: bash\">\r\nset MAVEN_OPTS=-Xmx512m -Dcom.sun.management.jmxremote.port=9400 \\\r\n    -Dcom.sun.management.jmxremote.authenticate=false \\\r\n    -Dcom.sun.management.jmxremote.ssl=false %MAVEN_OPTS%\r\n<\/pre>\n<p>\u518d\u8fdb\u4e00\u6b65\uff0c\u901a\u5e38\u662f\u5728 eclipse \u7684 m2e \u63d2\u4ef6\u542f\u52a8 jetty:run\uff0c\u5982\u4e0b\u56fe\u8bbe\u7f6e<br \/>\n<a href=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jmx.png\"><img loading=\"lazy\" src=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jmx-500x296.png\" alt=\"\" title=\"m2e add MAVEN_OPTS with jmx settings\" width=\"500\" height=\"296\" class=\"aligncenter size-medium wp-image-954\" srcset=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jmx-500x296.png 500w, http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jmx.png 600w\" sizes=\"(max-width: 500px) 100vw, 500px\" \/><\/a><br \/>\n\u7ecf\u8fc7\u591a\u6b21\u9a8c\u8bc1\uff0c\u57fa\u672c\u80af\u5b9a\u8fd9\u91cc\u5b58\u5728 bug \u7684\uff0c\u8bbe\u7f6e MAVEN_OPTS \u662f\u65e0\u6548\u7684\uff0c\u800c\u4e14\u4e0d\u62a5\u9519\u3002<br \/>\n\u65e2\u7136\u8fd9\u662f\u4f5c\u4e3a JDK \u53c2\u6570\u7684\uff0c\u518d\u5c1d\u8bd5\u5c06\u53c2\u6570\u6dfb\u52a0\u5230 jdk \u7684\u542f\u52a8\u53c2\u6570\u91cc\u9762\uff0c\u5c45\u7136\u62a5\u9519\u4e86\uff5e<br \/>\n<a href=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jdk-with-jmx.png\"><img loading=\"lazy\" src=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jdk-with-jmx-500x310.png\" alt=\"\" title=\"m2e-set-jdk-with-jmx\" width=\"500\" height=\"310\" class=\"aligncenter size-medium wp-image-955\" srcset=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jdk-with-jmx-500x310.png 500w, http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/m2e-set-jdk-with-jmx.png 658w\" sizes=\"(max-width: 500px) 100vw, 500px\" \/><\/a><\/p>\n<pre name=\"code\" class=\"brush: text\">\r\nException thrown by the agent : java.net.MalformedURLException: Local host name unknown: java.net.UnknownHostException: LEX-WS: LEX-WS\r\n<\/pre>\n<p>\u9042\u5f80 hosts \u6dfb\u52a0 <strong>127.0.0.1  LEX-WS<\/strong><br \/>\n\u542f\u52a8\u4f9d\u7136\u62a5\u9519\u3002<br \/>\n\u90c1\u95f7\uff0c\u91cd\u542f\u4e00\u4e0b eclipse\uff0c\u5728\u542f\u52a8\uff0c\u5c45\u7136\u597d\u4e86\u3002\u83ab\u975e\u52a8\u6001\u4fee\u6539 hosts \u6587\u4ef6 jvm \u91cc\u662f\u65e0\u6cd5\u52a8\u6001\u8ddf\u4e0a\u7684\uff1f<\/p>\n<p>\u597d\uff0c\u73b0\u5728\u4e00\u5207\u5c31\u7eea\uff0c\u518d\u6b21\u6267\u884c <strong>jconsole 127.0.0.1:9410<\/strong><br \/>\n<a href=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/jconsole-connected.png\"><img loading=\"lazy\" src=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/jconsole-connected-500x365.png\" alt=\"\" title=\"jconsole-connected\" width=\"500\" height=\"365\" class=\"aligncenter size-medium wp-image-957\" srcset=\"http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/jconsole-connected-500x365.png 500w, http:\/\/leegorous.net\/blog\/wp-content\/uploads\/2011\/08\/jconsole-connected.png 845w\" sizes=\"(max-width: 500px) 100vw, 500px\" \/><\/a><br \/>\n\u8fd9\u662f\u5728\u672c\u5730\u6a21\u62df\u8fdc\u7a0b\u7684\u60c5\u51b5\u3002\u5728\u8fdc\u7a0b\u7684\u914d\u7f6e\u4e0b\uff0c\u8fd8\u9700\u8981\u52a0\u5165\u4e00\u4e2a  <strong>-Djava.rmi.server.hostname=&lt;host.name.or.ip&gt;<\/strong>\uff0c\u5426\u5219\uff0c\u53ef\u80fd\u4f1a\u51fa\u73b0\u8fde\u63a5\u6ca1\u6709\u62d2\u7edd\uff0c\u4f46\u662f\u603b\u662f\u8fde\u63a5\u4e0d\u6210\u529f\u7684\u60c5\u51b5\uff0c\u90a3\u4e5f\u662f\u76f8\u5f53\u7684\u90c1\u95f7\u7684\u3002<\/p>\n<p>PS\uff0c\u8fd9\u6837\u914d\u7f6e\u4e4b\u540e\uff0c\u4e5f\u662f\u53ef\u4ee5\u5728 visualvm \u91cc\u901a\u8fc7\u6dfb\u52a0 JMX Connection \u6765\u505a\u76d1\u63a7\u7684\uff0c\u800c\u4e14\u591a\u4e86\u4e2a\u7ebf\u7a0b\u76d1\u63a7\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4e3a\u4e86\u76d1\u63a7 JVM\uff0c\u7814\u7a76\u4e86\u4e0b VisualVM\uff0c\u4f46\u662f\u4e0d\u77e5\u9053\u600e\u4e48\u5bfc\u51fa\u91cc\u9762\u7684\u6570\u636e\uff0c\u53ef\u5bfc\u51fa\u5c31\u6bd4\u8f83\u65b9\u4fbf\u505a\u6570\u636e\u6bd4\u5bf9\uff0c\u800c\u4e14\u4e5f &hellip; <\/p>\n<p class=\"link-more\"><a href=\"http:\/\/leegorous.net\/blog\/2011\/08\/23\/run-maven-build-with-jmx-agent\/\" class=\"more-link\">\u7ee7\u7eed\u9605\u8bfb<span class=\"screen-reader-text\">\u201cMaven build \u4e2d\u542f\u52a8 JMX Agent\u201d<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[17],"tags":[43,67,31],"_links":{"self":[{"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/posts\/953"}],"collection":[{"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/comments?post=953"}],"version-history":[{"count":11,"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/posts\/953\/revisions"}],"predecessor-version":[{"id":1054,"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/posts\/953\/revisions\/1054"}],"wp:attachment":[{"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/media?parent=953"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/categories?post=953"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/leegorous.net\/blog\/wp-json\/wp\/v2\/tags?post=953"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}