1.      概述

任何一个系统中,日志都是不可缺少的,现在Apache提供了两套日志工具,一个就是Log4j,另一个是本文要给出例子的LogKit。

Log4j和LogKit有很多相似的地方。比如,Log4j提供5级日志:DEBUG、INFO、WARN、ERROR和FATAL,LogKit也提供5级日志:DEBUG、INFO、WARN、ERROR和FATAL-ERROR,除了级别5的命名不一样,实质是一样的。

LogKit同样提供目录功能,而对日志格式的控制,在Log4j中是使用Layout,而在LogKit中使用的是Formatter。对于日志输出,Log4j使用的是Appender,LogKit则使用了更为直接的名字:Target。

这个文章当然不是用来对比LogKit和Log4j的不同的,而是想说明,为什么在有了Log4j这样的日志工具以后,还需要使用LogKit。

使用LogKit的原因是:ContextLogTargets。使用Log4j的时候,日志的内容只能是一句话,而使用LogKit,你可以记录很多项内容,甚至可以各项内容记录到对应的数据库字段中。如果使用Log4j存储日志到不同的存储介质,如数据库,需要使用Appender,而LogKit已经可以支持多种存储目标。

下面的程序将用一个产品检测线(ProductChecker)作为示范。

2.      一个例子

产品检测线是用来检查产品是否合格使用的,要求记录产品编号、产品是否通过检测、简要说明三个项目。而LogKit会把级别、时间和信息也记录下作为参考。

在免费的Mysql数据库上建立logkitexample表的sql语句:

create table logkigexample

(

logmessage varcher(1000),

logpriority varchar(20),

logtime datetime,

productnumber varchar(100),

productpass varchar(10),

productexplain varchar(100)

)

在这个产品检测线中,产品是否通过分三种情况:ok、soso和bad。其中,ok代表产品质量好,soso代表质量一般,bad代表没有通过检查,需要重新制造。

代码如下:

package logkitexample;

import java.lang.*;

import java.util.*;

import org.apache.log.*;

import org.apache.log.output.db.*;

public class ProductChecker

{

static private org.apache.log.Logger LoggerProductChecker;

public static void main(String[] argv)

{

ProductChecker _p = new ProductChecker();

_p.initLogKit();

//模拟产品检查的结果

Random _checkrandom = new Random();

int _checkresult;

for (int i = 1; i <= 20; i++)

{

_checkresult = (int)(_checkrandom.nextFloat() * 3);

switch (_checkresult)

{

case 0:

ContextMap.bind(_p.getProductCheckerMap("no." + String.valueOf(i), "ok", "ok"));

LoggerProductChecker.info("ProductChecker Pass");

break;

case 1:

ContextMap.bind(_p.getProductCheckerMap("no." + String.valueOf(i), "soso", "check again"));

LoggerProductChecker.warn("ProductChecker No Good");

break;

case 2:

ContextMap.bind(_p.getProductCheckerMap("no." + String.valueOf(i), "bad", "redo"));

LoggerProductChecker.error("ProductChecker Bad");

break;

}

}

}

private void initLogKit()

{

try

{

//登记使用的数据源

Class.forName("org.gjt.mm.mysql.Driver");

DefaultDataSource _dataSource = new DefaultDataSource("jdbc:mysql://localhost/logkitexample" , "root", "");

//登记对应的列映射关系

ColumnInfo[] _columeProductChecker = {

new ColumnInfo( "logmessage", ColumnType.MESSAGE, null ),

new ColumnInfo( "logpriority", ColumnType.PRIORITY, null ),

new ColumnInfo( "logtime", ColumnType.TIME, null ),

new ColumnInfo( "productnumber", ColumnType.CONTEXT,"productnumber" ),

new ColumnInfo( "productpass", ColumnType.CONTEXT,"productpass" ),

new ColumnInfo( "productexplain", ColumnType.CONTEXT,"productexplain" ),

};

//登记JDBCTarget

DefaultJDBCTarget _targetProductChecker =

new DefaultJDBCTarget(_dataSource, "logkitexample", _columeProductChecker);

//登记日志的层次

org.apache.log.Hierarchy _hierarchy = new org.apache.log.Hierarchy();

LoggerProductChecker = _hierarchy.getLoggerFor("logkitexample");

//设置ProductChecker的日志记录器使用的Target

LoggerProductChecker.setLogTargets(

new LogTarget[] {_targetProductChecker});

//设置日志级别为DEBUG

LoggerProductChecker.setPriority(org.apache.log.Priority.DEBUG);

}

catch (Exception e)

{

System.out.println("LogKitinit error");

}

}

/** 获得产品日志的ContextMap */

private org.apache.log.ContextMap getProductCheckerMap(String _ProductNumber, String _ProductPass, String _ProductExplain)

{

org.apache.log.ContextMap _cm = new org.apache.log.ContextMap();

_cm.set("productnumber", _ProductNumber);

_cm.set("productpass", _ProductPass);

_cm.set("productexplain", _ProductExplain);

return (_cm);

}

}

3.      LogKit的存储目标

LogKit支持多种不同的日志存储目标,称为LogTargets,包括有文件、数据库、IRC频道、JMS,甚至是任意的Sockets定义。

