最好用的 Kafka Json Logger Java客户端。

slf4j4json

最好用的 Kafka Json Logger 库;不尝试一下可惜了!

Description

一款为 Kafka 提供的 json logger 客户端,支持将 json 格式的 log 输出到 kafka、文件、控制台。

支持 slf4j 的全部功能。

比 KafkaLog4jAppender 更好用,可配置性更好。

支持 close logger, 在程序关闭之前 flush log to kafka。

支持链式编程模式,方便用户使用。

maven dependency

  1. 添加repository
  1. <repositories>
  2. <repositories>
  3. <repository>
  4. <id>release</id>
  5. <url>https://raw.github.com/joyang1/slf4j4json/mvn-repo/</url>
  6. <snapshots>
  7. <enabled>true</enabled>
  8. <updatePolicy>always</updatePolicy>
  9. </snapshots>
  10. </repository>
  11. </repositories>
  12. </repositories>
  1. 添加dependency
  1. <dependency>
  2. <groupId>cn.tommyyang</groupId>
  3. <artifactId>slf4j4json</artifactId>
  4. <version>1.4.0</version>
  5. </dependency>

使用

需要配置log4j.properties

因为该 jar 包同样是依赖于 slf4j, 所以按 log4j 配置 log4j.properties 即可正常使用。

log4j.properties 的详细配置说明请参考log4j 配置说明

  1. log4j.rootLogger=DEBUG,console
  2. #输出日志到控制台
  3. log4j.appender.console=org.apache.log4j.ConsoleAppender
  4. log4j.appender.console.Threshold=all
  5. log4j.appender.console.layout=org.apache.log4j.PatternLayout
  6. log4j.appender.console.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c\:%L]-[%p] %m%n

slf4j4json使用

  1. 直接打印

    跟 slf4j 类似,不过该库提供链式编程方式,便于用户使用。

  1. //通过LoggerFactory获取一个logger
  2. final static Logger logger = LoggerFactory.getLogger(Test.class);
  3. //打印必须调用log()方法
  4. logger.info().field("key1", "value1").intField("key2", 1).log();
  5. logger.warn().field("key1", "value1").intField("key2", 1).log();
  6. logger.debug().strField("key1", "value1").longField("key2", 1L).log();
  7. logger.trace().strField("key1", "value1").intField("key2", 1).log();
  8. logger.error().strField("key1", "value1").intField("key2", 1).log();
  1. 比如有一些键值对要重复赋值,使用getLogger方法,实例如下

  1. JsonLogger jsonLogger = logger.info().strField("appname", "app").getLogger();
  2. jsonLogger.strField("msg","infotest1").intField("port", 2).log();
  3. jsonLogger.field("msg","infotest2").longField("long", 23L).log();
  1. 1.4.0更新, 只提供getLogger方法

配置了 LogConfig 则打印 log 到 kafka,否则打印 log 到 file;

如果打印 log 到 file 文件或者控制台,则需要配置 log4j.properties,具体如何配置见使用

如果只用打印 log 到 kafka,则不用配置 log4j.properties。


  1. LogConfig conf = new LogConfig("Vinci", LogLevel.INFO, "localhost:9092", "admin-app-log");
  2. LoggerFactory.openKafkaLogger(conf);
  3. Logger logger = LoggerFactory.getLogger();
  4. logger.info().strField("test", "test-info").log();
  5. logger.error().strField("test", "test-error").log();
  6. logger.warn().strField("test", "test-warn").log();
  7. logger.debug().strField("test", "test-debug").log();

输出


  1. {"key1":"value1","key2":1,"index":"server-end-log","host":"DESKTOP-2B1VG6J","level":"info","time":1535021174}

version

  • 1.0版本

    • 实现 JsonLog For Java 的基本功能

    • 使用 KafkaLog4jAppender 打印 log 到 Kafka

  • 1.1版本

    • 修复JsonLogger jsonLogger = logger.info().strField("appname", "app").getLogger(); 出现重复内容的bug
  • 1.2版本

    • 去掉log中自带的index键值对

    • repository修改


      1. <repositories>
      2. <repository>
      3. <id>release</id>
      4. <url>https://raw.github.com/joyang1/slf4j4json/mvn-repo/</url>
      5. <snapshots>
      6. <enabled>true</enabled>
      7. <updatePolicy>always</updatePolicy>
      8. </snapshots>
      9. </repository>
      10. </repositories>
  • 1.3.0版本

    • 添加kafka logger的实现,批量打印log到kafka

    • 10s或者5m flush一次

  • 1.4.0版本

    • 优化logger实现

欢迎 fork 和 star

Github地址:slf4j4json

