java代码日志文件 java写日志文件

JAVA的log4j如何实现程序重新启动会自动生成新的日志文件,文件名可以是当前日期log4j输出日志文件时以当前日期为文件名
在初始化日志配置后加入以下代码:
Java代码Appender appender = LogManager.getLoggerRepository().getRootLogger().getAppender("A2");if(appender instanceof FileAppender){FileAppender fileAppender = (FileAppender)appender;fileAppender.setFile( "log/"DateUtil.getFormatDate()".log");fileAppender.activateOptions();}//DateUtil.getFormatDate();是指得到当前格式化后的日期
要是通过配置生成日期是不可能的
java代码中添加日志怎么会呢...log4j多好用啊,你先下一个log4j的jar包, 导入到项目后, 在网上找一个log4j.properties文件(必须有这个文件), 把它放到src目录下(必须), 然后需要打日志的时候logger.info("...")调用就好了啊, 没啥别的啊... 毕竟只是个日志文件, 如果你要打到文件里, 在log4j.properties文件里设置路径参数就好了, 纯手打望采纳!
log4j的使用,即java该如何使用日志文件java使用日志文件log4j的方法:
1、 新建一个Java工程 , 导入Log4j包,pom文件中对应的配置代码如下:
!-- log4j support --
dependency
groupIdlog4j/groupId
artifactIdlog4j/artifactId
version1.2.17/version
/dependency
2、resources目录下创建log4j.properties文件
### 设置###
log4j.rootLogger = debug,stdout,D,E
### 输出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
### 输出DEBUG 级别以上的日志到=/home/duqi/logs/debug.log ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = /home/duqi/logs/debug.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}[ %t:%r ] - [ %p ]%m%n
### 输出ERROR 级别以上的日志到=/home/admin/logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =/home/admin/logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}[ %t:%r ] - [ %p ]%m%n
3、输出日志的例子如下
package com.javadu.log;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Log4JTest {
private static final Logger logger = LoggerFactory.getLogger(Log4JTest.class);
public static void main(String[] args) {
// 记录debug级别的信息
logger.debug("This is debug message.");
// 记录info级别的信息
logger.info("This is info message.");
// 记录error级别的信息
logger.error("This is error message.");
}
}
4、输出结果
首先 , 控制台输入如下图所示:
然后 , 查看/Users/duqi/logs目录下的debug.log和error.log文件,内容分别如下,可以看出:
您可以为Java程序创建日志文件的4种方法是什么?日志打印一般为控制台打印 , 文件打?。菘獯蛴〉榷嘀?。平时写代码时打控制台可以直观看到 。正式发布时打印在文件可以保存运行记录 。数据库也一样 。
如果不是这样的话你是不是想问怎么配置?具体配置内容可以直接写一份博客了,这里不够用 。
如果配置文件内容可以写xml,properties,yam , java中 。
这种最好查博客,这里只能给查询方向 。
java中怎么在log4g的日志文件里添加第一步 引入jar包:
第二步:
编写java代码:
import org.apache.log4j.Logger;
public class Hello {
private static Logger logger = Logger.getLogger(Hello.class);
public static void main(String args[]){
System.out.println("hello word!");
logger.debug("hello word!");
}
}
第三步:
编写
log4j.properties文件:
内容如下:
log4j.rootLogger=debug,R
log4j.appender.R=org.apache.log4j.ConsoleAppender
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%d{yyyy/MM/dd HH:mm:ss} %4r %5p %c{2}:%L - %m%n
这个文件需要放在src目录下
最后运行程序:会在控制台打出日志信息
为什么java导入日志包后就能用关于日志 , 在大家的印象中都是比较简单的,只须引入了相关依赖包 , 剩下的事情就是在项目中“尽情”的打印我们需要的信息了 。但是往往越简单的东西越容易让我们忽视,从而导致一些不该有的bug发生 , 作为一名严谨的程序员,怎么能让这种事情发生呢?所以下面我们就来了解一下关于日志的那些正确使用姿势 。
正文
日志规范
命名
首先是日志文件的命名,尽量要做到见名知意 , 团队里面也必须使用统一的命名规范,不然“脏乱差”的日志文件会影响大家排查问题的效率 。这里推荐以“projectName_logName_logType.log”来命名,这样通过名字就可以清晰的知道该日志文件是属于哪个项目,什么类型,有什么作用 。例如在我们MessageServer项目中监控Rabbitmq 消费者相关的日志文件名可以定义成“messageserver_rabbitmqconsumer_monitor.log” 。
保存时间
关于日志保存的时间,普通的日志文件建议保留15天,若比较重要的可根据实际情况延长,具体请参考各自服务器磁盘空间以及日志文件大小作出最优选择 。
日志级别
常见的日志级别有以下:
DEBUG级别:记录调试程序相关的信息 。
INFO级别:记录程序正常运行有意义的信息 。
WARN级别:记录可能会出现潜在错误的信息 。
ERROR级别:记录当前程序出错的信息,需要被关注处理 。
Fatal级别:表示出现了严重错误,程序将会中断执行 。
建议在项目中使用这四种级别 , ERROR、WARN、INFO 、DEBUG 。
正确姿势
1、提前判断日志级别
//条件判断if(logger.isDebugEnabled){ logger.debug("server info , id : "id", user : "user);}//使用占位符logger.debug("server info , id : {}, user : {}",id,user);
对于DEBUG,INFO级别的日志,在我们的程序中是比较高频的存在,当我们的项目大了 , 日志变多了,这时候为了程序运行的效率,我们必须以条件判断或者占位符的方式来打印日志 。为什么呢?假如我们项目中配置的日志级别为WARN,那么对于我们下面的日志输出语句‘ logger.debug("server info , id : "id", user : "user);’,虽然该日志不会被打?。侨椿嶂葱凶址唇拥牟僮?nbsp;, 这里我们的user是一个实例对象,所以还会执行toString方法,这样就白白浪费了不少系统的资源 。
2、避免多余日志输出
在我们的生产环境中,一般禁止DEBUG日志的输出,其打印的频率是非常高的,容易对正常运行的程序造成严重的影响,在我们最近的项目中就有遇到过类似的情况 。
那么这时候该学会使用additivity属性
logger name="xx" additivity="true"
在这边配置成true的话,也就是默认的情况,这时候当前Logger会继承父Logger的Appender,说白了就是当前日志的输出除了输出在当前日志文件以外,还会输出至父文件里 。所以一般情况下 , 我们为了避免重复打印,会将这个参数设置成false,以减少不必要的输出 。
3、保证日志记录信息完整
在我们的代码中,日志记录的内容要包含异常的堆栈,请勿随意输出“XX出错”等简单的日志,这对于错误的调试毫无帮助 。所以我们在记录异常的时候一定要带上堆栈信息,例如
logger.error("rabbitmq consumer error,cause : " e.getMessage(),e); 语言 方法
9347 eS694L2Q42
3RFHn语音主播
1391 2010-10-26 06:46:57
切记在输出对象实例的时候,须确保对象重写了toString方法 , 否则只会输出其hashCode值 。
4、定义logger变量为static
private static final Logger logger = LoggerFactory.getLogger(XX.class);
确保一个对象只使用一个Logger对象,避免每次都重新创建,否则可能会导致OOM 。
5、正确使用日志级别
try{ //..}catch(xx){ logger.info(..); }
【java代码日志文件 java写日志文件】这样一来,本来是ERROR的信息,全都打印在INFO日志文件里了,不知情的同事还会在死盯着错误日志,而且还找不出问题,多影响工作效率是吧?
6、推荐使用slf4j logback组合
logback库里自身就已经实现了slf4j的接口 , 就无需引入多余的适配器了,而且logback也具有更多的优点,建议新项目可以使用这个组合 。还有一点需要注意 , 当引入slf4j后,要注意其实际使用的日志库是否是由我们引入的,也有可能会使用了我们第三方依赖包所带入的日志库,这样就可能会导致我们的日志失效 。
7、日志的聚合分析
日志的聚合可以把位于不同服务器之间的日志统一起来分析处理,如今ELK技术栈亦或者的EFG(fluentd elasticsearch grafana)等都是一些比较成熟的开源解决方案 。
拿ELK来说,可以在我们的服务器上直接通过logstash来读取应用打印的日志文件 , 或者也可以在我们项目中的日志配置文件里配置好相关的socket信息,打印的时候直接把日志信息输出至logstash 。再交由elasticsearch存储,kibana展示 。
关于java代码日志文件和java写日志文件的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读