Over a million developers have joined DZone.

Running Jolokia JVM Agent With Mule Standalone Runtime

DZone's Guide to

Running Jolokia JVM Agent With Mule Standalone Runtime

Learn to how to start the Jolokia JVM Agent for Java application monitoring with Mule runtime and enable HTTPS and basic authentication.

· Integration Zone ·
Free Resource

Are your API program basics covered? Read the 5 Pillars of Full Lifecycle API Management eBook

Jolokia is a great way to monitor JVM applications and provide easy access to all the JMX goodies using simple JSON over HTTP. I would say that it has almost become the de facto standard when it comes to monitoring and managing Java applications.

While Jolokia does provide a specialized Mule agent, it does not allow us to expose the Jolokia interface over HTTPS (or enable TLS Client Authentication). On the other hand, this is supported by the Jolokia JVM Agent, and it also works great with the Mule Server Runtime. In this blog post, I do a step by step instruction on how to start the Jolokia JVM Agent with Mule runtime and enable HTTPS and basic authentication. 

  1. Create /opt/jolokia/

  2.  Download and copy the Jolokia JVM agent jar (in my case, jolokia-jvm-1.3.7-agent.jar) into /opt/jolokia.

  3.  Copy your keystore into /opt/jolokia (skip this step if you do not plan to use HTTPS to access Jolokia).

  4. Create a Jolokia properties file in /opt/jolokia. For a complete set of configuration options, see the Jolokia reference manual.

  5. In your Mule config, add the following additional Java argument. As usual, you need to change the <n> to be a consecutive number (based on the number of additional properties).
  6. Start the Mule runtime.

  7. Test by using curl.

  8. user @devws: ~$ curl - k https: //user:password@localhost:8774/jolokia
      "request": {
       "type": "version"
      "value": {
       "agent": "1.3.7",
       "protocol": "7.2",
       "config": {
        "maxDepth": "15",
        "discoveryEnabled": "true",
        "maxCollectionSize": "0",
        "password": "password",
        "agentId": "",
        "debug": "false",
        "agentType": "jvm",
        "historyMaxEntries": "10",
        "agentContext": "\/jolokia",
        "maxObjects": "0",
        "user": "ipf",
        "debugMaxEntries": "100"
       "info": {}
      "timestamp": 1506498074,
      "status": 200
    user @devws: ~$

Establish API creation, publishing and discovery as a master practice with the API Management Playbook.

mule ,jolokia ,managament ,integration ,java ,jvm

Published at DZone with permission of

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}