JMX connector
The JMX connector provides the ability to query Java Management Extensions (JMX) information from all nodes in a Trino cluster. This is very useful for monitoring or debugging. JMX provides information about the Java Virtual Machine and all of the software running inside it. Trino itself is heavily instrumented via JMX.
This connector can be configured so that chosen JMX information is periodically dumped and stored in memory for later access.
Configuration
To configure the JMX connector, create a catalog properties file
etc/catalog/jmx.properties
with the following contents:
connector.name=jmx
To enable periodical dumps, define the following properties:
connector.name=jmx
jmx.dump-tables=java.lang:type=Runtime,trino.execution.scheduler:name=NodeScheduler
jmx.dump-period=10s
jmx.max-entries=86400
dump-tables
is a comma separated list of Managed Beans (MBean). It
specifies which MBeans are sampled and stored in memory every
dump-period
. You can configure the maximum number of history entries
with max-entries
and it defaults to 86400
. The time between dumps
can be configured using dump-period
and it defaults to 10s
.
Commas in MBean names must be escaped using double backslashes (\\
) in
the following manner:
connector.name=jmx
jmx.dump-tables=trino.memory:name=general\\,type=memorypool,trino.memory:name=reserved\\,type=memorypool
Double backslashes are required because a single backslash (\
) is used
to split the value across multiple lines in the following manner:
connector.name=jmx
jmx.dump-tables=trino.memory:name=general\\,type=memorypool,\
trino.memory:name=reserved\\,type=memorypool
Querying JMX
The JMX connector provides two schemas.
The first one is current
that contains every MBean from every node in
the Trino cluster. You can see all of the available MBeans by running
SHOW TABLES
:
SHOW TABLES FROM jmx.current;
MBean names map to non-standard table names, and must be quoted with double quotes when referencing them in a query. For example, the following query shows the JVM version of every node:
SELECT node, vmname, vmversion
FROM jmx.current."java.lang:type=runtime";
node | vmname | vmversion
--------------------------------------+-----------------------------------+-----------
ddc4df17-0b8e-4843-bb14-1b8af1a7451a | Java HotSpot(TM) 64-Bit Server VM | 24.60-b09
(1 row)
The following query shows the open and maximum file descriptor counts for each node:
SELECT openfiledescriptorcount, maxfiledescriptorcount
FROM jmx.current."java.lang:type=operatingsystem";
openfiledescriptorcount | maxfiledescriptorcount
-------------------------+------------------------
329 | 10240
(1 row)
The wildcard character *
may be used with table names in the current
schema. This allows matching several MBean objects within a single
query. The following query returns information from the different Trino
memory pools on each node:
SELECT freebytes, node, object_name
FROM jmx.current."trino.memory:*type=memorypool*";
freebytes | node | object_name
------------+---------+----------------------------------------------------------
214748364 | example | trino.memory:type=MemoryPool,name=reserved
1073741825 | example | trino.memory:type=MemoryPool,name=general
858993459 | example | trino.memory:type=MemoryPool,name=system
(3 rows)
The history
schema contains the list of tables configured in the
connector properties file. The tables have the same columns as those in
the current schema, but with an additional timestamp column that stores
the time at which the snapshot was taken:
SELECT "timestamp", "uptime" FROM jmx.history."java.lang:type=runtime";
timestamp | uptime
-------------------------+--------
2016-01-28 10:18:50.000 | 11420
2016-01-28 10:19:00.000 | 21422
2016-01-28 10:19:10.000 | 31412
(3 rows)
SQL support
The connector provides globally available and read operation statements to access JMX information on your Trino nodes.