To send your logs to Datadog, log to a file and tail that file with your Datadog Agent.
Stack traces from typical Java logs are split into multiple lines, which makes them difficult to associate to the original log event. For example:
//4 events generated when only one is expected!Exceptioninthread"main"java.lang.NullPointerExceptionatcom.example.myproject.Book.getTitle(Book.java:16)atcom.example.myproject.Author.getBookTitles(Author.java:25)atcom.example.myproject.Bootstrap.main(Bootstrap.java:14)
To address this issue, configure your logging library to produce your logs in JSON format. By logging to JSON, you:
Ensure that the stack trace is properly wrapped into the log event.
Ensure that all log event attributes (such as severity, logger name, and thread name) are properly extracted.
The following instructions show setup examples for the Log4j, Log4j 2, and Logback logging libraries.
Configure your logger
JSON format
For Log4j, log in JSON format by using the SLF4J module log4j-over-slf4j combined with Logback. log4j-over-slf4j cleanly replaces Log4j in your application so you do not have to make any code changes.
In your pom.xml file, replace the log4j.jar dependency with a log4j-over-slf4j.jar dependency, and add the Logback dependencies. For example:
Configure an appender using the JSON layout in log4j2.xml. See the following example configurations for file and console appender. For a comprehensive description of Log4j plugins, see the Log4j Plugin reference.
If APM is enabled for this application, you can correlate logs and traces by enabling trace ID injection. See Connecting Java Logs and Traces for more information.
Raw format
Configure a file appender in log4j.xml. For example:
If APM is enabled for this application, you can correlate logs and traces by enabling trace ID injection. See Connecting Java Logs and Traces.
If you are not correlating logs and traces, you can remove the MDC placeholders (%X{dd.trace_id} %X{dd.span_id}) from the log patterns included in the above configuration examples.
Create a conf.yaml file in java.d/ with the following content:
#Log sectionlogs:- type:filepath:"<path_to_your_java_log>.log"service:<service_name>source:javasourcecategory:sourcecode# For multiline logs, if they start by the date with the format yyyy-mm-dd uncomment the following processing rule#log_processing_rules:# - type: multi_line# name: new_log_start_with_date# pattern: \d{4}\-(0?[1-9]|1[012])\-(0?[1-9]|[12][0-9]|3[01])
Run the Agent’s status subcommand and look for java under the Checks section to confirm logs are successfully submitted to Datadog.
If logs are in JSON format, Datadog automatically parses the log messages to extract log attributes. Use the Log Explorer to view and troubleshoot your logs.
Agentless logging
In the exceptional case where your application is running on a machine that cannot be accessed or cannot log to a file, it is possible to stream logs to Datadog or to the Datadog Agent directly. This is not the recommended setup, because it requires that your application handles connection issues.
To stream logs directly to Datadog:
Add the Logback logging library to your code, or bridge your current logger to Logback.
Configure Logback to send logs to Datadog.
Bridge from Java logging libraries to Logback
If you are not already using Logback, most common logging libraries can be bridged to Logback.
Use the SLF4J module log4j-over-slf4j with Logback to send logs to another server. log4j-over-slf4j cleanly replaces Log4j in your application so that you do not have to make any code changes.
In your pom.xml file, replace the log4j.jar dependency with a log4j-over-slf4j.jar dependency, and add the Logback dependencies. For example:
Note: As a result of this change, Log4j configuration files will no longer be picked up. Migrate your log4j.properties file to logback.xml with the Log4j translator.
Log4j 2 allows logging to a remote host, but it does not offer the ability to prefix the logs with an API key. Because of this, use the SLF4J module log4j-over-slf4j and Logback. log4j-to-slf4j.jar cleanly replaces Log4j 2 in your application so that you do not have to make any code changes. To use it:
In your pom.xml file, replace the log4j.jar dependency with a log4j-over-slf4j.jar dependency, and add the Logback dependencies. For example:
As a result of this migration, Log4j 2 configuration files will no longer be picked up. Migrate your log4j.properties file to logback.xml with the Log4j translator.
Use the logstash-logback-encoder logging library along with Logback to stream logs directly to Datadog.
Configure a TCP appender in your logback.xml file. With this configuration, your API key is retrieved from the DD_API_KEY environment variable. Alternatively, you can insert your API key directly into the configuration file:
For the following configuration, replace <YOUR REGION INTAKE> with the intake based on your region:.
Note:%mdc{keyThatDoesNotExist} is added because the XML configuration trims whitespace. For more information about the prefix parameter, see the Logback documentation.
Add the Logstash encoder dependency to your pom.xml file. For example:
Enrich your log events with contextual attributes.
Using the key value parser
The key value parser extracts any <KEY>=<VALUE> pattern recognized in any log event.
To enrich your log events in Java, you can re-write messages in your code and introduce <KEY>=<VALUE> sequences.
For instance if you have:
logger.info("Emitted 1001 messages during the last 93 seconds for customer scope prod30");
You can change it to:
logger.info("Emitted quantity=1001 messages during the last durationInMs=93180 ms for customer scope=prod30");
With the key value parser enabled, each pair is extracted from the JSON:
{"message":"Emitted quantity=1001 messages during the last durationInMs=93180 ms for customer scope=prod30","scope":"prod30","durationInMs":93180,"quantity":1001}
So you can exploit scope as a field, and durationInMs and quantity as log measures.