1136 lines
38 KiB
HTML
1136 lines
38 KiB
HTML
|
<!DOCTYPE html SYSTEM "about:legacy-compat">
|
||
|
<html lang="en"><head><META http-equiv="Content-Type" content="text/html; charset=UTF-8"><link href="./images/docs-stylesheet.css" rel="stylesheet" type="text/css"><title>Apache Tomcat 8 (8.0.53) - Monitoring and Managing Tomcat</title><script type="application/javascript" data-comments-identifier="tomcat-8.0-doc/monitoring">
|
||
|
"use strict"; // Enable strict mode
|
||
|
|
||
|
(function() {
|
||
|
var thisScript = document.currentScript;
|
||
|
if (!thisScript) { // Workaround for IE <= 11
|
||
|
var scripts = document.getElementsByTagName("script");
|
||
|
thisScript = scripts[scripts.length - 1];
|
||
|
}
|
||
|
document.addEventListener("DOMContentLoaded", (function() {
|
||
|
var commentsDiv = document.getElementById("comments_thread");
|
||
|
var commentsShortname = "tomcat";
|
||
|
var commentsIdentifier = "https://tomcat.apache.org/" +
|
||
|
thisScript.getAttribute("data-comments-identifier") + ".html";
|
||
|
|
||
|
(function(w, d) {
|
||
|
if (w.location.hostname.toLowerCase() == "tomcat.apache.org") {
|
||
|
var s = d.createElement("script");
|
||
|
s.type = "application/javascript";
|
||
|
s.async = true;
|
||
|
s.src = "https://comments.apache.org/show_comments.lua?site=" +
|
||
|
encodeURIComponent(commentsShortname) +
|
||
|
"&page=" + encodeURIComponent(commentsIdentifier);
|
||
|
d.head.appendChild(s);
|
||
|
} else {
|
||
|
commentsDiv.appendChild(d.createTextNode("Comments are disabled for this page at the moment."));
|
||
|
}
|
||
|
})(window, document);
|
||
|
}), false);
|
||
|
})();
|
||
|
</script></head><body><div id="wrapper"><header><div id="header"><div><div><div class="logo noPrint"><a href="https://tomcat.apache.org/"><img alt="Tomcat Home" src="./images/tomcat.png"></a></div><div style="height: 1px;"></div><div class="asfLogo noPrint"><a href="https://www.apache.org/" target="_blank"><img src="./images/asf-logo.svg" alt="The Apache Software Foundation" style="width: 266px; height: 83px;"></a></div><h1>Apache Tomcat 8</h1><div class="versionInfo">
|
||
|
Version 8.0.53,
|
||
|
<time datetime="2018-06-29">Jun 29 2018</time></div><div style="height: 1px;"></div><div style="clear: left;"></div></div></div></div></header><div id="middle"><div><div id="mainLeft" class="noprint"><div><nav><div><h2>Links</h2><ul><li><a href="index.html">Docs Home</a></li><li><a href="https://wiki.apache.org/tomcat/FAQ">FAQ</a></li><li><a href="#comments_section">User Comments</a></li></ul></div><div><h2>User Guide</h2><ul><li><a href="introduction.html">1) Introduction</a></li><li><a href="setup.html">2) Setup</a></li><li><a href="appdev/index.html">3) First webapp</a></li><li><a href="deployer-howto.html">4) Deployer</a></li><li><a href="manager-howto.html">5) Manager</a></li><li><a href="host-manager-howto.html">6) Host Manager</a></li><li><a href="realm-howto.html">7) Realms and AAA</a></li><li><a href="security-manager-howto.html">8) Security Manager</a></li><li><a href="jndi-resources-howto.html">9) JNDI Resources</a></li><li><a href="jndi-datasource-examples-howto.html">10) JDBC DataSources</a></li><li><a href="class-loader-howto.html">11) Classloading</a></li><li><a href="jasper-howto.html">12) JSPs</a></li><li><a href="ssl-howto.html">13) SSL/TLS</a></li><li><a href="ssi-howto.html">14) SSI</a></li><li><a href="cgi-howto.html">15) CGI</a></li><li><a href="proxy-howto.html">16) Proxy Support</a></li><li><a href="mbeans-descriptors-howto.html">17) MBeans Descriptors</a></li><li><a href="default-servlet.html">18) Default Servlet</a></li><li><a href="cluster-howto.html">19) Clustering</a></li><li><a href="balancer-howto.html">20) Load Balancer</a></li><li><a href="connectors.html">21) Connectors</a></li><li><a href="monitoring.html">22) Monitoring and Management</a></li><li><a href="logging.html">23) Logging</a></li><li><a href="apr.html">24) APR/Native</a></li><li><a href="virtual-hosting-howto.html">25) Virtual Hosting</a></li><li><a href="aio.html">26) Advanced IO</a></li><li><a href="extras.html">27) Additional Components</a></li><li><a href="maven-jars.html">28) Mavenized</a></li><li><a href="security-howto.html">29) Security Considerations</a></li><li><a href="windows-service-howto.html">30) Windows Service</a></li><li><a href="windows-auth-howto.html">31) Windows Authentication</a></li><li><a href="jdbc-pool.html">32) Tomcat's JDBC Pool</a></li><li><a href="web-socket-howto.html">33) WebSocket</a></li><li><a href="rewrite.html">34) Rewrite</a></li></ul></div><div><h2>Reference</h2><ul><li><a href="RELEASE-NOTES.txt">Release Notes</a></li><li><a href="config/index.html">Configuration</a></li><li><a href="api/index.html">Tomcat Javadocs</a></li><li><a href="servletapi/index.html">Servlet Javadocs</a></li><li><a href="jspapi/index.html">JSP 2.3 Javadocs</a></li><li><a href="elapi/index.html">EL 3.0 Javadocs</a></li><li><a href="websocketapi/index.html">WebSocket 1.1 Javadocs</a></li><li><a href="https://tomcat.apache.org/connectors-doc/">JK 1.2 Documentation</a></li></ul></div><div><h2>Apache Tomcat Development</h2><ul><li><a href="building.html">Building</a></li><li><a href="changelog.html">Changelog</a></li><li><a href="https://wiki.apache.org/tomcat/TomcatVersions">Status</a></li><li><a href="developers.html">Developers</a></li><li><a href="architecture/index.html">Architecture</a></li><li><a href="funcspecs/index.html">Functional Specs.</a></li><li><a href="tribes/introduction.html">Tribes</a></li></ul></div></nav></div></div><div id="mainRight"><div id="content"><h2>Monitoring and Managing Tomcat</h2><h3 id="Table_of_Contents">Table of Contents</h3><div class="text">
|
||
|
<ul><li><a href="#Introduction">Introduction</a></li><li><a href="#Enabling_JMX_Remote">Enabling JMX Remote</a></li><li><a href="#Manage_Tomcat_with_JMX_remote_Ant_Tasks">Manage Tomcat with JMX remote Ant Tasks</a></li><li><a href="#JMXAccessorOpenTask_-_JMX_open_connection_task">JMXAccessorOpenTask - JMX open connection task</a></li><li><a href="#JMXAccessorGetTask:__get_attribute_value_Ant_task">JMXAccessorGetTask: get attribute value Ant task</a></li><li><a href="#JMXAccessorSetTask:__set_attribute_value_Ant_task">JMXAccessorSetTask: set attribute value Ant task</a></li><li><a href="#JMXAccessorInvokeTask:__invoke_MBean_operation_Ant_task">JMXAccessorInvokeTask: invoke MBean operation Ant task</a></li><li><a href="#JMXAccessorQueryTask:__query_MBean_Ant_task">JMXAccessorQueryTask: query MBean Ant task</a></li><li><a href="#JMXAccessorCreateTask:__remote_create_MBean_Ant_task">JMXAccessorCreateTask: remote create MBean Ant task</a></li><li><a href="#JMXAccessorUnregisterTask:__remote_unregister_MBean_Ant_task">JMXAccessorUnregisterTask: remote unregister MBean Ant task</a></li><li><a href="#JMXAccessorCondition:__express_condition">JMXAccessorCondition: express condition</a></li><li><a href="#JMXAccessorEqualsCondition:__equals_MBean_Ant_condition">JMXAccessorEqualsCondition: equals MBean Ant condition</a></li><li><a href="#Using_the_JMXProxyServlet">Using the JMXProxyServlet</a></li></ul>
|
||
|
</div><h3 id="Introduction">Introduction</h3><div class="text">
|
||
|
|
||
|
<p>Monitoring is a key aspect of system administration. Looking inside a
|
||
|
running server, obtaining some statistics or reconfiguring some aspects of
|
||
|
an application are all daily administration tasks.</p>
|
||
|
|
||
|
</div><h3 id="Enabling_JMX_Remote">Enabling JMX Remote</h3><div class="text">
|
||
|
|
||
|
<p><strong>Note:</strong> This configuration is needed only if you are
|
||
|
going to monitor Tomcat remotely. It is not needed if you are going
|
||
|
to monitor it locally, using the same user that Tomcat runs with.</p>
|
||
|
|
||
|
<p>The Oracle website includes the list of options and how to configure
|
||
|
JMX Remote on Java 6:
|
||
|
<a href="http://docs.oracle.com/javase/6/docs/technotes/guides/management/agent.html">
|
||
|
http://docs.oracle.com/javase/6/docs/technotes/guides/management/agent.html</a>.
|
||
|
</p>
|
||
|
<p>The following is a quick configuration guide for Java 6:</p>
|
||
|
<p>Add the following parameters to <code>setenv.bat</code> script of your
|
||
|
Tomcat (see <a href="RUNNING.txt">RUNNING.txt</a> for details).<br>
|
||
|
<em>Note:</em> This syntax is for Microsoft Windows. The command has
|
||
|
to be on the same line. It is wrapped to be more readable. If Tomcat is
|
||
|
running as a Windows service, use its configuration dialog to set
|
||
|
java options for the service.
|
||
|
For un*xes remove <code>"set "</code> from beginning of the line.
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code>set CATALINA_OPTS=-Dcom.sun.management.jmxremote
|
||
|
-Dcom.sun.management.jmxremote.port=%my.jmx.port%
|
||
|
-Dcom.sun.management.jmxremote.ssl=false
|
||
|
-Dcom.sun.management.jmxremote.authenticate=false</code></pre></div>
|
||
|
|
||
|
<ol>
|
||
|
<li>If you require authorization, add and change this:
|
||
|
<div class="codeBox"><pre><code> -Dcom.sun.management.jmxremote.authenticate=true
|
||
|
-Dcom.sun.management.jmxremote.password.file=../conf/jmxremote.password
|
||
|
-Dcom.sun.management.jmxremote.access.file=../conf/jmxremote.access</code></pre></div>
|
||
|
</li>
|
||
|
<li>edit the access authorization file <em>$CATALINA_BASE/conf/jmxremote.access</em>:
|
||
|
<div class="codeBox"><pre><code>monitorRole readonly
|
||
|
controlRole readwrite</code></pre></div>
|
||
|
</li>
|
||
|
<li>edit the password file <em>$CATALINA_BASE/conf/jmxremote.password</em>:
|
||
|
<div class="codeBox"><pre><code>monitorRole tomcat
|
||
|
controlRole tomcat</code></pre></div>
|
||
|
<b>Tip</b>: The password file should be read-only and only accessible by the
|
||
|
operating system user Tomcat is running as.
|
||
|
</li>
|
||
|
</ol>
|
||
|
<p><strong>Note:</strong> The JSR 160 JMX-Adaptor opens a second data channel
|
||
|
on a random port. That is a problem when you have a local firewall installed.
|
||
|
To fix it, configure a <code>JmxRemoteLifecycleListener</code>, as described
|
||
|
in <a href="config/listeners.html">listeners</a> documentation.
|
||
|
</p>
|
||
|
|
||
|
</div><h3 id="Manage_Tomcat_with_JMX_remote_Ant_Tasks">Manage Tomcat with JMX remote Ant Tasks</h3><div class="text">
|
||
|
<p>To simplify JMX usage with Ant 1.6.x, a set of tasks is provided that may
|
||
|
be used with antlib.</p>
|
||
|
<p><b>antlib</b>: Copy your catalina-ant.jar from $CATALINA_HOME/lib to $ANT_HOME/lib.</p>
|
||
|
<p>The following example shows the JMX Accessor usage:<br>
|
||
|
<em>Note:</em> The <code>name</code> attribute value was wrapped here to be
|
||
|
more readable. It has to be all on the same line, without spaces.</p>
|
||
|
<div class="codeBox"><pre><code><project name="Catalina Ant JMX"
|
||
|
xmlns:jmx="antlib:org.apache.catalina.ant.jmx"
|
||
|
default="state"
|
||
|
basedir=".">
|
||
|
<property name="jmx.server.name" value="localhost" />
|
||
|
<property name="jmx.server.port" value="9012" />
|
||
|
<property name="cluster.server.address" value="192.168.1.75" />
|
||
|
<property name="cluster.server.port" value="9025" />
|
||
|
|
||
|
<target name="state" description="Show JMX Cluster state">
|
||
|
<jmx:open
|
||
|
host="${jmx.server.name}"
|
||
|
port="${jmx.server.port}"
|
||
|
username="controlRole"
|
||
|
password="tomcat"/>
|
||
|
<jmx:get
|
||
|
name=
|
||
|
"Catalina:type=IDataSender,host=localhost,
|
||
|
senderAddress=${cluster.server.address},senderPort=${cluster.server.port}"
|
||
|
attribute="connected"
|
||
|
resultproperty="IDataSender.backup.connected"
|
||
|
echo="false"
|
||
|
/>
|
||
|
<jmx:get
|
||
|
name="Catalina:type=ClusterSender,host=localhost"
|
||
|
attribute="senderObjectNames"
|
||
|
resultproperty="senderObjectNames"
|
||
|
echo="false"
|
||
|
/>
|
||
|
<!-- get current maxActiveSession from ClusterTest application
|
||
|
echo it to Ant output and store at
|
||
|
property <em>clustertest.maxActiveSessions.orginal</em>
|
||
|
-->
|
||
|
<jmx:get
|
||
|
name="Catalina:type=Manager,context=/ClusterTest,host=localhost"
|
||
|
attribute="maxActiveSessions"
|
||
|
resultproperty="clustertest.maxActiveSessions.orginal"
|
||
|
echo="true"
|
||
|
/>
|
||
|
<!-- set maxActiveSession to 100
|
||
|
-->
|
||
|
<jmx:set
|
||
|
name="Catalina:type=Manager,context=/ClusterTest,host=localhost"
|
||
|
attribute="maxActiveSessions"
|
||
|
value="100"
|
||
|
type="int"
|
||
|
/>
|
||
|
<!-- get all sessions and split result as delimiter <em>SPACE</em> for easy
|
||
|
access all session ids directly with Ant property sessions.[0..n].
|
||
|
-->
|
||
|
<jmx:invoke
|
||
|
name="Catalina:type=Manager,context=/ClusterTest,host=localhost"
|
||
|
operation="listSessionIds"
|
||
|
resultproperty="sessions"
|
||
|
echo="false"
|
||
|
delimiter=" "
|
||
|
/>
|
||
|
<!-- Access session attribute <em>Hello</em> from first session.
|
||
|
-->
|
||
|
<jmx:invoke
|
||
|
name="Catalina:type=Manager,context=/ClusterTest,host=localhost"
|
||
|
operation="getSessionAttribute"
|
||
|
resultproperty="Hello"
|
||
|
echo="false"
|
||
|
>
|
||
|
<arg value="${sessions.0}"/>
|
||
|
<arg value="Hello"/>
|
||
|
</jmx:invoke>
|
||
|
<!-- Query for all application manager.of the server from all hosts
|
||
|
and bind all attributes from all found manager MBeans.
|
||
|
-->
|
||
|
<jmx:query
|
||
|
name="Catalina:type=Manager,*"
|
||
|
resultproperty="manager"
|
||
|
echo="true"
|
||
|
attributebinding="true"
|
||
|
/>
|
||
|
<!-- echo the create properties -->
|
||
|
<echo>
|
||
|
senderObjectNames: ${senderObjectNames.0}
|
||
|
IDataSender.backup.connected: ${IDataSender.backup.connected}
|
||
|
session: ${sessions.0}
|
||
|
manager.length: ${manager.length}
|
||
|
manager.0.name: ${manager.0.name}
|
||
|
manager.1.name: ${manager.1.name}
|
||
|
hello: ${Hello}
|
||
|
manager.ClusterTest.0.name: ${manager.ClusterTest.0.name}
|
||
|
manager.ClusterTest.0.activeSessions: ${manager.ClusterTest.0.activeSessions}
|
||
|
manager.ClusterTest.0.counterSend_EVT_SESSION_EXPIRED:
|
||
|
${manager.ClusterTest.0.counterSend_EVT_SESSION_EXPIRED}
|
||
|
manager.ClusterTest.0.counterSend_EVT_GET_ALL_SESSIONS:
|
||
|
${manager.ClusterTest.0.counterSend_EVT_GET_ALL_SESSIONS}
|
||
|
</echo>
|
||
|
|
||
|
</target>
|
||
|
|
||
|
</project></code></pre></div>
|
||
|
<p><b>import:</b> Import the JMX Accessor Project with
|
||
|
<em><import file="${CATALINA.HOME}/bin/catalina-tasks.xml" /></em> and
|
||
|
reference the tasks with <em>jmxOpen</em>, <em>jmxSet</em>, <em>jmxGet</em>,
|
||
|
<em>jmxQuery</em>, <em>jmxInvoke</em>, <em>jmxEquals</em> and <em>jmxCondition</em>.</p>
|
||
|
|
||
|
</div><h3 id="JMXAccessorOpenTask_-_JMX_open_connection_task">JMXAccessorOpenTask - JMX open connection task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>url</td>
|
||
|
<td>Set JMX connection URL - <em>service:jmx:rmi:///jndi/rmi://localhost:8050/jmxrmi</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>host</td>
|
||
|
<td>Set the host, shortcut the very long URL syntax.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">localhost</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>port</td>
|
||
|
<td>Set the remote connection port
|
||
|
</td>
|
||
|
<td><code class="noHighlight">8050</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>username</td>
|
||
|
<td>remote JMX connection user name.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>password</td>
|
||
|
<td>remote JMX connection password.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>Name of the internal connection reference. With this attribute you can
|
||
|
configure more the one connection inside the same Ant project.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo the command usage (for access analysis or debugging)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>if</td>
|
||
|
<td>Only execute if a property of the given name <b>exists</b> in the current project.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>unless</td>
|
||
|
<td>Only execute if a property of the given name <b>not exists</b> in the current project.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Example to open a new JMX connection
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:open
|
||
|
host="${jmx.server.name}"
|
||
|
port="${jmx.server.port}"
|
||
|
/></code></pre></div>
|
||
|
|
||
|
<p>
|
||
|
Example to open a JMX connection from URL, with authorization and
|
||
|
store at other reference
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:open
|
||
|
url="service:jmx:rmi:///jndi/rmi://localhost:9024/jmxrmi"
|
||
|
ref="jmx.server.9024"
|
||
|
username="controlRole"
|
||
|
password="tomcat"
|
||
|
/></code></pre></div>
|
||
|
|
||
|
<p>
|
||
|
Example to open a JMX connection from URL, with authorization and
|
||
|
store at other reference, but only when property <em>jmx.if</em> exists and
|
||
|
<em>jmx.unless</em> not exists
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:open
|
||
|
url="service:jmx:rmi:///jndi/rmi://localhost:9024/jmxrmi"
|
||
|
ref="jmx.server.9024"
|
||
|
username="controlRole"
|
||
|
password="tomcat"
|
||
|
if="jmx.if"
|
||
|
unless="jmx.unless"
|
||
|
/></code></pre></div>
|
||
|
|
||
|
<p><b>Note</b>: All properties from <em>jmxOpen</em> task also exists at all
|
||
|
other tasks and conditions.
|
||
|
</p>
|
||
|
|
||
|
</div><h3 id="JMXAccessorGetTask:__get_attribute_value_Ant_task">JMXAccessorGetTask: get attribute value Ant task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=Server</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>attribute</td>
|
||
|
<td>Existing MBean attribute (see Tomcat MBean description above)
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>JMX Connection reference
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo command usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>resultproperty</td>
|
||
|
<td>Save result at this project property
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>delimiter</td>
|
||
|
<td>Split result with delimiter (java.util.StringTokenizer)
|
||
|
and use resultproperty as prefix to store tokens.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>separatearrayresults</td>
|
||
|
<td>When return value is an array, save result as property list
|
||
|
(<em>$resultproperty.[0..N]</em> and <em>$resultproperty.length</em>)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">true</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Example to get remote MBean attribute from default JMX connection
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:get
|
||
|
name="Catalina:type=Manager,context=/servlets-examples,host=localhost"
|
||
|
attribute="maxActiveSessions"
|
||
|
resultproperty="servlets-examples.maxActiveSessions"
|
||
|
/></code></pre></div>
|
||
|
|
||
|
<p>
|
||
|
Example to get and result array and split it at separate properties
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:get
|
||
|
name="Catalina:type=ClusterSender,host=localhost"
|
||
|
attribute="senderObjectNames"
|
||
|
resultproperty="senderObjectNames"
|
||
|
/></code></pre></div>
|
||
|
<p>
|
||
|
Access the senderObjectNames properties with:
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> ${senderObjectNames.length} give the number of returned sender list.
|
||
|
${senderObjectNames.[0..N]} found all sender object names</code></pre></div>
|
||
|
|
||
|
|
||
|
<p>
|
||
|
Example to get IDataSender attribute connected only when cluster is configured.<br>
|
||
|
<em>Note:</em> The <code>name</code> attribute value was wrapped here to be
|
||
|
more readable. It has to be all on the same line, without spaces.
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code>
|
||
|
<jmx:query
|
||
|
failonerror="false"
|
||
|
name="Catalina:type=Cluster,host=${tomcat.application.host}"
|
||
|
resultproperty="cluster"
|
||
|
/>
|
||
|
<jmx:get
|
||
|
name=
|
||
|
"Catalina:type=IDataSender,host=${tomcat.application.host},
|
||
|
senderAddress=${cluster.backup.address},senderPort=${cluster.backup.port}"
|
||
|
attribute="connected"
|
||
|
resultproperty="datasender.connected"
|
||
|
if="cluster.0.name" /></code></pre></div>
|
||
|
|
||
|
</div><h3 id="JMXAccessorSetTask:__set_attribute_value_Ant_task">JMXAccessorSetTask: set attribute value Ant task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=Server</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>attribute</td>
|
||
|
<td>Existing MBean attribute (see Tomcat MBean description above)
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>value</td>
|
||
|
<td>value that set to attribute
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>type</td>
|
||
|
<td>type of the attribute.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">java.lang.String</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>JMX Connection reference
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo command usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Example to set remote MBean attribute value
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:set
|
||
|
name="Catalina:type=Manager,context=/servlets-examples,host=localhost"
|
||
|
attribute="maxActiveSessions"
|
||
|
value="500"
|
||
|
type="int"
|
||
|
/></code></pre></div>
|
||
|
|
||
|
|
||
|
</div><h3 id="JMXAccessorInvokeTask:__invoke_MBean_operation_Ant_task">JMXAccessorInvokeTask: invoke MBean operation Ant task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=Server</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>operation</td>
|
||
|
<td>Existing MBean operation (see Tomcat
|
||
|
<a href="funcspecs/fs-admin-opers.html">funcspecs/fs-admin-opers.html</a>).
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>JMX Connection reference
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo command usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>resultproperty</td>
|
||
|
<td>Save result at this project property
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>delimiter</td>
|
||
|
<td>Split result with delimiter (java.util.StringTokenizer)
|
||
|
and use resultproperty as prefix to store tokens.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>separatearrayresults</td>
|
||
|
<td>When return value is an array, save result as property list
|
||
|
(<em>$resultproperty.[0..N]</em> and <em>$resultproperty.length</em>)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">true</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
stop an application
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:invoke
|
||
|
name="Catalina:type=Manager,context=/servlets-examples,host=localhost"
|
||
|
operation="stop"/></code></pre></div>
|
||
|
<p>
|
||
|
Now you can find the sessionid at <em>${sessions.[0..N}</em> properties and access the count
|
||
|
with ${sessions.length} property.
|
||
|
</p>
|
||
|
<p>
|
||
|
Example to get all sessionids
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:invoke
|
||
|
name="Catalina:type=Manager,context=/servlets-examples,host=localhost"
|
||
|
operation="listSessionIds"
|
||
|
resultproperty="sessions"
|
||
|
delimiter=" "
|
||
|
/></code></pre></div>
|
||
|
<p>
|
||
|
Now you can find the sessionid at <em>${sessions.[0..N}</em> properties and access the count
|
||
|
with ${sessions.length} property.
|
||
|
</p>
|
||
|
<p>
|
||
|
Example to get remote MBean session attribute from session ${sessionid.0}
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:invoke
|
||
|
name="Catalina:type=Manager,context=/ClusterTest,host=localhost"
|
||
|
operation="getSessionAttribute"
|
||
|
resultproperty="hello">
|
||
|
<arg value="${sessionid.0}"/>
|
||
|
<arg value="Hello" />
|
||
|
</jmx:invoke></code></pre></div>
|
||
|
|
||
|
<p>
|
||
|
Example to create a new access logger valve at vhost <em>localhost</em>
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:invoke
|
||
|
name="Catalina:type=MBeanFactory"
|
||
|
operation="createAccessLoggerValve"
|
||
|
resultproperty="accessLoggerObjectName"
|
||
|
>
|
||
|
<arg value="Catalina:type=Host,host=localhost"/>
|
||
|
</jmx:invoke></code></pre></div>
|
||
|
<p>
|
||
|
Now you can find new MBean with name stored at <em>${accessLoggerObjectName}</em>
|
||
|
property.
|
||
|
</p>
|
||
|
|
||
|
</div><h3 id="JMXAccessorQueryTask:__query_MBean_Ant_task">JMXAccessorQueryTask: query MBean Ant task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>JMX ObjectName query string -- <em>Catalina:type=Manager,*</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>JMX Connection reference
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo command usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>resultproperty</td>
|
||
|
<td>Prefix project property name to all founded MBeans (<em>mbeans.[0..N].objectname</em>)
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>attributebinding</td>
|
||
|
<td>bind ALL MBean attributes in addition to <em>name</em>
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>delimiter</td>
|
||
|
<td>Split result with delimiter (java.util.StringTokenizer)
|
||
|
and use resultproperty as prefix to store tokens.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>separatearrayresults</td>
|
||
|
<td>When return value is an array, save result as property list
|
||
|
(<em>$resultproperty.[0..N]</em> and <em>$resultproperty.length</em>)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">true</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Get all Manager ObjectNames from all services and Hosts
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:query
|
||
|
name="Catalina:type=Manager,*
|
||
|
resultproperty="manager" /></code></pre></div>
|
||
|
<p>
|
||
|
Now you can find the Session Manager at <em>${manager.[0..N].name}</em>
|
||
|
properties and access the result object counter with ${manager.length} property.
|
||
|
</p>
|
||
|
<p>
|
||
|
Example to get the Manager from <em>servlet-examples</em> application an bind all MBean properties
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:query
|
||
|
name="Catalina:type=Manager,context=/servlet-examples,host=localhost*"
|
||
|
attributebinding="true"
|
||
|
resultproperty="manager.servletExamples" /></code></pre></div>
|
||
|
<p>
|
||
|
Now you can find the manager at <em>${manager.servletExamples.0.name}</em> property
|
||
|
and can access all properties from this manager with <em>${manager.servletExamples.0.[manager attribute names]</em>}.
|
||
|
The result object counter from MBeans is stored ad ${manager.length} property.
|
||
|
</p>
|
||
|
|
||
|
<p>
|
||
|
Example to get all MBeans from a server and store inside an external XML property file
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code><project name="jmx.query"
|
||
|
xmlns:jmx="antlib:org.apache.catalina.ant.jmx"
|
||
|
default="query-all" basedir=".">
|
||
|
<property name="jmx.host" value="localhost"/>
|
||
|
<property name="jmx.port" value="8050"/>
|
||
|
<property name="jmx.username" value="controlRole"/>
|
||
|
<property name="jmx.password" value="tomcat"/>
|
||
|
|
||
|
<target name="query-all" description="Query all MBeans of a server">
|
||
|
<!-- Configure connection -->
|
||
|
<jmx:open
|
||
|
host="${jmx.host}"
|
||
|
port="${jmx.port}"
|
||
|
ref="jmx.server"
|
||
|
username="${jmx.username}"
|
||
|
password="${jmx.password}"/>
|
||
|
|
||
|
<!-- Query MBean list -->
|
||
|
<jmx:query
|
||
|
name="*:*"
|
||
|
resultproperty="mbeans"
|
||
|
attributebinding="false"/>
|
||
|
|
||
|
<echoproperties
|
||
|
destfile="mbeans.properties"
|
||
|
prefix="mbeans."
|
||
|
format="xml"/>
|
||
|
|
||
|
<!-- Print results -->
|
||
|
<echo message=
|
||
|
"Number of MBeans in server ${jmx.host}:${jmx.port} is ${mbeans.length}"/>
|
||
|
</target>
|
||
|
</project></code></pre></div>
|
||
|
<p>
|
||
|
Now you can find all MBeans inside the file <em>mbeans.properties</em>.
|
||
|
</p>
|
||
|
|
||
|
</div><h3 id="JMXAccessorCreateTask:__remote_create_MBean_Ant_task">JMXAccessorCreateTask: remote create MBean Ant task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=MBeanFactory</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>className</td>
|
||
|
<td>Existing MBean full qualified class name (see Tomcat MBean description above)
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>classLoader</td>
|
||
|
<td>ObjectName of server or web application classloader <br>
|
||
|
( <em>Catalina:type=ServerClassLoader,name=[server,common,shared]</em> or<br>
|
||
|
<em>Catalina:type=WebappClassLoader,context=/myapps,host=localhost</em>)
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>JMX Connection reference
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo command usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Example to create remote MBean
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:create
|
||
|
ref="${jmx.reference}"
|
||
|
name="Catalina:type=MBeanFactory"
|
||
|
className="org.apache.commons.modeler.BaseModelMBean"
|
||
|
classLoader="Catalina:type=ServerClassLoader,name=server">
|
||
|
<arg value="org.apache.catalina.mbeans.MBeanFactory" />
|
||
|
</jmx:create></code></pre></div>
|
||
|
|
||
|
<p>
|
||
|
<b>Warning</b>: Many Tomcat MBeans can't be linked to their parent once<br>
|
||
|
created. The Valve, Cluster and Realm MBeans are not automatically<br>
|
||
|
connected with their parent. Use the <em>MBeanFactory</em> create<br>
|
||
|
operation instead.
|
||
|
</p>
|
||
|
|
||
|
</div><h3 id="JMXAccessorUnregisterTask:__remote_unregister_MBean_Ant_task">JMXAccessorUnregisterTask: remote unregister MBean Ant task</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=MBeanFactory</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>JMX Connection reference
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo command usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Example to unregister remote MBean
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code> <jmx:unregister
|
||
|
name="Catalina:type=MBeanFactory"
|
||
|
/></code></pre></div>
|
||
|
|
||
|
<p>
|
||
|
<b>Warning</b>: A lot of Tomcat MBeans can't be unregister.<br>
|
||
|
The MBeans are not unlinked from their parent. Use <em>MBeanFactory</em><br>
|
||
|
remove operation instead.
|
||
|
</p>
|
||
|
|
||
|
</div><h3 id="JMXAccessorCondition:__express_condition">JMXAccessorCondition: express condition</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>url</td>
|
||
|
<td>Set JMX connection URL - <em>service:jmx:rmi:///jndi/rmi://localhost:8050/jmxrmi</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>host</td>
|
||
|
<td>Set the host, shortcut the very long URL syntax.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">localhost</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>port</td>
|
||
|
<td>Set the remote connection port
|
||
|
</td>
|
||
|
<td><code class="noHighlight">8050</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>username</td>
|
||
|
<td>remote JMX connection user name.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>password</td>
|
||
|
<td>remote JMX connection password.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>Name of the internal connection reference. With this attribute you can
|
||
|
configure more the one connection inside the same Ant project.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=Server</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo condition usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>if</td>
|
||
|
<td>Only execute if a property of the given name <b>exists</b> in the current project.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>unless</td>
|
||
|
<td>Only execute if a property of the given name <b>not exists</b> in the current project.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>value (required)</td>
|
||
|
<td>Second arg for operation
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>type</td>
|
||
|
<td>Value type to express operation (support <em>long</em> and <em>double</em>)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">long</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>operation</td>
|
||
|
<td> express one
|
||
|
<ul>
|
||
|
<li>== equals</li>
|
||
|
<li>!= not equals</li>
|
||
|
<li>> greater than (&gt;)</li>
|
||
|
<li>>= greater than or equals (&gt;=)</li>
|
||
|
<li>< lesser than (&lt;)</li>
|
||
|
<li><= lesser than or equals (&lt;=)</li>
|
||
|
</ul>
|
||
|
</td>
|
||
|
<td><code class="noHighlight">==</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Wait for server connection and that cluster backup node is accessable
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code><target name="wait">
|
||
|
<waitfor maxwait="${maxwait}" maxwaitunit="second" timeoutproperty="server.timeout" >
|
||
|
<and>
|
||
|
<socket server="${server.name}" port="${server.port}"/>
|
||
|
<http url="${url}"/>
|
||
|
<jmx:condition
|
||
|
operation="=="
|
||
|
host="localhost"
|
||
|
port="9014"
|
||
|
username="controlRole"
|
||
|
password="tomcat"
|
||
|
name=
|
||
|
"Catalina:type=IDataSender,host=localhost,senderAddress=192.168.111.1,senderPort=9025"
|
||
|
attribute="connected"
|
||
|
value="true"
|
||
|
/>
|
||
|
</and>
|
||
|
</waitfor>
|
||
|
<fail if="server.timeout" message="Server ${url} don't answer inside ${maxwait} sec" />
|
||
|
<echo message="Server ${url} alive" />
|
||
|
</target></code></pre></div>
|
||
|
|
||
|
</div><h3 id="JMXAccessorEqualsCondition:__equals_MBean_Ant_condition">JMXAccessorEqualsCondition: equals MBean Ant condition</h3><div class="text">
|
||
|
<p>
|
||
|
List of Attributes
|
||
|
</p>
|
||
|
<table class="defaultTable">
|
||
|
|
||
|
<tr>
|
||
|
<th>Attribute</th>
|
||
|
<th>Description</th>
|
||
|
<th>Default value</th>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>url</td>
|
||
|
<td>Set JMX connection URL - <em>service:jmx:rmi:///jndi/rmi://localhost:8050/jmxrmi</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>host</td>
|
||
|
<td>Set the host, shortcut the very long URL syntax.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">localhost</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>port</td>
|
||
|
<td>Set the remote connection port
|
||
|
</td>
|
||
|
<td><code class="noHighlight">8050</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>username</td>
|
||
|
<td>remote JMX connection user name.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>password</td>
|
||
|
<td>remote JMX connection password.
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>ref</td>
|
||
|
<td>Name of the internal connection reference. With this attribute you can
|
||
|
configure more the one connection inside the same Ant project.
|
||
|
</td>
|
||
|
<td><code class="noHighlight">jmx.server</code></td>
|
||
|
</tr>
|
||
|
|
||
|
<tr>
|
||
|
<td>name</td>
|
||
|
<td>Full qualified JMX ObjectName -- <em>Catalina:type=Server</em>
|
||
|
</td>
|
||
|
<td></td>
|
||
|
</tr>
|
||
|
|
||
|
|
||
|
<tr>
|
||
|
<td>echo</td>
|
||
|
<td>Echo condition usage (access and result)
|
||
|
</td>
|
||
|
<td><code class="noHighlight">false</code></td>
|
||
|
</tr>
|
||
|
|
||
|
</table>
|
||
|
|
||
|
<p>
|
||
|
Wait for server connection and that cluster backup node is accessible
|
||
|
</p>
|
||
|
<div class="codeBox"><pre><code><target name="wait">
|
||
|
<waitfor maxwait="${maxwait}" maxwaitunit="second" timeoutproperty="server.timeout" >
|
||
|
<and>
|
||
|
<socket server="${server.name}" port="${server.port}"/>
|
||
|
<http url="${url}"/>
|
||
|
<jmx:equals
|
||
|
host="localhost"
|
||
|
port="9014"
|
||
|
username="controlRole"
|
||
|
password="tomcat"
|
||
|
name=
|
||
|
"Catalina:type=IDataSender,host=localhost,senderAddress=192.168.111.1,senderPort=9025"
|
||
|
attribute="connected"
|
||
|
value="true"
|
||
|
/>
|
||
|
</and>
|
||
|
</waitfor>
|
||
|
<fail if="server.timeout" message="Server ${url} don't answer inside ${maxwait} sec" />
|
||
|
<echo message="Server ${url} alive" />
|
||
|
</target></code></pre></div>
|
||
|
|
||
|
</div><h3 id="Using_the_JMXProxyServlet">Using the JMXProxyServlet</h3><div class="text">
|
||
|
|
||
|
<p>
|
||
|
Tomcat offers an alternative to using remote (or even local) JMX
|
||
|
connections while still giving you access to everything JMX has to offer:
|
||
|
Tomcat's
|
||
|
<a href="api/org/apache/catalina/manager/JMXProxyServlet.html">JMXProxyServlet</a>.
|
||
|
</p>
|
||
|
|
||
|
<p>
|
||
|
The JMXProxyServlet allows a client to issue JMX queries via an HTTP
|
||
|
interface. This technique offers the following advantages over using
|
||
|
JMX directly from a client program:
|
||
|
</p>
|
||
|
|
||
|
<ul>
|
||
|
<li>You don't have to launch a full JVM and make a remote JMX connection
|
||
|
just to ask for one small piece of data from a running server</li>
|
||
|
<li>You don't have to know how to work with JMX connections</li>
|
||
|
<li>You don't need any of the complex configuration covered in the rest
|
||
|
of this page</li>
|
||
|
<li>Your client program does not have to be written in Java</li>
|
||
|
</ul>
|
||
|
|
||
|
<p>
|
||
|
A perfect example of JMX overkill can be seen in the case of popular
|
||
|
server-monitoring software such as Nagios or Icinga: if you want to
|
||
|
monitor 10 items via JMX, you will have to launch 10 JVMs, make 10 JMX
|
||
|
connections, and then shut them all down every few minutes. With the
|
||
|
JMXProxyServlet, you can make 10 HTTP connections and be done with it.
|
||
|
</p>
|
||
|
|
||
|
<p>
|
||
|
You can find out more information about the JMXProxyServlet in the
|
||
|
documentation for the
|
||
|
<a href="manager-howto.html#Using_the_JMX_Proxy_Servlet">Tomcat
|
||
|
manager</a>.
|
||
|
</p>
|
||
|
</div><div class="noprint"><h3 id="comments_section">
|
||
|
Comments
|
||
|
</h3><div class="text"><p class="notice"><strong>Notice: </strong>This comments section collects your suggestions
|
||
|
on improving documentation for Apache Tomcat.<br><br>
|
||
|
If you have trouble and need help, read
|
||
|
<a href="https://tomcat.apache.org/findhelp.html">Find Help</a> page
|
||
|
and ask your question on the tomcat-users
|
||
|
<a href="https://tomcat.apache.org/lists.html">mailing list</a>.
|
||
|
Do not ask such questions here. This is not a Q&A section.<br><br>
|
||
|
The Apache Comments System is explained <a href="./comments.html">here</a>.
|
||
|
Comments may be removed by our moderators if they are either
|
||
|
implemented or considered invalid/off-topic.
|
||
|
</p><div id="comments_thread"></div></div></div></div></div></div></div><footer><div id="footer">
|
||
|
Copyright © 1999-2018, The Apache Software Foundation
|
||
|
</div></footer></div></body></html>
|