日志文件要保存到哪个磁盘相关的配置
查看FileAppender的源码
看到属性信息
protected boolean fileAppend; 表示是否追加信息,通过构造方法赋值为true
protected int bufferSize; 缓冲区的大小,通过构造方法赋值为8192
继续观察,找到setFile方法,这个方法就是用来指定文件位置的方法
通过ognl,可以推断setFile方法操作的属性就是file
如果有输出中文的需求怎么办
观察FileAppender的父类
找到protected String encoding;属性
#配置appender输出方式 输出到文件
log4j.appender.file=org.apache.log4j.FileAppender
#配置输出到文件中的格式
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.conversionPattern=[%-10p]%r %c%t%d{yyyy-MM-dd HH:mm:ss:SSS} %m%n
#第一个file是我们自己命名的appenderName,第二个file是用来指定文件位置的属性
log4j.appender.file.file=D://test//log4j.log
#配置输出字符编码
log4j.appender.file.encoding=UTF-8
protected boolean fileAppend;
protected String fileName;
protected boolean bufferedIO;
protected int bufferSize;
public FileAppender() {
this.fileAppend = true;
this.fileName = null;
this.bufferedIO = false;
this.bufferSize = 8192;
}
public FileAppender(Layout layout, String filename, boolean append, boolean bufferedIO, int bufferSize) throws IOException {
this.fileAppend = true;
this.fileName = null;
this.bufferedIO = false;
this.bufferSize = 8192;
this.layout = layout;
this.setFile(filename, append, bufferedIO, bufferSize);
}
public FileAppender(Layout layout, String filename, boolean append) throws IOException {
this.fileAppend = true;
this.fileName = null;
this.bufferedIO = false;
this.bufferSize = 8192;
this.layout = layout;
this.setFile(filename, append, false, this.bufferSize);
}
public FileAppender(Layout layout, String filename) throws IOException {
this(layout, filename, true);
}
public void setFile(String file) {
String val = file.trim();
this.fileName = val;
}