Log4j官方文档翻译(四、如何在java中输出日志消息)
时间:2022-04-22
本文章向大家介绍Log4j官方文档翻译(四、如何在java中输出日志消息),主要内容包括基本的例子、在java程序中使用log4j、编译与执行、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
我们已经创建来配置文件,本章详细的介绍下如何生成调试信息,并把他们转化成文本文件。
基本的例子
下面就是创建的一个基本的例子:
log4j.properties
的内容为:
log = /usr/home/log4j
log4j.rootLogger = DEBUG, FILE
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n
看看它都做了什么工作:
- root logger的级别是DEBUG,并且绑定了一个名字叫做FILE的appender。
- appender FILE定义为org.apache.log4j.FileAppender,并且把内容写到log.out文件中。
- layout格式定义为%m%n,意思是每条信息都会跟随一个换行符
在java程序中使用log4j
下面的java类中简单的进行了初始化、使用、log4j日志输出等工作:
import org.apache.log4j.Logger;
import java.io.;
import java.sql.SQLException;
import java.util.;
public class log4jExample{
/* Get actual class name to be printed on */
static Logger log = Logger.getLogger(log4jExample.class.getName());
public static void main(String[] args)throws IOException,SQLException{
log.debug("Hello this is a debug message");
log.info("Hello this is an info message");
}
}
编译与执行
这里是编译与执行上面代码的步骤:保证你在执行前设置了PATH和CLASSPATH等变量
所有的类库文件都应该放在CLASSPATH
里面,你的log4j.properties
文件也应该放在PATH
里面.然后按照下面的步骤:
- 创建
log4j.properties
- 创建
log4jExample.java
并且编译它 - 执行
log4jExample
二进制文件
你可以在/usr/home/log4j/log.out文件中,得到下面的信息:
Hello this is a debug message
Hello this is an info message
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- rsyslog磁盘辅助(Disk-Assisted)模式踩坑记
- Guava字符串的处理
- Phishing
- Guava Cache用法介绍(极简版)
- Linux Netcat 命令——网络工具中的瑞士军刀
- __all__ 是干嘛用的?
- 业务视角谈谈Kafka(第一篇)
- 面试必问:session,cookie和token的区别
- 14-2常见软件包管理任务
- Pytest之skip、skipif、xfail
- 为什么spring不推荐@Autowired注入,提示:Field injection is not recommended
- 使用springboot发送复杂类型正文的邮件
- 业务视角谈谈Kafka(第三篇)
- 图文详解互联网根基之HTTP
- Jenkins部署异常:报错 TomcatManagerException: FAIL - Unable to delete