文件管理 · 2022年8月25日

log4j输出文件位置|java工程中如何使用log4j输出指定路径日志文件是java工程不是web工程谢谢

① log4j centos 位置

log4j centos 位置:entos 中的主要log文件都存储在 /var/log/ 目录下面: 1. apache log的位置 a. 默认情况下是:/var/log/httpd/ 目录下面,主要查看错误是 error_log b

② 如何查找log4j加载配置文件的位置

自动加载配置文件:(1)如果采用log4j输出日志,要对log4j加载配置文件的过程有所了解。log4j启动时,默认会寻找source folder下的log4j.xml配置文件,若没有,会寻找log4j.properties文件。然后加载配置。配置文件放置位置正确,不用在程序中手动加载log4j配置文件。如果将配置文件放到了config文件夹下,在build Path中设置下就好了。若要手动加载配置文件如下:(1)PropertyConfigurator.configure("log4j.properties") 默认读取的是项目根目录的路径。此时的log4j.properties要放在项目目录下。

③ log4j,选择日志输出位置

多定义几个不就ok了?log4j.rootLogger=info,CONSOLE,FILEOUTlog4j.addivity.org.apache=true# CONSOLElog4j.appender.CONSOLE=org.apache.log4j.ConsoleAppenderlog4j.appender.Threshold=DEBUGlog4j.appender.CONSOLE.Target=System.outlog4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout#log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d – %c -%-4r [%t] %-5p %c %x – %m%nlog4j.appender.CONSOLE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH\:mm\:ss} \:%m%n ## FILEOUTlog4j.appender.FILEOUT=org.apache.log4j.RollingFileAppenderlog4j.appender.FILEOUT.File=${catalina.home}\\file.loglog4j.appender.fileout.MaxFileSize=100000KB# default is true,append to the file; if false, the replace the log file whenever restart system log4j.appender.FILEOUT.Append=true#RollingFileAppender没有DatePattern这个属性log4j.appender.FILEOUT.layout=org.apache.log4j.PatternLayout#log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d – %c -%-4r [%t] %-5p %c %x – %m%nlog4j.appender.FILEOUT.layout.ConversionPattern=[%-5p]_%d{yyyy-MM-dd HH:mm:ss} :%m%n

④ LOG4J 的日志写到了哪里

