基于java.util.logging实现轻量级日志记录库(增加根据当前类class初始化,修复线程池模型(javaEE)下的堆栈轨迹顺序与当前调用方法不一致问题)
2017-04-09 22:16
1101 查看
前言:
本章介绍自己写的基于java.util.logging的轻量级日志记录库(baseLog)。
该版本的日志记录库犹如其名,baseLog,是个实现日志记录基本功能的小库,适合小型项目使用,方便快捷,简单实用,没有使用缓冲区,日志写出操作都是同步操作。
很早就想过要写两个日志记录器,一个用于大项目(logGuide),解决多线程模型下的日志记录并发性能问题;一个是基于Java的logging库写的简单同步日志记录,适合小项目,简单、便捷。
之前写过一个logGuide,该日志记录系统没有使用任何第三方库,也没有使用Java自带的logging库,并且首次使用了缓冲区来解决由于日志数量过大导致的项目死锁问题,后来使用了logback,觉得现在的日志记录框架已经很全面了,所以不再继续写下去了。
2、四种不同等级的日志记录
3、单线程下不需要使用当前类的class作为初始化参数,用以提高性能
4、线程池模型下必须使用当前类的class作为初始化参数(与其他日志记录框架相同)以此来保证日志记录中的正确的方法堆栈轨迹
5、基于properties的简单配置
6、配置支持控制是否开启控制台、文件的日志输出以及日期输出格式
7、可设置自定义等级的日志输出到文件、控制台
#日志名称
logName=测试
#是否开启日志
log=true
#日志记录等级
logLevel=all
#是否在控制台显示消息
consoleLog=true
#控制台显示的日志级别(显示全部)
consoleLogLevel=all
#是否开启日志文件
fileLog=true
#日志文件记录等级(全部)
fileLogLevel=all
#日志文件路径
filelogPath=log.log
#是否接着上次的文件继续写出日志消息
fileAppend=true
#日期格式
dateFormat=yyyy-MM-dd HH:mm:ss
Logger log=BaseLogger.getLogger();
Logger log2=BaseLogger.getLogger(LogTest.class);
不同等级的日志可以调用专用的记录方法也可以调用log()方法来记录不同等级的日志
日志记录器通用接口:
public void debug(String msg);
public void warn(String msg);
public void err(String msg);
public void info(String msg);
public void log(String level, String msg);
public void debug(String msg, Throwable thrown);
public void warn(String msg, Throwable thrown);
public void err(String msg, Throwable thrown);
public void info(String msg, Throwable thrown);
public void log(String level, String msg, Throwable thrown);
public void debug(String className, String methodName,String msg);
public void warn(String className, String methodName,String msg);
public void err(String className, String methodName,String msg);
public void info(String className, String methodName,String msg);
public void log(String className, String methodName,String level, String msg);
public void debug(String className, String methodName,String msg, Throwable thrown);
public void warn(String className, String methodName,String msg, Throwable thrown);
public void err(String className, String methodName,String msg, Throwable thrown);
public void info(String className, String methodName,String msg, Throwable thrown);
下载地址:http://download.csdn.net/detail/eguid_1/9808783
本章介绍自己写的基于java.util.logging的轻量级日志记录库(baseLog)。
该版本的日志记录库犹如其名,baseLog,是个实现日志记录基本功能的小库,适合小型项目使用,方便快捷,简单实用,没有使用缓冲区,日志写出操作都是同步操作。
很早就想过要写两个日志记录器,一个用于大项目(logGuide),解决多线程模型下的日志记录并发性能问题;一个是基于Java的logging库写的简单同步日志记录,适合小项目,简单、便捷。
之前写过一个logGuide,该日志记录系统没有使用任何第三方库,也没有使用Java自带的logging库,并且首次使用了缓冲区来解决由于日志数量过大导致的项目死锁问题,后来使用了logback,觉得现在的日志记录框架已经很全面了,所以不再继续写下去了。
一、实现功能
1、基于java.util.logging2、四种不同等级的日志记录
3、单线程下不需要使用当前类的class作为初始化参数,用以提高性能
4、线程池模型下必须使用当前类的class作为初始化参数(与其他日志记录框架相同)以此来保证日志记录中的正确的方法堆栈轨迹
5、基于properties的简单配置
6、配置支持控制是否开启控制台、文件的日志输出以及日期输出格式
7、可设置自定义等级的日志输出到文件、控制台
二、配置日志记录
配置文件名必须为:logconf.properties#日志名称
logName=测试
#是否开启日志
log=true
#日志记录等级
logLevel=all
#是否在控制台显示消息
consoleLog=true
#控制台显示的日志级别(显示全部)
consoleLogLevel=all
#是否开启日志文件
fileLog=true
#日志文件记录等级(全部)
fileLogLevel=all
#日志文件路径
filelogPath=log.log
#是否接着上次的文件继续写出日志消息
fileAppend=true
#日期格式
dateFormat=yyyy-MM-dd HH:mm:ss
三、日志的使用
可以使用两种方式初始化Logger log=BaseLogger.getLogger();
Logger log2=BaseLogger.getLogger(LogTest.class);
不同等级的日志可以调用专用的记录方法也可以调用log()方法来记录不同等级的日志
日志记录器通用接口:
public void debug(String msg);
public void warn(String msg);
public void err(String msg);
public void info(String msg);
public void log(String level, String msg);
public void debug(String msg, Throwable thrown);
public void warn(String msg, Throwable thrown);
public void err(String msg, Throwable thrown);
public void info(String msg, Throwable thrown);
public void log(String level, String msg, Throwable thrown);
public void debug(String className, String methodName,String msg);
public void warn(String className, String methodName,String msg);
public void err(String className, String methodName,String msg);
public void info(String className, String methodName,String msg);
public void log(String className, String methodName,String level, String msg);
public void debug(String className, String methodName,String msg, Throwable thrown);
public void warn(String className, String methodName,String msg, Throwable thrown);
public void err(String className, String methodName,String msg, Throwable thrown);
public void info(String className, String methodName,String msg, Throwable thrown);
四、项目地址及下载地址
github:稍后下载地址:http://download.csdn.net/detail/eguid_1/9808783
相关文章推荐
- 基于java.util.logging实现轻量级日志记录库(增加根据当前类class初始化,修复线程池模型(javaEE)下的堆栈轨迹顺序与当前调用方法不一致问题)
- Asp.Net Core 2.0 项目实战(9) 日志记录,基于Nlog或Microsoft.Extensions.Logging的实现及调用实例
- Java使用注解和动态代理实现方法调用时的日志记录示例
- Python记录详细调用堆栈日志的方法
- java 初始化顺序以及由此可能引发的构造方法的潜在问题。
- 记录一个java.util.logging.Logger 使用中关于时间格式的问题
- 如何使用java.util.logging中的Logger来记录日志
- java继承时的方法调用顺序记录
- Java学习记录(一):Java中继承与静态static、非静态、构造方法等的初始化顺序
- (转)javabean操作文件正确,但是Jsp调用javabean时文件路径出错问题解决之JavaBean访问本地文件实现路径无关实现方法
- java动态加载指定的类或者jar包反射调用其方法-涉及其他jar中的类就报ClassNotFound问题分析及解决思路
- java中构造代码块、方法调用顺序问题
- javabean操作文件正确,但是Jsp调用javabean时文件路径出错问题解决之JavaBean访问本地文件实现路径无关实现方法
- class中对实例字段进行初始化调用构造方法的问题
- java中继承期间父子类型的初始化顺序以及重写方法的调用规则
- 关于java的多态方法调用顺序的问题
- java 扫描Class文件获取接口对应的实现类及其方法util
- java 中获得当前方法名及行号.....---可以做日志记录及跟踪
- Java反射:根据方法名动态调用方法,解决商品动态属性取值问题。
- JAVA问题记录-利用Spring AOP来拦截特定方法上的注解并根据业务修改注解字段值