Loki4j is the simplest way to push logs from your Java application to Loki and to connect them with all other metrics using Grafana dashboards. No extra tools needed, just add Loki4j appender to your Logback configuration and enjoy.
Quick Start
The current stable version of Loki4j requires Java 11+ and Logback v1.4.x. See the compatibility matrix for more information about older versions' support.
Add the following dependency to your project:
<dependency>
<groupId>com.github.loki4j</groupId>
<artifactId>loki-logback-appender</artifactId>
<version>1.6.0</version>
</dependency>
implementation 'com.github.loki4j:loki-logback-appender:1.6.0'
Then add Loki appender to your logback.xml
:
<appender name="LOKI" class="com.github.loki4j.logback.Loki4jAppender">
<http>
<url>http://localhost:3100/loki/api/v1/push</url>
</http>
<format>
<label>
<!-- Labels -->
<pattern>
app = my-app,
host = ${HOSTNAME}
</pattern>
<!-- Structured metadata (since Loki v2.9.0) -->
<structuredMetadataPattern>
level = %level,
thread = %thread,
class = %logger,
traceId = %mdc{traceId:-none}
</structuredMetadataPattern>
</label>
<message>
<pattern>%-5level %logger{20} %msg %ex</pattern>
</message>
</format>
</appender>
<root level="DEBUG">
<appender-ref ref="LOKI" />
</root>
<appender name="LOKI" class="com.github.loki4j.logback.Loki4jAppender">
<http>
<url>http://localhost:3100/loki/api/v1/push</url>
</http>
<format>
<label>
<pattern>app=my-app,host=${HOSTNAME}</pattern>
</label>
<message class="com.github.loki4j.logback.JsonLayout" />
</format>
</appender>
<root level="DEBUG">
<appender-ref ref="LOKI" />
</root>
For more details, please refer to Docs.
Migrating from the previous Loki4j version? Read the Migration Guide.
Key Features:
Structured metadata support. Pass any non-label metadata along with your log lines using structured metadata.
Flexible management of Loki labels and metadata using MDC and SLF4J Markers. You can specify Loki labels as well as structured metadata dynamically, even on a per-record basis. Learn more...
Out-of-the-box JSON layout support for log message formatting. You can choose between plain text and JSON (Logstash-like) log message formatting. Learn more...
Logback plain text formatting patterns can be used for both labels and messages. Loki4j allows you to use all the power and flexibility of Logback patterns both for labels and messages. Same patterns are used in Logback's standard
ConsoleAppender
orFileAppender
, so you are probably familiar with the syntax.Support for JSON and Protobuf Loki API flavors. With Loki4j, you can try out either JSON or Protobuf API to send log records to Loki. Learn more...
Compatibility with Grafana Cloud. Loki4j supports HTTP basic authentication, so you can use it for hosted Loki services (e.g., Grafana Cloud) as well as for on-premise Loki instances. See the example...
No JSON library bundled. Instead of bundling with any JSON library (e.g., Jackson), Loki4j comes with a small part of JSON rendering functionality borrowed from DSL-JSON.
Zero-dependency. Loki4j does not bring any new transitive dependencies to your project, assuming you already use
logback-classic
for logging. See the example...Logging performance metrics. You can monitor Loki4j's performance (e.g., encode/send duration, number of batches sent, etc.) by enabling instrumentation powered by Micrometer. Learn more...
Project Status
At the moment all the main logging features have been implemented and stabilized.
Further development will be concentrated on bug fixes (if any), keeping up with new versions of Loki, and improving the codebase so it's easier to maintain.
If you have found this project helpful, please drop a ☆ on GitHub.