Documentation
Introduction
RESTHeart uses for logging the LogBack implementation of SLF4J.
Default LogBack configuration
restheart.jar embeds the following default logback.xml
configuration.
Note that it defines loggers only for org.restheart
and com.restheart
packages. If you are developing a plugin in a different package, you’ll need to specify a custom configuration in order to get log messages from your classes.
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<withJansi>true</withJansi>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %highlight(%-5level) %logger{36} - %msg%n %throwable{short}</pattern>
</encoder>
</appender>
<root level="ERROR">
<appender-ref ref="STDOUT" />
</root>
<logger name="org.restheart" level="INFO"/>
<logger name="com.restheart" level="INFO"/>
</configuration>
Logging preferences in restheart.yml
The configuration file restheart.yml
allows to modify the log level and other logging options.
#### Logging
# enable-log-console: true => log messages to the console (default value: true)
# enable-log-file: true => log messages to a file (default value: true)
# log-file-path: to specify the log file path (default value: restheart.log in system temporary directory)
# log-level: to set the log level. Value can be OFF, ERROR, WARN, INFO, DEBUG, TRACE and ALL. (default value is INFO)
# ansi-console: use Ansi console for logging. Default to 'true' if parameter missing, for backward compatibility
# requests-log-level: log the request-response. 0 => no log, 1 => light log, 2 => detailed dump
# requests-log-trace-headers: add the HTTP headers you want to be put on the MDC for logback. Use with %X{header-name} in logback.xml.
# Useful for tracing support in the logs. Leave empty to deactivate this feature.
# metrics-gathering-level: metrics gathering for which level? OFF => no gathering, ROOT => gathering at root level,
# DATABASE => at db level, COLLECTION => at collection level
# WARNING: use requests-log-level level 2 only for development purposes, it logs user credentials (Authorization and Auth-Token headers)
enable-log-file: false
log-file-path: ./restheart.log
enable-log-console: true
log-level: INFO
requests-log-level: 1
ansi-console: true
metrics-gathering-level: DATABASE
requests-log-trace-headers:
# - x-b3-traceid # vv Zipkin headers, see https://github.com/openzipkin/b3-propagation
# - x-b3-spanid
# - x-b3-parentspanid
# - x-b3-sampled # ^^
# - uber-trace-id # jaeger header, see https://www.jaegertracing.io/docs/client-libraries/#trace-span-identity
# - traceparent # vv opencensus.io headers, see https://github.com/w3c/distributed-tracing/blob/master/trace_context/HTTP_HEADER_FORMAT.md
# - tracestate # ^^
Specify a custom LogBack configuration
To define a different logging configuration, set the property logback.configurationFile
, as follows:
$ java -Dlogback.configurationFile=./logback.xml -jar restheart.jar etc/restheart.yml -e etc/default.properties
Example: enable logging from the MongoDB driver
The following logback.xml
adds <logger name="org.mongodb" level="ALL"/>
to enable trace level logging from the MongoDB driver.
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<withJansi>true</withJansi>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %highlight(%-5level) %logger{36} - %msg%n %throwable{short}</pattern>
</encoder>
</appender>
<root level="ERROR">
<appender-ref ref="STDOUT" />
</root>
<logger name="org.restheart" level="INFO"/>
<logger name="com.restheart" level="INFO"/>
<logger name="org.mongodb" level="ALL"/>
</configuration>
Example: log trace headers
Trace headers allow to trace a request context propagation across service boundaries. See for reference b3-propagation
In restheart.yml
configuration, enable requests-log-trace-headers:
requests-log-trace-headers:
-x-b3-traceid
-uber-trace-id
-traceparent
The define a custom logback.xml
with the following pattern
(note that is includes %X{x-b3-traceid}
)
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<withJansi>true</withJansi>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread / %X{x-b3-traceid}] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="ERROR">
<appender-ref ref="STDOUT" />
</root>
<logger name="org.restheart" level="INFO"/>
<logger name="com.restheart" level="INFO"/>
<logger name="org.mongodb" level="ALL"/>
</configuration>
Watch Logging