LogKit中一个日志记录器可以对应不同的LogTargets,使用Filter可以根据不同的日志级别记录到不同的LogTargets中。比如日志都是存放早数据库的,但是FATAL_ERROR要存放在文本文件,因为这种情况下,很可能数据库都是不可用的。

LogKit还支持异步的LogTargets,适用于不能实时响应的LogTargets,如邮件系统等。

4.      参考资料

LogKit项目主页:http://jakarta.apache.org/avalon/logkit/index.html

使用LogKit进行日志操作的更多相关文章

  1. mysql 查看 删除 日志操作总结(包括单独和主从mysql)

    我们可以在mysql的安装目录下看到mysql的二进制日志文件,如mysql-bin.000***等,很多人都不及时的处理,导致整个硬盘被塞满也是有可能的.这些是数据库的操作日志.它记录了我们平时使用 ...

  2. SQL Server 最小化日志操作解析,应用

    Sql Server 中数据库在BULK_LOGGED/SIMPLE模式下的一些操作会采用最小化日志的记录方式,以减小tran log落盘日志量从而提高整体性能. 这里我简单介绍下哪些操作在什么样的情 ...

  3. 使用Log4j进行日志操作

    使用Log4j进行日志操作 一.Log4j简介 (1)概述 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接字服 ...

  4. SQL Server 最小化日志操作解析,应用[手稿]

    Sql Server 中数据库在BULK_LOGGED/SIMPLE模式下的一些操作会采用最小化日志的记录方式,以减小tran log落盘日志量从而提高整体性能. 这里我简单介绍下哪些操作在什么样的情 ...

  5. xBIM 日志操作

    目录 xBIM 应用与学习 (一) xBIM 应用与学习 (二) xBIM 基本的模型操作 xBIM 日志操作 XBIM 3D 墙壁案例 xBIM 格式之间转换 xBIM 使用Linq 来优化查询 x ...

  6. python中的日志操作和发送邮件

    1.python中的日志操作 安装log模块:pip install nnlog 参数:my_log = nnlog.Logger('server_log.log',level='debug',bac ...

  7. 从零开始的Python学习Episode 14——日志操作

    日志操作 一.logging模块 %(message)s 日志信息 %(levelno)s 日志级别 datefmt 设置时间格式 filename 设置日志保存的路径 level 设置日志记录的级别 ...

  8. Java 使用Log4J进行日志操作

    使用Log4J进行日志操作   Log4J简介   Log4J是Apache的一个开放源代码项目,它是一个日志操作包,通过使用Log4J,可以指定日志信息输出的目的地,如控制台.文件.CUI组件.NT ...

  9. Python之日志操作(logging)

    import logging   1.自定义日志级别,日志格式,输出位置 logging.basicConfig( level=logging.DEBUG, format='%(asctime)s | ...

随机推荐

  1. 继承自 DevExpress 17.2 的自定义控件如何在工具箱显示

    最近把DevExpress版本从13.1升级到了17.2,结果发现继承自DevExpress的自定义控件居然在工具箱中消失了,弄了两天还是没有任何头绪,部分自定义Dev控件可以正常出现,但大部分自定义 ...

  2. 04_Struts2标签

    1.通用标签: property标签: 用来输出值栈属性的值 如果value属性没有给出,ValueStack值栈栈顶对象的值被输出 许多情况下,EL表达式可以提供更简洁的语法 url标签: url方 ...

  3. springMVC源码解析--HandlerMethodArgumentResolverComposite参数解析器集合(二)

    上一篇博客springMVC源码分析--HandlerMethodArgumentResolver参数解析器(一)中我们已经介绍了参数解析相关的东西,并且也提到了HandlerMethodArgume ...

  4. windows pe

    下载adk https://www.microsoft.com/en-us/download/details.aspx?id=30652 安装 C:\Program Files (x86)\Windo ...

  5. FindBugs入门简介(eclipse安装使用实例)

    前言:一般公司都会有一些开发规范,但是事实上,简单看那么一两遍并不能养成习惯,或者将这些规范记住.特别的,对于一些新手,写的代码往往会很糟糕.回头看看你一两年前写的代码就会知道,所谓的"糟糕 ...

  6. java实例化对象

    摘要:分享牛,分享牛分享,java类加载机制,java实例化对象,java实例化对象机制,java基础. java是如何实例化对象的呢?以及实例化对象的先后顺序是什么?下面我们以测试的方式说明. 1. ...

  7. Scala:函数式编程之下划线underscore

    http://blog.csdn.net/pipisorry/article/details/52913548 python参考[python函数式编程:apply, map, lambda和偏函数] ...

  8. 操作系统服务:OS模块

    http://blog.csdn.net/pipisorry/article/details/52454486 一般的操作系统服务之OS模块Generic Operating System Servi ...

  9. Java并发框架——什么是AQS框架

    什么是AQS框架 1995年sun公司发布了第一个java语言版本,可以说从jdk1.1到jdk1.4期间java的使用主要是在移动应用和中小型企业应用中,在此类领域中基本不用设计大型并发场景,当然也 ...

  10. 19 Handler 子线程向主线程发送信息

    案例一 Message创建三种方法: package com.example.day19_handler_demo1; import android.os.Bundle; import android ...