Step 1. Add the JitPack repository to your build file
Add it in your root settings.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
Add it in your settings.gradle.kts at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url = uri("https://jitpack.io") }
}
}
Add to pom.xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.Sberned:kafka-logback:1.0.2'
}
dependencies {
implementation("com.github.Sberned:kafka-logback:1.0.2")
}
<dependency>
<groupId>com.github.Sberned</groupId>
<artifactId>kafka-logback</artifactId>
<version>1.0.2</version>
</dependency>
libraryDependencies += "com.github.Sberned" % "kafka-logback" % "1.0.2"
:dependencies [[com.github.Sberned/kafka-logback "1.0.2"]]
This is a logback appender for Kafka (3.7.0 kafka-client used)
This appender expects topic, bootstrapServers, valueSerializer and layout as mandatory.
You could also supply additional kafka customProps in <customProps>
tag in the following manner
<customProps>key1|value1,key2|value2</customProps>
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="KAFKA" class="ru.sberned.kafkalogback.KafkaAppender">
<topic><your_topic_name></topic>
<bootstrapServers><server1>,<server2></bootstrapServers>
<valueSerializer>org.apache.kafka.common.serialization.StringSerializer</valueSerializer>
<failOnStartup>false</failOnStartup>
<customProp>acks|all</customProp>
<layout class="ru.sberned.kafkalogback.CustomJsonLayout">
<timestampFormat>yyyy-MM-dd'T'HH:mm:ssZ</timestampFormat>
<jsonFormatter class="ch.qos.logback.contrib.jackson.JacksonJsonFormatter"/>
<additionalField>environment|${KAFKA_ENVIRONMENT:-dev}</additionalField>
</layout>
</appender>
<appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
<neverBlock>true</neverBlock>
<includeCallerData>true</includeCallerData>
<appender-ref ref="KAFKA" />
</appender>
<!-- Do not sent kafka client logs to kafka. This way you could fill all the queue of AsyncAppender-->
<logger name="org.apache.kafka" level="INFO" additivity="false">
<appender-ref ref="CONSOLE" />
<appender-ref ref="FILE" />
</logger>
<!-- Please note. CONSOLE and FILE appenders are not defined in this example -->
<root level="TRACE">
<appender-ref ref="CONSOLE" />
<appender-ref ref="FILE" />
<appender-ref ref="ASYNC" />
</root>
</configuration>