修改Zookeeper输出日志 zookeeper.out输出路径

     使用过zookeeper的小伙伴都知道,当前终端处于哪个目录,执行完zkServer.sh start命令, zookeeper.out就会写在哪个目录,下次想看zookeeper日志的时候,又忘记上次在哪执行的命令啦,这真的很蛋疼(虽然可以每次固定在某个目录执行),在多次痛苦之后,决定修改日志输出到固定目录,方便问题定位。

   

查看bin目录下的zkEnv.sh找到了这一行,发现如果没有配置ZOO_LOG_DIR,默认就是保存在终端所在当前目录下,所以果断修改(或者可以在上面配置ZOO_LOG_DIR这个变量)

ZOO_LOG_DIR="$ZOOKEEPER_PREFIX/logs"

 将日志文件写到zookeeper安装目录下的logs文件夹中(logs不需要创建,它会自己创建)

 美中不足的是在你设定的目录中, 仍会有zookeeper.out文件存在, 虽然它的size=0,究其原因是因为zkServer.sh会使用nohup进行zookeeper的启动, 然而nohup必然会输出一个日志文件到你设置的目录中,

相关代码如下, 需要将此处的逻辑修改掉, 就可以将zookeeper.out移除啦,

最后修改 bin/zkServer.sh

_ZOO_DAEMON_OUT="$ZOO_LOG_DIR/zookeeper.log"

ok,完成!

既然改都改了,为什么不改的彻底一点呢?让他按照天进行滚动

继续修改bin目录下的zkEnv.sh,修改为:

将
ZOO_LOG4J_PROP="INFO,CONSOLE"
修改为:
ZOO_LOG4J_PROP="INFO,ROLLINGFILE"

修改Zookeeper输出日志 zookeeper.out输出路径_第1张图片

修改conf/log4j.properties文件

修改Zookeeper输出日志 zookeeper.out输出路径_第2张图片

          其它可配置参数:

  

log4j.appender.ROLLINGFILE.File=zookeeper.log
log4j.appender.ROLLINGFILE.DataPattern='.'yyyy-MM-dd-HH-mm
log4j.appender.ROLLINGFILE.Threshold=debug
log4j.appender.ROLLINGFILE.encoding=UTF-8
log4j.appender.ROLLINGFILE.Append=false
log4j.appender.ROLLINGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.ROLLINGFILE.layout.ConversionPattern= [%d{yyyy-MM-dd HH\:mm\:ss}]%-5p %c(line\:%L) %x-%m%n

DailyRollingFileAppender特点是固定周期时间生成一个日志文件,比如,默认情况是每天生成一个文件。这种日志可以方便根据时间来定位日志位置,使日志清晰易查。但是这种日志有个不好地方是,不能限制日志数量,MaxBackupIndex属性和MaxFileSize在DailyRollingFileAppender中是无效的,这个还是按照自己的需求来定!

          所以还需要自己弄个Crontab定期清理日志

你可能感兴趣的:(大数据,大数据踩过的坑)