AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 413988
Accepted
pyramid13
pyramid13
Asked: 2018-01-01 06:55:35 +0800 CST2018-01-01 06:55:35 +0800 CST 2018-01-01 06:55:35 +0800 CST

警告找不到记录器的附加程序(org.apache.zookeeper.ZooKeeper)

  • 772

我在这条路径上安装了 zookeeper /opt/zookeeper。

我zoo-1.cfg的/opt/zookeeper/conf/:

#Node1
 dataDir=/var/zookeeper/data-1
 clientPort=2181
 server.1=127.0.0.1:2888:3888
 server.2=127.0.0.1:2889:3889
 server.3=127.0.0.1:2890:3890

我log4j.properties的/opt/zookeeper/conf/:

zookeeper.root.logger=DEBUG, SYSLOG8
log4j.rootLogger=${zookeeper.root.logger}
zookeeper.log.dir=/var/log/zookeeper
zookeeper.log.file=zookeeper.log
zookeeper.log.threshold=DEBUG
zookeeper.tracelog.dir=.
zookeeper.tracelog.file=zookeeper_trace.log
#-------------------------------------------------
log4j.appender.SYSLOG8=org.apache.log4j.net.SyslogAppender
log4j.appender.SYSLOG8.threshold=DEBUG
log4j.appender.SYSLOG8.syslogHost=192.168.26.16
log4j.appender.SYSLOG8.facility=USER
log4j.appender.SYSLOG8.layout=org.apache.log4j.PatternLayout
log4j.appender.SYSLOG8.layout.conversionPattern=[%p] %c:%L - %m$

当我想与客户端连接时,出现此错误:

[root@server-1 bin]# sh zkCli.sh -server 127.0.0.1:2182
log4j:ERROR Could not find value for key log4j.appender.CONSOLE
log4j:ERROR Could not instantiate appender named "CONSOLE".
Connecting to 127.0.0.1:2182
log4j:WARN No appenders could be found for logger 
(org.apache.zookeeper.ZooKeeper).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for 
more info.
Welcome to ZooKeeper!
JLine support is enabled

WATCHER::

WatchedEvent state:SyncConnected type:None path:null
[zk: 127.0.0.1:2182(CONNECTED) 0] 

我的rsyslog.cnf:

$ModLoad imudp
$UDPServerRun 514
$ModLoad imtcp
$InputTCPServerRun 514
*.*  @192.168.26.16:514

请说明错误的原因。还需要做什么才能在 syslog 中注册 zookeeper 日志?谢谢。

logs rsyslog
  • 2 2 个回答
  • 5373 Views