va代码 # log4j configuration file ################################################################## # Pattern to output the caller's file name and line number. ################################################################## #等级为INFO的日志信息输出到ota,ota的定义在下面的代码,可以任意起名。# #等级可分为OFF、 FATAL、ERROR、WARN、INFO、DEBUG、ALL,# #如果配置OFF则不打出任何信息,# #如果配置为INFO这样只显示INFO, WARN, ERROR的log信息,而DEBUG信息不会被显示,具体讲解可参照第三部分定义配置文件中的logger。# log4j.rootLogger=INFO,CONSOLE,fileout log4j.logger.fileout=INFO,fileout log4j.logger.OTA=INFO,OTA #配置输出的类型# #org.apache.log4j.ConsoleAppender(控制台),# #org.apache.log4j.FileAppender(文件),# #org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),# #org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)# #org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)# log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender #此句为定义名为stdout的输出端的layout是哪种类型,# #org.apache.log4j.HTMLLayout(以HTML表格形式布局),# #org.apache.log4j.PatternLayout(可以灵活地指定布局模式),# #org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),# #org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)# log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout #pattern布局就要指定的打印信息的具体格式ConversionPattern,打印参数如下:# #%m 输出代码中指定的消息# #Ip 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL# #%r 输出自应用启动到输出该log信息耗费的毫秒数# #%c 输出所属的类目,通常就是所在类的全名# #%t 输出产生该日志事件的线程名# #%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”# #%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921# #%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。$ #[OTC]是log信息的开头,可以为任意字符,一般为项目简称。# #输出的信息# #[OTC] DEBUG [main] AbstractBeanFactory.getBean(189) | Returning cached instance of singleton bean 'MyAutoProxy'# # log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %m%n #—- save to log file log4j.appender.fileout=org.apache.log4j.RollingFileAppender log4j.appender.fileout.File=e:/logs/run.log log4j.appender.fileout.encoding=UTF-8 log4j.appender.fileout.Threshold=DEBUG log4j.appender.fileout.MaxFileSize=4MB log4j.appender.fileout.MaxBackupIndex=10 log4j.appender.fileout.layout=org.apache.log4j.PatternLayout log4j.appender.fileout.layout.ConversionPattern=%-5p [%d] %C – %m%n #—- save to log file log4j.appender.OTA=org.apache.log4j.RollingFileAppender log4j.appender.OTA.File=e:/logs/run2.log log4j.appender.OTA.encoding=UTF-8 log4j.appender.OTA.Threshold=DEBUG log4j.appender.OTA.MaxFileSize=4MB log4j.appender.OTA.MaxBackupIndex=10 log4j.appender.OTA.layout=org.apache.log4j.PatternLayout log4j.appender.OTA.layout.ConversionPattern=%-5p [%d] %C – %m%n log4j.logger.com.ibatis = DEBUG log4j.logger.com.ibatis.common.jdbc.SimpleDataSource = DEBUG log4j.logger.com.ibatis.common.jdbc.ScriptRunner = DEBUG log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate = DEBUG log4j.logger.java.sql.Connection = DEBUG log4j.logger.java.sql.Statement = DEBUG log4j.logger.java.sql.PreparedStatement = DEBUG, fileout log4j.logger.java.sql.ResultSet = DEBUG Java代码 //它会写到哪里? //经测试写到了console 和run.log Logger logger = Logger.getLogger(getClass); //经测试写到了console 和run.log Logger rootLogger = Logger.getRootLogger(); //经测试写到了console 和run.log run2.log Logger fileout = Logger.getLogger("fileout"); 经测试写到了console 和run.log run2.log Logger ota = Logger.getLogger("OTA"); logger.info("CLASS"); rootLogger.info("ROOT"); fileout.info("FILEOUT"); ota.info("OTA"); 总结: 其中 Logger.getLogger(String name); name即为appender的name log4j.appender.fileout即为fileout Logger.getLogger(Class clazz); 即获取class.name后调用 Logger.getLogger(String name); root为所有日志的根 所以通过输出结果来看,所有自定义的appender都是继承自root的 它会 1、先输出到appender定义的设备中(console file 或其他),如果name没有对应的appender则不会输出任何内容 2、再输出到root Class 和String的差别还是比较大的。

⑤ Log4J配置文件里的日志文件路径问题!!!急~

给你一个我们的项目文件自己看吧。。希望老板别发现。。。# Global logging configurationlog4j.rootLogger=INFO,file# SqlMap logging configuration…log4j.logger.com.ibatis=INFOlog4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUGlog4j.logger.com.ibatis.common.jdbc.ScriptRunner=INFOlog4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=INFOlog4j.logger.java.sql.Connection=INFOlog4j.logger.java.sql.Statement=INFOlog4j.logger.java.sql.PreparedStatement=INFOlog4j.logger.java.sql.ResultSet=INFO# Console output…log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Threshold=DEBUGlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%d %p [%c] – %m%nlog4j.appender.stdout.Target=System.out###########################log4j.appender.stdout.layout.ConversionPattern=[framework] %d – %c -%-4r [%t] %-5p %c %x – %m%n#log4j.appender.stdout.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n# File output by days…log4j.appender.file=org.apache.log4j.DailyRollingFileAppenderlog4j.appender.file.Threshold=ERRORlog4j.appender.file.file=${catalina.base}/logs/psp_error.loglog4j.appender.file.MaxFileSize=2000KBlog4j.appender.file.DatePattern="."yyyy-MM-ddlog4j.appender.file.layout=org.apache.log4j.PatternLayoutlog4j.appender.file.layout.ConversionPattern=%d %p [%c] – %m%n# HTML output…log4j.appender.sql_html=org.apache.log4j.RollingFileAppender log4j.appender.sql_html.Threshold=DEBUGlog4j.appender.sql_html.File=${catalina.base}/logs/psp_sql.html log4j.appender.sql_html.MaxFileSize=5000KBlog4j.appender.sql_html.MaxBackupIndex=1 log4j.appender.sql_html.layout=org.apache.log4j.HTMLLayout

