BoxLang 🚀 A New JVM Dynamic Language Learn More...

CommandBox Elastic APM

v1.0.1 CommandBox Modules

Elastic APM Module

This module adds support to enable Elastic APM on the servers you start inside CommandBox. You will need to have an APM server running and an Elastic search instance to store the data. One of the settings you'll need to provide will be the URL of the APM server to send the data to.

You can read more about how Elastic APM works here: https://www.elastic.co/apm/

Installation

Install the module like so:

install commandbox-elastic-apm

Every server that starts will have the JVM args to add the elastic APM java agent.

Configuration

You can configure your Elastic APM client in the server.json like so:

{
  "elasticAPM" : {
    "enable" : false,
    "installID" : "jar:https: //repo1.maven.org/maven2/co/elastic/apm/elastic-apm-agent/1.24.0/elastic-apm-agent-1.24.0.jar",
    "settings" : {
      "SERVICE_NAME" : "${serverinfo.name}",
      "SERVER_URL" : "http://elk-host.local:8200",
      "ENVIRONMENT" : "${ENVIRONMENT}",
      "USE_PATH_AS_TRANSACTION_NAME" : true      
    }
  }
}

The keys in the settings struct above would be turned into these enviroment variables for you.

  • ELASTIC_APM_SERVICE_NAME
  • ELASTIC_APM_SERVER_URL
  • ELASTIC_APM_ENVIRONMENT
  • ELASTIC_APM_USE_PATH_AS_TRANSACTION_NAME

The possible settings are defined by Elastic APM here: https://www.elastic.co/guide/en/apm/agent/java/current/configuration.html

The enable flag defaults to true and the installID defaults to a recent version of the jar. These are optional and you don't need to provide them unless you're overriding a default.

$ box install commandbox-elastic-apm

No collaborators yet.
 
  • {{ getFullDate("2021-08-18T01:37:49Z") }}
  • {{ getFullDate("2021-08-18T16:55:04Z") }}
  • 1,753
  • 132,400