我们遇到了无法覆盖log4j.properties的问题。
这是我们的代码Dockerfile
FROM confluentinc/cp-zookeeper:6.2.0
# RUN chmod 777 /etc/kafka/connect-log4j.properties
USER root
COPY ./log4j.properties /etc/kafka/log4j.properties
log4j.properties
log4j.rootLogger=INFO, ROLLINGFILE
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d] %p %m (%c)%n
log4j.appender.ROLLINGFILE=org.apache.log4j.RollingFileAppender
log4j.appender.ROLLINGFILE.Threshold=DEBUG
log4j.appender.ROLLINGFILE.File=/var/log/zookeeper.log
注意:-我们正在使用这个融合的Zookeeper'confluentinc/cp-Zookeeper:6.2.0'
2条答案
按热度按时间s2j5cfk01#
或者,也可以复制模板文件
其中
k5ifujac2#
你不应该在log4j文件中复制。这会在运行时被这里定义的Jinja 2模板覆盖-https://github.com/confluentinc/kafka-images/blob/master/zookeeper/include/etc/confluent/docker/log4j.properties.template
要设置自定义记录器,只需将
ZOOKEEPER_LOG4J_LOGGERS
的环境变量添加到现有映像中,而不必创建自己的环境变量您还应该使用Docker日志记录桥,而不是强制进程写入容器中的文件