在我的工作场所,我们写了一个自定义的log4j appender,它将日志消息写入数据库(异步使用专用线程,因此不会导致性能下降).
我更喜欢写日志文件 – 基于数据库的日志更容易查询和分析.
我更喜欢写日志文件 – 基于数据库的日志更容易查询和分析.
是否有开源解决方案(对于log4j,或任何其他java记录器)?
我们的appender有些东西,我想看一个替代方法:
>日志异常(呃!)
>数据库写入来自一个单独的线程/池
我们的appender支持以下列,我想在任何我们找到的解决方案中看到它们.
> LogId
>时间
>消息
> stacktrace
>进程ID
>线程ID
>机器名称
>组件
>级别(debug / info / warn / …)
> ThreadName
解决方法
还有一个由log4j提供的DBAppender类(log4j需要一组特定的表以使用此appender进行日志记录).
http://logging.apache.org/log4j/companions/receivers/apidocs/org/apache/log4j/db/DBAppender.html
http://logging.apache.org/log4j/companions/receivers/apidocs/org/apache/log4j/db/DBAppender.html
这里有一个更新的非Apache jdbc记录器,您可能还想尝试:
http://www.dankomannhaupt.de/projects/index.html