2 个回答

  • Voted
  1. Best Answer
    deoren
    2018-01-01T15:32:11+08:002018-01-01T15:32:11+08:00

    你有log4j.appender.SYSLOG8. 你确定它不应该是log4j.appender.SYSLOG吗?

    来自blog.trifork.com的示例配置块:

    log4j.rootLogger=信息,系统日志
    
    log4j.appender.SYSLOG=org.apache.log4j.net.SyslogAppender
    log4j.appender.SYSLOG.syslogHost=127.0.0.1
    log4j.appender.SYSLOG.layout=org.apache.log4j.PatternLayout
    log4j.appender.SYSLOG.layout.conversionPattern=%d{ISO8601} %-5p [%t] %c{2} %x - %m%n
    log4j.appender.SYSLOG.Facility=LOCAL1
    

    另请参阅https://stackoverflow.com/questions/33177076/escape-newlines-in-zookeeper-logs-using-log4j-1-2-syslogappender

    • 0
  2. pyramid13
    2018-01-02T21:26:14+08:002018-01-02T21:26:14+08:00

    我的问题已经解决了。使用默认配置文件时出现问题。默认配置文件。/opt/zookeeper/conf/log4j.propertise

    [root@server-1 conf]# cat tmp/log4j.properties.orgin 
    # Define some default values that can be overridden by system properties
    #zookeeper.root.logger=DEBUG, CONSOLE, ROLLINGFILE
    #zookeeper.console.threshold=DEBUG
    #zookeeper.log.dir=.
    #zookeeper.log.file=zookeeper.log
    #zookeeper.log.threshold=ERROR
    #zookeeper.tracelog.dir=.
    #zookeeper.tracelog.file=zookeeper_trace.log
    
    #
    # ZooKeeper Logging Configuration
    #
    
    # Format is "<default threshold> (, <appender>)+
    
    # DEFAULT: console appender only
    log4j.rootLogger=DEBUG, CONSOLE, ROLLINGFILE
    
    # Example with rolling log file
    #log4j.rootLogger=DEBUG, CONSOLE, ROLLINGFILE
    
    # Example with rolling log file and tracing
    #log4j.rootLogger=TRACE, CONSOLE, ROLLINGFILE, TRACEFILE
    
    #
    # Log ERROR level and above messages to the console
    #
    log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
    log4j.appender.CONSOLE.Threshold=DEBUG
    log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
    log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L] - %m%n
    
    #
    # Add ROLLINGFILE to rootLogger to get log file output
    #    Log DEBUG level and above messages to a log file
    log4j.appender.ROLLINGFILE=org.apache.log4j.RollingFileAppender
    log4j.appender.ROLLINGFILE.Threshold=DEBUG
    log4j.appender.ROLLINGFILE.File=/var/log/zookeeper/rolling.log
    
    # Max log file size of 10MB
    log4j.appender.ROLLINGFILE.MaxFileSize=10MB
    # uncomment the next line to limit number of backup files
    #log4j.appender.ROLLINGFILE.MaxBackupIndex=10
    
    log4j.appender.ROLLINGFILE.layout=org.apache.log4j.PatternLayout
    log4j.appender.ROLLINGFILE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L] - %m%n
    
    #
    # Add TRACEFILE to rootLogger to get log file output
    #    Log DEBUG level and above messages to a log file
    log4j.appender.TRACEFILE=org.apache.log4j.FileAppender
    log4j.appender.TRACEFILE.Threshold=TRACE
    log4j.appender.TRACEFILE.File=${zookeeper.tracelog.dir}/${zookeeper.tracelog.file}
    
    log4j.appender.TRACEFILE.layout=org.apache.log4j.PatternLayout
    ### Notice we are including log4j's NDC here (%x)
    log4j.appender.TRACEFILE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L][%x] - %m%n
    

    该文件使用变量!我删除了所有变量,只插入rsyslog代码,我也检查ROLLINGFILE了,没关系。你甚至可以在这个log4j中找到这个文件。所以,我删除了所有变量,只放置了原始代码。‍‍‍‍

    # Define some default values that can be overridden by system properties
    log4j.rootLogger=INFO, SYSLOG
    log4j.appender.SYSLOG=org.apache.log4j.net.SyslogAppender
    log4j.appender.SYSLOG.syslogHost=192.168.26.16
    log4j.appender.SYSLOG.layout=org.apache.log4j.PatternLayout
    log4j.appender.SYSLOG.layout.conversionPattern=%d{ISO8601} %-5p [%t] %c{2} %x - %m%n
    log4j.appender.SYSLOG.Facility=LOCAL1
    log4j.appender.SYSLOG.Threshold=debug
    log4j.appender.SYSLOG.FacilityPrinting=true
    

    我的rsyslog配置是:/etc/rsyslog.d/zookeeper.conf

    template(name="zkformat" type="list") {
      property(name="timestamp" dateFormat="rfc3339")
      constant(value=" ")
      property(name="hostname")
      constant(value=" ")
      property(name="syslogtag")
      constant(value=" ")
      property(name="msg" spifno1stsp="on" )
      property(name="msg" droplastlf="on" )
      constant(value="\n")
    }
    ruleset(name="zookeeper"){
            if $programname  contains 'zookeeper' or $msg contains 'zookeeper'  then {
                    action(type="omfile" file="/var/log/zookeeper/zoosys.log" Template="zkformat")
            }
    }
    input (type="imudp" port="514" ruleset="zookeeper") 
    

    log4j.propertise对于ROLLINGFILE:

    # Define some default values that can be overridden by system properties
    log4j.rootLogger=INFO, ROLLINGFILE
    
    log4j.appender.ROLLINGFILE=org.apache.log4j.RollingFileAppender
    log4j.appender.ROLLINGFILE.Threshold=DEBUG
    log4j.appender.ROLLINGFILE.File=/var/log/zookeeper/rollingfile.log
    
    log4j.appender.ROLLINGFILE.MaxFileSize=10MB
    log4j.appender.ROLLINGFILE.layout=org.apache.log4j.PatternLayout
    log4j.appender.ROLLINGFILE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L] - %m%n
    

    最后我的输出文件log:

    [root@server-1 conf]# tail /var/log/zookeeper/zoosys.log    
    2018-01-01T09:49:34.059426-05:00 slavedns local1:  2018-01-01 09:49:34,058 INFO  [main] zookeeper.ZooKeeper  - Client environment:user.home=/root
    2018-01-01T09:49:34.060238-05:00 slavedns local1:  2018-01-01 09:49:34,059 INFO  [main] zookeeper.ZooKeeper  - Client environment:user.dir=/opt/zookeeper-3.4.10/conf
    2018-01-01T09:49:34.069773-05:00 slavedns local1:  2018-01-01 09:49:34,068 INFO  [main] zookeeper.ZooKeeper  - Initiating client connection, connectString=192.168.26.16:2182 sessionTimeout=30000 watcher=org.apache.zookeeper.ZooKeeperMain$MyWatcher@46f7f36a
    2018-01-01T09:49:34.131923-05:00 slavedns local1:  2018-01-01 09:49:34,126 INFO  [main-SendThread(192.168.26.16:2182)] zookeeper.ClientCnxn  - Opening socket connection to server 192.168.26.16/192.168.26.16:2182. Will not attempt to authenticate using SASL (unknown error)
    2018-01-01T09:49:34.230174-05:00 slavedns local1:  2018-01-01 09:49:34,227 INFO  [main-SendThread(192.168.26.16:2182)] zookeeper.ClientCnxn  - Socket connection established to 192.168.26.16/192.168.26.16:2182, initiating session
    2018-01-01T09:49:34.240287-05:00 slavedns local1:  2018-01-01 09:49:34,239 INFO  [main-SendThread(192.168.26.16:2182)] zookeeper.ClientCnxn  - Session establishment complete on server 192.168.26.16/192.168.26.16:2182, sessionid = 0x260b1fa599e0002, negotiated timeout = 30000
    2018-01-01T11:11:14.478194-05:00 slavedns local1:  2018-01-01 11:11:14,477 INFO  [main] zookeeper.ZooKeeper  - Session: 0x160b1f776080005 closed
    2018-01-01T11:11:14.481063-05:00 slavedns local1:  2018-01-01 11:11:14,480 INFO  [main-EventThread] zookeeper.ClientCnxn  - EventThread shut down for session: 0x160b1f776080005
    2018-01-01T11:11:26.424726-05:00 slavedns local1:  2018-01-01 11:11:26,423 INFO  [main] zookeeper.ZooKeeper  - Session: 0x260b1fa599e0002 closed
    2018-01-01T11:11:26.424726-05:00 slavedns local1:  2018-01-01 11:11:26,424 INFO  [main-EventThread] zookeeper.ClientCnxn  - EventThread shut down for session: 0x260b1fa599e0002
    [root@server-1 conf]# 
    
    • 0

相关问题

  • 在被 logrotate 删除之前传输旧的日志文件

  • 使用 sed 清理日志文件中的长路径

  • logrotate 描述符可以处理多个通配符吗?

  • systemd:如何将标准输出重定向到日志文件

  • journalctl 中的区分级别

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve