问题描述:
有时在项目中导入log4j的jar包,并配置log4j.xml或者是log4j2.xml后,在代码中引入log4j的API,并不能成功的将log写入控制台或者文件中。
原因有很多很多种,下面将介绍经过我测试log写入成功的事例。
在开始前,需要谨记log4j的几种级别:trace<debug<info<warn<error<fatal, 级别之间是包含的关系,意思是如果你设置日志级别是trace,则大于等于这个级别的日志都会输出。
成功例子1 log4j.xml:
1. 导入log4j2的jar包,主需要导入log4j2的core包即可。如:log4j-core.2.1.jar,引入改jar包会自动引入
log4j-api.2.1.jar.
<dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.1</version> </dependency>
2.在classpath中配置log4j.xml,注意不是log4j2.xml,其内容如下
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/xml/doc-files/log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false"> <!-- Set INFO to WARN for warning-level logging, or DEBUG for debug-level logging. --> <!-- Output to terminal by default. --> <appender name="terminal" class="org.apache.log4j.ConsoleAppender"> <param name="Threshold" value="INFO" /> <param name="Target" value="System.out" /> <layout class="org.apache.log4j.PatternLayout"> <!-- param name="ConversionPattern" value="%d{ABSOLUTE} [%t] %-5p [%c{1}] %m%n"/ --> <param name="ConversionPattern" value="%-d [%t] %-5p %c:%L - %m%n" /> </layout> </appender> <!-- Optional: asynchronous file output (set <appender-ref ref="asynch-file"/> in root below). --> <appender name="asynch-file" class="org.apache.log4j.AsyncAppender"> <param name="locationInfo" value="false" /> <appender-ref ref="out-file" /> </appender> <!-- Optional: asynchronous file location (set <appender-ref ref="asynch-file"/> in root below). --> <appender name="out-file" class="org.apache.log4j.RollingFileAppender"> <param name="Threshold" value="INFO" /> <!-- <param name="file" value="${app.logfile}"/> --> <param name="file" value="log/automation.log" /> <param name="MaxFileSize" value="50MB" /> <param name="MaxBackupIndex" value="50" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%-d [%t] %-5p %c %X{processID}-%X{queryIndex} - %m %n" /> </layout> </appender> <logger name="com.wsheng.uiautomation.test"> <level value="INFO" /> </logger> <logger name="com.wsheng.uiautomation.sitestatus"> <level value="INFO" /> </logger> <root> <level value="INFO" /> <appender-ref ref="terminal" /> <appender-ref ref="out-file" /> </root> </log4j:configuration>
3. 在项目中写log的代码:
import org.apache.log4j.Logger; protected static Logger logger = Logger.getLogger(BaseTestPlan.class);
需要注意的是此处导入的是org.apache.log4j.Logger;如果使用下面的代码,则不能写入log
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; protected static Logger logger = LogManager.getLogger(BaseTestPlan.class);
即便是将上面的log4j.xml改为log4j2.xml也不能写入log。
这是因为log4j2.xml和log4j.xml在配置上有区别。
成功例子2: log4j2.xml
1. 和log4j.xml一样,也导入log4j2的jar包,主需要导入log4j2的core包即可。如:log4j-core.2.1.jar,引入改jar包会自动引入log4j-api.2.1.jar.
<dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.1</version> </dependency>
2.在classpath中配置log4j2.xml,注意不是log4j.xml,其内容如下
<?xml version="1.0" encoding="UTF-8"?> <Configuration status="WARN"> <properties> <property name="logPath">log</property> </properties> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" /> <!-- <PatternLayout pattern="%d{HH:mm:ss} [%t] %-5level %logger{36} - %msg%n" /> --> <!-- <PatternLayout pattern="%-d [%t] %-5p %c{1}:%L - %m%n" /> --> </Console> <!-- <File name="LogFile" filename="${sys:catalina.home}/logs/automation.log"> <PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" /> </File> --> <RollingFile name="RollingFile" filename="${logPath}/automation.log" filepattern="${logPath}/%d{YYYYMMddHHmmss}-automation.log"> <PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" /> <Policies> <SizeBasedTriggeringPolicy size="100 MB"/> </Policies> <DefaultRolloverStrategy max="20"/> </RollingFile> </Appenders> <Loggers> <Root level="info"> <AppenderRef ref="Console" /> <!-- <AppenderRef ref="LogFile" /> --> <AppenderRef ref="RollingFile" /> </Root> </Loggers> </Configuration>
3. 在项目中写log的代码:
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; protected static Logger logger = LogManager.getLogger(BaseTestPlan.class);
如果使用 org.apache.log4j.Logger,得到的结果是能写入控制台,但不能写入对应的文件。
import org.apache.log4j.Logger; protected static Logger logger = Logger.getLogger(BaseTestPlan.class);
Note: 如果启动的时候报类似下面的异常:
2015-04-30 15:10:07,962 WARN Could not instantiate SimpleDateFormat with pattern YYYYMMddHHmmss java.lang.IllegalArgumentException: Illegal pattern character 'Y'
可将YYYY改成小写的yyyy试一试。
相关推荐
基于matlab实现的一种新型的配电网潮流计算,基于前推回代法,并附有10kv配电网数据,利用新的判别手段,成功解决配电网不收敛的问题.rar
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
ASP+ACCESS网上园林设计(源代码+设计说明书).zip
2023-04-06-项目笔记-第一百二十二阶段-课前小分享_小分享1.坚持提交gitee 小分享2.作业中提交代码 小分享3.写代码注意代码风格 4.3.1变量的使用 4.4变量的作用域与生命周期 4.4.1局部变量的作用域 4.4.2全局变量的作用域 4.4.2.1全局变量的作用域_1 4.4.2.120全局变量的作用域_120 - 2024-05-03
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
基于matlab实现的电动汽车动力性经济性UI,希望对初学者有用。.rar
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
本次设计是系统介绍了智能台灯的应用背景、设计原理、软硬件电路等。以STM32作为主控,应用定时模块、人体感应模块、光敏模块,使得智能台灯具备调光,监督使用者的坐姿,节能,时间提醒等功能。有五级自动、手动灯光。ds1302实时时钟模块、HCSR04超声波模块、dht11温湿度模块、HCSR501人体感应模块、光敏电阻模块和无源蜂鸣器模块。
词频统计
ASP基于BS结构的房屋租售管理系统的实现(源代码+设计说明书).zip
c&c++课程设计-图书管理系统.zip
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
ASP基于WEB教学评估系统设计(源代码+设计说明书).zip
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
基于matlab实现的配电网自动化的一些程序.rar
基于知识图谱的推荐算法-MKR的实现 运行环境 python == 3.7.0 torch == 1.12.0 pandas == 1.1.5 numpy == 1.21.6 sklearn == 0.0 数据集介绍 music-音乐 book-书籍 ml-电影 yelp-商户 文件介绍 ratings.txt:记录用户点击的项目,1代表点击了,0代表没有点击 kg.txt:知识图谱文件,第一列是头实体,第二列是尾实体,第三列是关系 user-list.txt:用户及其id文件,第一列是用户的id,第二列是用户 其余文件可忽略 About 基于知识图谱的推荐算法-MKR的实现 Resources Readme Activity Stars 7 stars Watchers 1 watching Forks 1 fork Report repository Releases No releases published Packages No packages published Languages Python 100.0% Footer
儒家文化指标 计算说明 使用公司注册地200公里和300公里半径范围内的孔庙数 量作为儒家文化强度的代理变量。 具体做法为:通过搜集确定全国各省市的孔庙数量及位 置信息,然后在百度地图上分别确定孔庙和上市公司的经纬度,以各上市公司为圆心分别以 200公里、300公里为半径确定上市公司周围的孔庙数量,作为儒家文化( CONF _ 200,CONF_300 )的代理变量,除以1000进行标准化处理。 稳健性 使用用公司注册地200公里、300公里以内的明清进士数量分别替换孔庙数量,并取对 数进行标准化,得到变量MQJS200和MQJS300。 参考文献 [1]张璇,a nd 可善雪."隐形的力量:儒家文化与企业劳动投资效率." 会计之友 .15(2 023):11-18. [2]古志辉. "全球化情境中的儒家伦理与代理成本." 管理世界 3(2015):11. 数据说明 全部A股上市公司数据 截止至2022 年12月上市的 结果说明 数据截图 描述性统计 相关系数 附件下载 代码[经管之 家momingqimiao7].do 经管之家:momingiqmiao7 欢迎 关注,分享更多实
污水处理计算书
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
基于matlab实现的气体静压止推轴承气膜厚度随时间的变化分析.rar