① 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日志文件保存路径
以DailyRollingFileAppender 为例:假设每天一个日志文件 有以下设置: log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender log4j.appender.A1.File=app.log log4j.appender.A1.DatePattern='.'yyyy-MM-dd log4j.appender.A1.layout=org.apache.log4j.PatternLayout log4j.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.log 3 自己设置目录,也就是在项目启动时通过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 来解决。
③ 怎样将web项目的log4j日志文件放入当前的项目文件夹下
【6】log4j.appender.file.File=library.log 这里是日志文件,可以加上路径、可以是绝对路径也可以是相对的。
④ 请教以下log4j 日志文件不会弄啊。
你用一个类去读,然后在里面用logger去执行,在log4j的配置文件里面针对这个类配置一个把日志写到文件里面的appender,这样应该就可以了
⑤ 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 日志log文件如何放在根目录下
在log4j.properties文件中关键配置如下:log4j.rootLogger=Rlog4j.appender.R=org.apache.log4j.RollingFileAppender log4j.appender.R.File= /server.log希望对你有帮助
⑦ log4j的使用,即java该如何使用日志文件
java使用日志文件log4j的方法:
1、 新建一个Java工程,导入Log4j包,pom文件中对应的配置代码如下:
<!– log4j support –><dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version></dependency>
2、resources目录下创建log4j.properties文件
### 设置###log4j.rootLogger = debug,stdout,D,E### 输出信息到控制抬 ###log4j.appender.stdout = org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target = System.outlog4j.appender.stdout.layout = org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n### 输出DEBUG 级别以上的日志到=/home/qi/logs/debug.log ###log4j.appender.D = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.D.File = /home/qi/logs/debug.loglog4j.appender.D.Append = truelog4j.appender.D.Threshold = DEBUG log4j.appender.D.layout = org.apache.log4j.PatternLayoutlog4j.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.DailyRollingFileAppenderlog4j.appender.E.File =/home/admin/logs/error.log log4j.appender.E.Append = truelog4j.appender.E.Threshold = ERROR log4j.appender.E.layout = org.apache.log4j.PatternLayoutlog4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] – [ %p ] %m%n
3、输出日志的例子如下
package com.java.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、输出结果首先,控制台输入如下图所示:
⑧ Android log4j如何把每条报错的日志存到文件里去
以DailyRollingFileAppender为例:假设每天一个日志文件有以下设置:log4j.appender.A1=org.apache.log4j.DailyRollingFileAppenderlog4j.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通过以下配置:webAppRootKeywebApp.:log4j.propertiesorg.springframework.web.util.Log4jConfigListenerlog4j.appender.logfile.File=${webApp.root}/WEB-INF/logs/app.log来解决2:使用已有jvm变量:例如:log4j.appender.logfile.File=${user.home}/logs/app.log日志将位于:例如windows:C:\DocumentsandSettings\joe\logs\app.log3自己设置目录,也就是在项目启动时通过System.setProperty设置通过实现ServletContextListener来解决:例如{="log4jdir";publicvoidcontextDestroyed(){System.getProperties().remove(log4jdirkey);}publicvoidcontextInitialized(){Stringlog4jdir=servletcontextevent.getServletContext().getRealPath("/");//System.out.println("log4jdir:"+log4jdir);System.setProperty(log4jdirkey,log4jdir);}}web.xml配置:com.log4j.log4jlistenerlog4j.prtperties配置:log4j.appender.A1.File=${log4jdir}/WEB-INF/logs/app1.log来解决。