最好用的 Kafka Json Logger Java客户端,赶紧尝试一下的更多相关文章

  1. 4 kafka集群部署及kafka生产者java客户端编程 + kafka消费者java客户端编程

    本博文的主要内容有   kafka的单机模式部署 kafka的分布式模式部署 生产者java客户端编程 消费者java客户端编程 运行kafka ,需要依赖 zookeeper,你可以使用已有的 zo ...

  2. java kafka单列模式生产者客户端

    1.所需要的依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="ht ...

  3. 报错:java.lang.AbstractMethodError: nl.techop.kafka.KafkaHttpMetricsReporter.logger()Lcom/typesafe/scalalogging/Logger;

    报错背景: CDH启动kafka的时候出现报错情况,并且报错的节点挂掉. 报错现象: Exiting Kafka due to fatal exception java.lang.AbstractMe ...

  4. 大数据学习day31------spark11-------1. Redis的安装和启动,2 redis客户端 3.Redis的数据类型 4. kafka(安装和常用命令)5.kafka java客户端

    1. Redis Redis是目前一个非常优秀的key-value存储系统(内存的NoSQL数据库).和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list ...

  5. kafka java客户端编程

    kafka_2.10-0.8.1.1 maven <dependencies> <dependency> <groupId>org.apache.kafka< ...

  6. kafka的Java客户端示例代码(kafka_2.11-0.8.2.2)

    1.使用Producer API发送消息到Kafka 从版本0.9开始被KafkaProducer替代. HelloWorldProducer.java package cn.ljh.kafka.ka ...

  7. kafka的Java客户端示例代码(kafka_2.12-0.10.2.1)

    使用0.9开始增加的KafkaProducer和KafkaConsumer. Pom.xml <project xmlns="http://maven.apache.org/POM/4 ...

  8. elasticsearch系列七:ES Java客户端-Elasticsearch Java client(ES Client 简介、Java REST Client、Java Client、Spring Data Elasticsearch)

    一.ES Client 简介 1. ES是一个服务,采用C/S结构 2. 回顾 ES的架构 3. ES支持的客户端连接方式 3.1 REST API ,端口 9200 这种连接方式对应于架构图中的RE ...

  9. Solr JAVA客户端SolrJ 4.9使用示例教程

    http://my.oschina.net/cloudcoder/blog/305024 简介 SolrJ是操作Solr的JAVA客户端,它提供了增加.修改.删除.查询Solr索引的JAVA接口.So ...

随机推荐

  1. SQLAlchemy 增删改查 一对一 多对多

    首先要导入SQLAIchemy模块 from sqlalchemy.ect.declaative import declarative_base 创建orm基类 Base = declarative_ ...

  2. POJ1523 SPF 单点故障

    POJ1523 题意很简单,求删除割点后原先割点所在的无向连通图被分成了几个连通部分(原题说prevent at least one pair of available nodes from bein ...

  3. 内存泄露问题改进(转自vczh)

    参考:http://www.cppblog.com/vczh/archive/2010/06/22/118493.html 参考:https://www.cnblogs.com/skynet/arch ...

  4. dede后台系统基本参数空白怎么办?

    dede后台系统基本参数空白怎么办? 如图:   解决办法:还原dede_sysconfig表即可 后台 系统-SQL命令行工具,执行如下sql delete table dede_sysconfig ...

  5. 3,ActiveMQ-入门(基于JMS发布订阅模型)

    一.Pub/Sub-发布/订阅消息传递模型 在发布/订阅消息模型中,发布者发布一个消息,该消息通过topic传递给所有的客户端.在这种模型中,发布者和订阅者彼此不知道对方,是匿名的且可以动态发布和订阅 ...

  6. Comet OJ - Contest #7 D 机器学习题 斜率优化 + 未调完

    Code: #include <cstdio> #include <algorithm> #include <cstring> #define setIO(s) f ...

  7. time,sys,os模块

      1.time模块 a:结构化时间:struct_time:通过time.localtime获取到一个时间对象,通过这个对象得到对象属性 ****localtime()如果没有参数,默认返回是一个时 ...

  8. Bellman-ford算法与SPFA算法思想详解及判负权环(负权回路)

    我们先看一下负权环为什么这么特殊:在一个图中,只要一个多边结构不是负权环,那么重复经过此结构时就会导致代价不断增大.在多边结构中唯有负权环会导致重复经过时代价不断减小,故在一些最短路径算法中可能会凭借 ...

  9. css3 clac()方法

    calc()从字面上可以把它理解成为一个函数function,英文单词是calculate(计算),是CSS3的一个新功能,用来显示元素的长度. 他的用途就是,如果你有一个元素,加了padding或者 ...

  10. Java中高级面试题(1)

    List和Set比较,各自的子类比较 对比一:Arraylist与LinkedList的比较 1.ArrayList是实现了基于动态数组的数据结构,因为地址连续,一旦数据存储好了,查询操作效率会比较高 ...