⑥ java工程中如何使用log4j输出指定路径日志文件,是java工程,不是web工程,谢谢

此文档放在项目编译文件.class相同的位置### set log levels ###log4j.rootLogger = debug , stdout , D### 输出到控制台 ###log4j.appender.stdout = org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target = System.outlog4j.appender.stdout.layout = org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{1}:%L – %m%n### 输出到日志文件 ###log4j.appender.D = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.D.File = logs/log.loglog4j.appender.D.Append = truelog4j.appender.D.Threshold = DEBUGlog4j.appender.D.layout = org.apache.log4j.PatternLayoutlog4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] – [ %p ] %m%n### 保存异常信息到单独文件 ###log4j.appender.D = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.D.File = logs/error.loglog4j.appender.D.Append = truelog4j.appender.D.Threshold = ERRORlog4j.appender.D.layout = org.apache.log4j.PatternLayoutlog4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] – [ %p ] %m%n配置获取方法: PropertyConfigurator.configure( "D:\\Project Files\\myeclipse\\commontest\\bin\\log\\log4j\\log4j.properties" ); Logger log=Logger. getLogger(TestLog4j.class); log.warn( "嘿嘿"); log.debug( "呜呜"); log.error( "错啦");

⑦ log4j怎么配置日志输出路径

以DailyRollingFileAppender 为例:假设每天一个日志文件有以下设置:log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender log4j.appender.A1.File=app.loglog4j.appender.A1.DatePattern='.'yyyy-MM-ddlog4j.appender.A1.layout=org.apache.log4j.PatternLayoutlog4j.appender.A1.layout.ConversionPattern=%d %5p – %c -%-4r [%t] – %m%n此时生成日志文件将位于tomcat的bin目录下,如要将日志文件保存在 :根目录/web-info/logs/下,个人有以下4种解决方案:1 绝对路径log4j.appender.A1.File=D:\apache-tomcat-6.0.18/webapps/项目/WEB-INF/logs/app.log但这种写法灵活性很差以下3中使用相同的设置原理: jvm的环境变量2:spring的Log4jConfigListener通过以下配置:< context-param><param-name>webAppRootKey</param-name><param-value>webApp.root</param-value></context-param><context-param><param-name>log4jConfigLocation</param-name><param-value>classpath:log4j.properties</param-value></context-param>< listener> <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> </listener>…log4j.appender.logfile.File=${webApp.root}/WEB-INF/logs/app.log…来解决2:使用已有jvm变量:例如:log4j.appender.logfile.File=${user.home}/logs/app.log日志将位于:例如windows:C:\Documents and Settings\joe\logs\app.log3 自己设置目录,也就是在项目启动时通过System.setProperty设置通过实现ServletContextListener来解决:例如public class log4jlistener implements ServletContextListener {public static final String log4jdirkey = "log4jdir";public void contextDestroyed(ServletContextEvent servletcontextevent) {System.getProperties().remove(log4jdirkey);}public void contextInitialized(ServletContextEvent servletcontextevent) {String log4jdir = servletcontextevent.getServletContext().getRealPath("/");//System.out.println("log4jdir:"+log4jdir);System.setProperty(log4jdirkey, log4jdir);}}web.xml配置:<listener><listener-class>com.log4j.log4jlistener</listener-class></listener>log4j.prtperties 配置:log4j.appender.A1.File=${log4jdir}/WEB-INF/logs/app1.log来解决。

⑧ log4j中是否可以切换日志输出位置

话说,你指定不同的appender不行么?log4j不是有类似addAppender的API存在的么每个appender应该可以对应不同的输出位置吧?我没这么干过,跟你一起等正解那么这么干呢?你把输出日志的方法封装下,比如叫一个wrapperLogXXX(),里面是真正的调用appender,输出日志的实现,每个方法调用wrapperLogXXX()的时候把class传进去,然后在里面根据class判断用哪个appender。办法挺SB的,继续跟你一起等正解