Reprint please state the source!
Tomcat Manager
Tomcat Manager is a built-in Tomcat management interface that starts with each Installation of Tomcat and provides links to quick start guides and related documents. On this page, you can view Tomcat indicators and query indicator data using the JMX proxy Servlet.
Tomcat Manager role and permission
Although the administrative interface is out-of-the-box, you will not be able to access it until you have set up the appropriate users and roles. Tomcat provides multiple roles to access Tomcat Manager. The two main roles are:
-
Manager-jmx: Provides access to JMX agent servlets and Tomcat server status pages
-
Manager-gui: Grants access to the Tomcat application manager where you can run diagnostics and manually trigger garbage collection
If you want to access Tomcat metrics from the admin interface, you need to assign appropriate roles to users. You can do this by updating Tomcat’s conf/tomcat-users.xml configuration file:
<role rolename="manager-gui"/>
<role rolename="manager-jmx"/>
<user username="tomcat-jmx" password="<YOUR_PASSWORD>" roles="manager-jmx,manager-gui"/>
Copy the code
This code snippet starts by defining the two roles we want to assign to the user. It then creates a new tomcat-JMX user, assigns these roles to it, and sets the password for the user. If you are using a newly installed Tomcat, you need to create a new user; Otherwise, you can assign roles to existing users.
Tomcat Manager Web UI
By default, Tomcat Manager can be accessed locally from http://localhost:8080, or you can make changes in Tomcat’s server configuration file. When you access the Web world, the system will prompt you to log in. The main data indicators are as follows:
-
Server and application status page: Displays a high-level overview of THE JVM, connector, and application metrics, including memory usage, thread count, and request processing time
-
Application manager: Provides diagnostic tools for investigating memory leaks in applications
-
JMX agent: A text-based interface for querying Tomcat metrics
Tomcat server status page
Advanced view of application and Server status, navigate to the/Manager/Status page or click the Server Status button on the home page. This page contains information about the Tomcat server and its AJP and HTTP connectors, as well as memory usage for the JVM.
Each connector section displays information about thread usage (for example, maximum number of threads, current number of threads, and current number of busy threads) as well as request throughput and performance (for example, processing time, error count, and bytes received), along with information for each connector.
Each thread goes through a series of phases as it processes a request:
-
** Ready: ** This thread can be used to process requests.
-
** The thread is parsing the request header or preparing to read the request body.
-
** Service: The ** thread is processing and generating a response to the incoming request.
-
** Finish (Finishing) : The ** thread has finished processing the request and sent the generated response back to the client.
-
** keep-alive: ** The thread keeps the connection open so that the same client can send another request. The maximum duration of this phase is determined by the keepAliveTimeout value set in the server configuration file. After the connection times out, the thread returns to the ready phase.
The threading phase helps you measure exactly how many threads are ready to accept incoming requests. You can also view the request count for each deployed application in the List of Tomcat applications on the server status page.
Tomcat application status page
To see the status of all deployed applications, navigate to the Manager/Status/All page. This page (page down) lists all applications, including Tomcat Manager itself, so you can quickly see the processing time, active sessions, and number of JSP servlets loaded for each application.
Application manager
To run diagnostics, you can navigate to Tomcat’s application manager interface at/Manager/HTML or click the “Manager App” button on the Tomcat Manager home page. The application Manager provides a simple interface for quickly managing applications, as well as a diagnostic section for troubleshooting memory leaks.
The “Find Leaks” button runs diagnostic checks for memory leaks in your application. Memory leaks occur when the garbage collector is unable to free working memory by removing objects no longer needed by the application. This causes the application to use more resources until it runs out, resulting in fatal memory errors and even memory overruns. Note that this diagnostic check should be used with caution because it triggers garbage collection, which can have an impact on performance.
This interface simply accesses the status of the Tomcat server, enabling you to quickly view relevant data. This will be explained in detail in later chapters.
Querying Tomcat Indicators
Tomcat Manager can access JMX proxy servlets using the manager-JMX role, which allows you to query from a Web browser. Tomcat is an available list can be found at http://localhost:8080/manager/jmxproxy (plain text).
To query data for a specific MBean, add parameters to the URL of the MBean’s field, type, name, and attribute in the following format:
http://localhost:8080/manager/jmxproxy/?get=<DOMAIN>:type=<TYPE>,name="<NAME>"&att=<JMX_ATTRIBUTE>
Copy the code
Find these parameters in the JMX properties and MBean columns above. You can use the following command to view the data for the HTTP connector’s maximum request processing time:
http://localhost:8080/manager/jmxproxy/?get=Catalina:type=GlobalRequestProcessor,name="http-nio-8080"&att=maxTime
Copy the code
This will produce the following results:
OK - Attribute get 'Catalina:type=GlobalRequestProcessor,name="http-nio-8080"' - maxTime = 189`
Copy the code
The command mode is complex and unintuitive. You cannot compare multiple metrics or view data changes over time. To gain a deeper understanding of Tomcat health and performance, we need to use other tools, such as JConsole.
Enable remote JMX connections for Tomcat monitoring tools
Before using JConsole to monitor the Tomcat server, you need to enable remote connections for JMX. JConsole can consume a lot of system resources, so Oracle recommends isolating JConsole from the server you are monitoring only by connecting to a remote host. Note that enabling remote JMX access requires appropriate security precautions because JMX provides limited access control. For the sake of the demonstration, we disable SSL.
First, create a setenv.sh** file in Tomcat’s **/ bin directory with the following contents:
export JAVA_OPTS="${JAVA_OPTS} -Dcom.sun.management.jmxremote" export
JAVA_OPTS="${JAVA_OPTS} -Dcom.sun.management.jmxremote.port=<PORT>" export
JAVA_OPTS="${JAVA_OPTS} -Djava.rmi.server.hostname=<TOMCAT_HOST_OR_IP>" export
JAVA_OPTS="${JAVA_OPTS} -Dcom.sun.management.jmxremote.ssl=false" export
JAVA_OPTS="${JAVA_OPTS} -Dcom.sun.management.jmxremote.authenticate=true" export
JAVA_OPTS="${JAVA_OPTS} -Dcom.sun.management.jmxremote.access.file=${CATALINA_BASE}/conf/jmxremote.access export
JAVA_OPTS="${JAVA_OPTS} -Dcom.sun.management.jmxremote.password.file=${CATALINA_BASE}/conf/jmxremote.password
Copy the code
This sets the hostname and port that JConsole can use to connect to the Tomcat server remotely. You can specify any host name and unused port. Although this example does not include SSL, it does enable password validation and specifies where to look for access (username) and password files; If they do not already exist, you may need to create them. You can add new users and give them one of two permissions (readonly and Readwrite) by editing the **${CATALINA_BASE} /conf/jmxremote.access** file:
tomcatUserRead readonly
tomcatUserWrite readwrite
Copy the code
The first line grants readonly permission to the tomcatUserRead user, which means that the user can view MBean properties and receive notifications.
The second line, the tomcatUserWrite user, provides readWrite permission that allows the user to add and remove MBeans, set properties, and run operations.
Next, set the password for these users in the file **${CATALINA_BASE} /conf/jmxremote.password** :
tomcatRead <PASSWORD> tomcatWrite <PASSWORD>
Copy the code
Save the file and restart the Tomcat server. Next, open JConsole and run the following command to make sure to include the hosts and ports that you defined in the setenv.sh file:
jconsole <TOMCAT_HOST_OR_IP>:<PORT>
Copy the code
This opens the JConsole interface, where you can start viewing data related to the JVM and Tomcat server.
Use JConsole
JConsole is a graphical interface that comes with the JDK. JConsole provides a more intuitive way to monitor key JVM metrics such as heap memory usage, thread usage, and CPU usage. Instead of querying data through a limited interface, such as a JMX agent, you can use JConsole to quickly view data for multiple metrics and drill down to specific MBean types and attributes for Tomcat’s Catalina and JVM’s Java.lang domain. You can navigate to six different tabs: Overview, Memory, Threads, Classes, VM Summary, and MBeans. Each TAB provides a drop-down menu that allows you to view data for different time ranges, such as the last five minutes, the last month, or starting from the server (shown as the “All” option in the drop-down list).
An overview of
The Overview TAB of JConsole shows information related to the JVM’s memory usage, number of threads, Java classes loaded by the application, and CPU usage, so you can monitor virtual machine health at a glance.
The VM
On the VM Summary TAB, you can view more detailed information about the JVM architecture and its characteristics. This is useful if you need a quick look at system-level properties or JVM configuration Settings. This includes any parameters you specify in Tomcat’s **/bin/setenv.sh** configuration file.
memory
Under the Memory TAB, you can view more detailed statistics on virtual machine heap and non-heap memory usage, as well as data on memory pools. From this TAB, you can click Execute GC to run garbage collection, just as you would in the Tomcat Manager.
If you want to view data related to a particular memory pool, you can select that data from the Charts drop-down list in the upper left corner of the Memory TAB.
thread
The Threads TAB of JConsole provides more details about available JVM threads and checks for deadlocked threads. The Threads list shows the thread name, status (similar to the thread phase you see on Tomcat’s server status page), and a stack trace for each available thread. Deadlock checking is useful for finding threads that might cause an application to hang. If any deadlocked threads are found, you will see a new deadlock TAB with more information about what caused the deadlock.
MBean
To see real-time data related to the Tomcat metrics you are monitoring, you can look at the Catalina and Java.lang domains under the MBeans TAB and drill down on specific properties. Like Tomcat Manager, JConsole collects data from the MBean server, but provides a simpler interface to find desired metrics.
JConsole provides a perfect summary of JVM and MBean data, which enables you to graph JVM data to visualize resource usage trends.
Customize Tomcat access and server logs
By default, Tomcat access logs use a common log format and record all requests processed by the server. You can view the contents of the access log in the conf/server. XML configuration file of Tomcat:
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b"/ > `Copy the code
The Pattern attribute of the Valve element specifies the information for each request (and its response) to be included in each log entry:
-
Host name or IP address of the client making the request (%h)
-
Username from identd service (always returns’ – ‘) (%l)
-
Authenticated user name (returned – if not used) (%u)
-
Requested date and time (%t)
-
Request method and URI (%r)
-
HTTP status code for the response (%s)
-
Size of the object returned to the client in bytes (%b)
The pattern used in the example above logs the request in the following format:
[21/Sep/2018:16:51:59 +0000]"The GET/sample/HTTP / 1.1"403, 1145,Copy the code
Tomcat also generates server logs by default and uses the java.util.logging package to do so. Server logs display information about the Tomcat JVM and Catalina server, including out of memory (OOM) errors and deployment activities, as shown in the following example:
16 - Oct - 2018 18:37:08. 624 INFO [main] org. Apache. Catalina. Core. StandardService. StartInternal Starting service [catalina] 16 - Oct - 2018 18:37:08. 625 INFO [main] org. Apache. Catalina. Core. StandardEngine. StartInternal Starting Servlet Engine: Apache Tomcat / 9.0.10 16 - Oct - 2018 18:37:08. 629 SEVERE [main] org. Apache. Catalina. Startup. HostConfig. BeforeStart Unable to create directoryfordeployment: [/ opt/tomcat/conf/Catalina/localhost] 16 - Oct - 2018 18:37:08. 672 INFO [main] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/opt/tomcat/webapps/sample.war] 16 - Oct - 2018 18:37:09. 341 INFO [main] org. Apache. Catalina. Startup. HostConfig. DeployWAR Deployment of a web application archive [/opt/tomcat/webapps/sample.war] has finishedin [667] ms
Copy the code
Tomcat writes server logs to the console and Catalina log files (for example, catalina.2018-07-03.log). You can customize the type of information that Tomcat should log, such as the minimum log level, output directory, and output format in the Tomcat logging properties file (conf/logging.properties).
Handlers are Java components that process incoming log messages and format their output, using a formatter to log to a file (FileHandler) or console (ConsoleHandler). The Tomcat logging properties file includes the configuration of logging for Catalina server, Tomcat Manager, and deployed Web applications:
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
# Handler specific properties. # Describes specific configuration info for Handlers.
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
1catalina.org.apache.juli.FileHandler.level = FINE 1catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs 1catalina.org.apache.juli.FileHandler.prefix = catalina.
2localhost.org.apache.juli.FileHandler.level = FINE 2localhost.org.apache.juli.FileHandler.directory = ${catalina.base}/logs 2localhost.org.apache.juli.FileHandler.prefix = localhost.
3manager.org.apache.juli.FileHandler.level = FINE 3manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs 3manager.org.apache.juli.FileHandler.prefix = manager.
3manager.org.apache.juli.FileHandler.bufferSize = 16384 java.util.logging.ConsoleHandler.level = FINE java.util.logging.ConsoleHandler.formatter = org.apache.juli.OneLineFormatter
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
# Facility specific properties. # Provides extra control for each logger.
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].level = INFO
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].handlers = \
2localhost.org.apache.juli.FileHandler org.apache.catalina.core.ContainerBase.[Catalina].[localhost].
[/manager].level = INFO org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager].handlers = \ 3manager.org.apache.juli.FileHandler
Copy the code
By default, Tomcat sets two different logging levels for its handler (FINE) and tool (INFO). The FINE log level contains detailed information about server activity, and the INFO level records higher-level informational messages. The handler properties manage the Tomcat logs as a whole, while the tools properties allow you to manage the configuration of each deployed application, including the Tomcat Manager. For example, to adjust the logging level of Tomcat Manager, you can edit the following handler and tool properties:
1. `3manager.org.apache.juli.FileHandler.level = FINE 3manager.org.apache.juli.FileHandler.directory = ${catalina.
Copy the code
conclusion
By setting some simple permissions, you can immediately start viewing Tomcat and JVM data using Tomcat Manager. Once remote connectivity is enabled for JMX, you can use tools such as JConsole to monitor Tomcat data through a simple graphical interface. Tomcat also provides basic diagnostic information about requests and server activity in its access and server logs.
Your praise and attention is my motivation to continue to create ~