java - Kafka Log4j 附加程序不发送消息

标签 java log4j apache-kafka

我对 apache Kafka 和 log4j 很陌生。我正在尝试将日志消息发送到 Kafka。这是我的 log4j 属性文件

log4j.rootLogger=INFO, stdout

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L %% %m%n

log4j.appender.KAFKA=kafka.producer.KafkaLog4jAppender
log4j.appender.KAFKA.BrokerList=localhost:9092
log4j.appender.KAFKA.Topic=kfkLogs


log4j.appender.KAFKA.SerializerClass=kafka.producer.DefaultStringEncoder
log4j.appender.KAFKA.layout=org.apache.log4j.PatternLayout
log4j.appender.KAFKA.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L %% - %m%n

log4j.logger.logGen=DEBUG, KAFKA

但是,我无法在我的消费者中收到任何消息。我已经用其他一些生产者代码测试了消费者,它工作得很好。

另外,我收到此警告

log4j:WARN No such property [serializerClass] in kafka.producer.KafkaLog4jAppender.

编辑

这是生成我的日志消息的代码

    package logGen;

import org.apache.log4j.Logger;

public class TestLog4j {

    static Logger log = Logger.getLogger(TestLog4j.class.getName());

    public static void main(String[] args) {

        log.debug("Debug message");

        log.info("Info message");

        log.error("Error Message");

        log.fatal("Fatal Message");

        log.warn("Warn Message");

        log.trace("Trace Message");
    }

}

此外,如果我使用类似的方法将日志消息写入文件

log4j.appender.KAFKA=org.apache.log4j.DailyRollingFileAppender
log4j.appender.KAFKA.DatePattern='.'yyyy-MM-dd-HH
log4j.appender.KAFKA.File=logs/server.log

我可以在 server.log 文件中看到日志消息

谢谢大家的建议。我认为我看到的奇怪行为可能与我的卡夫卡设置有关。这是我用来启动我的 kafka 服务器的 server.properties 文件的内容。你能看出什么奇怪的地方吗?

broker.id=0

port=9092

num.network.threads=3

num.io.threads=8

socket.send.buffer.bytes=102400

socket.receive.buffer.bytes=102400

socket.request.max.bytes=104857600

log.dirs=/Users/xyz/kafka/kafka-logs

num.partitions=1

num.recovery.threads.per.data.dir=1

log.retention.hours=168

log.segment.bytes=1073741824

log.retention.check.interval.ms=300000

log.cleaner.enable=false

zookeeper.connect=localhost:2181

zookeeper.connection.timeout.ms=6000

delete.topic.enable=true

最佳答案

我查看了 KafkaLog4jAppender.scala 的源代码,以下是自版本 0.8.2.1 起 Kafka log4j Appender 的 validexhaustive 属性: topic 、brokerList、压缩类型、requiredNumAcks、syncSend。

对我有用的log4j.properties如下:

log4j.rootLogger=ERROR, stdout

log4j.logger.logGen=DEBUG, KAFKA

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L %% %m%n

log4j.appender.KAFKA=kafka.producer.KafkaLog4jAppender
log4j.appender.KAFKA.topic=LOG
log4j.appender.KAFKA.brokerList=localhost:9092
log4j.appender.KAFKA.compressionType=none
log4j.appender.KAFKA.requiredNumAcks=0
log4j.appender.KAFKA.syncSend=true
log4j.appender.KAFKA.layout=org.apache.log4j.PatternLayout
log4j.appender.KAFKA.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L %% - %m%n

关于java - Kafka Log4j 附加程序不发送消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32301129/

相关文章:

java - 变量名称是否有任何限制,以免与包名称冲突?

java - 为什么 ConsoleAppender 抛出 "no output stream or file set for the appender named [null]"?

java - 禁用外部库上的日志记录框架

apache-kafka - Kafka 消费者无提示连接到代理失败

java - System.getCurrentTimeMillis() 的性能开销

java - Elasticsearch 1.3。 - 从 Java 调用自定义 REST 端点

ssl - 在 Kafka Strimzi 中使用我的可信证书

ssl - SSL 配置后 Apache Kafka 不启动

Java:如何将同一数组中的数组元素一一求和

Spring 幕后日志记录