利用Log4j进行系统日志管理

简介:

 

Log4jApache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。(附件为Log4j日志包下载)
这是百度百科对Log4j的介绍,上面还有其他比如Log4j的配置等内容。由于Log4j的开源,配置简单等特点,使其成为系统日志管理的首选。所谓日志(Log)是指系统所指定对象的某些操作和其操作结果按时间有序的集合。每个日志文件由日志记录组成,每条日志记录描述了一次单独的系统事件。通常情况下,系统日志是用户可以直接阅读的文本文件,其中包含了一个时间戳和一个信息或者子系统所特有的其他信息。日志文件为服务器、工作站、防火墙和应用软件等IT资源相关活动记录必要的、有价值的信息,这对系统监控、查询、报表和安全审计是十分重要的。
SSH框架下使用Log4j进行日志管理的代码极其简单,而且可维护性极强,可以称之为相当强。我在用的时候就是从以前别的项目中拷进来Log4j.properties,稍做修改即可重复利用。
我们只需要在一个地方进行配置即可,当然在此之前log4j通用日志包要导进工程里来。博客末尾提供这个日志包的下载。
打开Log4j.properties文件(在这里我们使用的配置文件是.properties格式,关于Log4j配置文件可以查看后面所附文章一),将一下代码考入。
################################################################################
# \u9002\u7528\u4e8e\u540e\u53f0\u8f93\u51fa\u8c03\u8bd5
log4j.appender.CONSOLE = org.apache.log4j.ConsoleAppender
log4j.appender.Threshold = DEBUG
log4j.appender.CONSOLE.Target = System.out
log4j.appender.CONSOLE.layout = org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern = [framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n
 
################################################################################
#\u9002\u7528\u4e8elog\u6587\u4ef6\u8bb0\u5f55
#log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
 
#log4j.appender.file.datePattern = '.'yyyy-MM-dd-HH-mm
#log4j.appender.file.MaxFileSize=100KB
 #Keep one backup file
#log4j.appender.file.MaxBackupIndex=1
#log4j.appender.file.append = true
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=[%d] [%p] -- %m%n
#log4j.appender.file.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:},%2r] [%p] - %m%n
 
################################################################################
#\u9002\u7528\u4e8elog\u6570\u636e\u5e93\u8bb0\u5f55
log4j.appender.DATABASE = org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL = jdbc:mysql://192.133.126.46/db_gao
log4j.appender.DATABASE.driver = com.mysql.jdbc.Driver
log4j.appender.DATABASE.user = root
log4j.appender.DATABASE.password = cumt
log4j.appender.DATABASE.sql = INSERT INTO system_log(createDate,priority, category, message) values('%d{yyyy-MM-dd HH:mm:ss}','%-5p', '%c', '%m')
log4j.appender.DATABASE.layout = org.apache.log4j.PatternLayout
log4j.appender.DATABASE.layout.ConversionPattern = %m
 
 
 
#priority level:   DEBUG < INFO < WARN < ERROR < FATAL
 
不管是Struts还是Struts2Action里面的代码是一样的:
 
 
public   class  ContactAction  extends  BaseAction {
    private   static  Logger  logger  = Logger.getLogger(ContactAction. class );
。。。
 
     public  String add1()  throws  Exception {
      ...
logger .warn(StringUtil.getLogString( "gaochao" " 进入了主题为的回复留言信息页面! " ));
        return   SUCCESS ;
    }
 
数据库设计:
/*
MySQL Data Transfer
Source Host: 192.133.126.46
Source Database: db_gao
Target Host: 192.133.126.46
Target Database: db_gao
Date: 2009-6-9 18:31:05
*/
 
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for system_log
-- ----------------------------
CREATE TABLE `system_log` (
  `id` int(11) NOT NULL auto_increment,
  `createDate` varchar(64) default NULL,
  `category` varchar(600) default NULL,
  `priority` varchar(60) default NULL,
  `message` varchar(4000) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3139 DEFAULT CHARSET=gbk;
 
-- ----------------------------
-- Records
-- ----------------------------
 
 
 
 



       本文转自 gaochaojs 51CTO博客,原文链接: http://blog.51cto.com/jncumter/166027 ,如需转载请自行联系原作者

相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
相关文章
WGLOG日志管理系统是怎么收集日志的
WGLOG通过部署Agent客户端采集日志,Agent持续收集指定日志文件并上报Server,Server负责展示与分析。Agent与Server需保持相同版本。官网下载地址:www.wgstart.com
|
6月前
|
Prometheus 监控 Cloud Native
基于docker搭建监控系统&日志收集
Prometheus 是一款由 SoundCloud 开发的开源监控报警系统及时序数据库(TSDB),支持多维数据模型和灵活查询语言,适用于大规模集群监控。它通过 HTTP 拉取数据,支持服务发现、多种图表展示(如 Grafana),并可结合 Loki 实现日志聚合。本文介绍其架构、部署及与 Docker 集成的监控方案。
585 122
基于docker搭建监控系统&日志收集
|
9月前
|
监控 API 开发工具
HarmonyOS Next的HiLog日志系统完全指南:从入门到精通
本文深入解析HarmonyOS Next的HiLog日志系统,涵盖日志级别、核心API、隐私保护与高级回调功能,助你从入门到精通掌握这一重要开发工具。
|
6月前
|
Ubuntu
在Ubuntu系统上设置syslog日志轮替与大小限制
请注意,在修改任何系统级别配置之前,请务必备份相应得原始档案并理解每项变更可能带来得影响。
751 2
|
10月前
|
监控 容灾 算法
阿里云 SLS 多云日志接入最佳实践:链路、成本与高可用性优化
本文探讨了如何高效、经济且可靠地将海外应用与基础设施日志统一采集至阿里云日志服务(SLS),解决全球化业务扩展中的关键挑战。重点介绍了高性能日志采集Agent(iLogtail/LoongCollector)在海外场景的应用,推荐使用LoongCollector以获得更优的稳定性和网络容错能力。同时分析了多种网络接入方案,包括公网直连、全球加速优化、阿里云内网及专线/CEN/VPN接入等,并提供了成本优化策略和多目标发送配置指导,帮助企业构建稳定、低成本、高可用的全球日志系统。
1012 54
|
8月前
|
存储
WGLOG日志管理系统可以采集网络设备的日志吗
WGLOG日志审计系统提供开放接口,支持外部获取日志内容后发送至该接口,实现日志的存储与分析。详情请访问:https://www.wgstart.com/wglog/docs9.html
|
12月前
|
存储 消息中间件 缓存
MiniMax GenAI 可观测性分析 :基于阿里云 SelectDB 构建 PB 级别日志系统
基于阿里云SelectDB,MiniMax构建了覆盖国内及海外业务的日志可观测中台,总体数据规模超过数PB,日均新增日志写入量达数百TB。系统在P95分位查询场景下的响应时间小于3秒,峰值时刻实现了超过10GB/s的读写吞吐。通过存算分离、高压缩比算法和单副本热缓存等技术手段,MiniMax在优化性能的同时显著降低了建设成本,计算资源用量降低40%,热数据存储用量降低50%,为未来业务的高速发展和技术演进奠定了坚实基础。
536 1
MiniMax GenAI 可观测性分析 :基于阿里云 SelectDB 构建 PB 级别日志系统
|
监控 Java 应用服务中间件
Tomcat log日志解析
理解和解析Tomcat日志文件对于诊断和解决Web应用中的问题至关重要。通过分析 `catalina.out`、`localhost.log`、`localhost_access_log.*.txt`、`manager.log`和 `host-manager.log`等日志文件,可以快速定位和解决问题,确保Tomcat服务器的稳定运行。掌握这些日志解析技巧,可以显著提高运维和开发效率。
1356 13
|
存储 JSON Go
PHP 日志系统的最佳搭档:一个 Go 写的远程日志收集服务
为了不再 SSH 上去翻日志,我写了个 Go 小脚本,用来接收远程日志。PHP 负责记录日志,Go 负责存储和展示,按天存储、支持 API 访问、可远程管理,终于能第一时间知道项目炸了。
268 10