Log4日志配置(转)

2024-05-26 16:32
文章标签 配置 日志 log4

本文主要是介绍Log4日志配置(转),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2010-10-19 19:44:23|  分类: .NET |  标签: |字号 订阅

Log4日志组件的应用确实简单实用,在比较了企业库和Log4的日志功能后,个人觉得Log4的功能更加强大点.补充说明下,我使用的企业库是2.0版本,Log4net是1.2.1版本的.

在Log4net的应用上,已经有人做了说明分析了,在本文中,主要解析下Log4net中的RollingFileAppender的应用.

主要参考了Log4net的帮助文档.在项目中的log4net-1.2.10\doc文件下有.


RollingFileAppender主要是基于FileAppender构建的,很多属性方法都是继承于FileAppender,所以在选项设置上,也有许多是相同的.

下面的例子使日志文件名为log.txt,日志文件名是以文件大小进行变换的,如果旧日志文件大小到100KB时,就会变换文件名为log.txt.1,log.txt.2,log.txt.3...,一直到10为止

  1. <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">  
  2.         <!--日志文件名-->
  3.     <file value="log.txt"/>
  4.     <!--是否在文件中追加-->
  5.     <appendToFile value="true"/>
  6.     <!--按照文件的大小进行变换日志文件-->
  7.     <rollingStyle value="Size"/>
  8.     <!--最大变换数量-->
  9.     <maxSizeRollBackups value="10"/>
  10.     <!--最大文件大小-->
  11.     <maximumFileSize value="100KB"/>
  12.     <!--日志文件名是否为静态-->
  13.     <staticLogFileName value="true"/>
  14.     <layout type="log4net.Layout.PatternLayout">
  15.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline"/>
  16.     </layout>
  17. </appender>

下面的例子以时间周期变换日志文件名,每分钟都改变日志的文件名,日志文件名为logfileyyyyMMdd-HHmm,这里补充说明下,如果要在这个文件名后面加上.log后缀,必须使用转义字符,比如<datePattern value="yyyyMMdd-HHmm&quot;.log&quot;" />

  1. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  2.         <!--日志文件名开头-->
  3.     <file value="logfile" />
  4.     <!--是否追加到文件-->
  5.     <appendToFile value="true" />
  6.     <!--变换的形式为日期-->
  7.     <rollingStyle value="Date" />
  8.     <!--日期的格式-->
  9.     <datePattern value="yyyyMMdd-HHmm" />
  10.     <layout type="log4net.Layout.PatternLayout">
  11.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline" />
  12.     </layout>
  13. </appender>

下面的例子综合使用使用日期和文件大小变换日志文件名。

  1. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  2.     <!--日志文件名开头-->
  3.     <file value="logfile" />
  4.     <!--是否追加到文件-->
  5.     <appendToFile value="true" />
  6.     <!--混合使用日期和文件大小变换日志文件名-->
  7.     <rollingStyle value="Composite" />
  8.     <!--日期的格式-->
  9.     <datePattern value="yyyyMMdd" />
  10.     <!--最大变换数量-->
  11.     <maxSizeRollBackups value="10" />
  12.     <!--最大文件大小-->
  13.     <maximumFileSize value="1MB" />
  14.     <layout type="log4net.Layout.PatternLayout">
  15.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline" />
  16.     </layout>
  17. </appender>

下面例子是在每次程序运行的时候,都会备份原先的日志文件,当运行的日志文件大于50G的时候才会变换日志文件名。

  1. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  2.     <!--日志文件名-->
  3.     <file value="logfile.txt" />
  4.     <!--不追加到原文件-->
  5.     <appendToFile value="false" />
  6.     <!--以日志文件大小变换文件名-->
  7.     <rollingStyle value="Size" />
  8.     <!--最大变换数量,-1为不限制-->
  9.     <maxSizeRollBackups value="-1" />
  10.     <!--最大文件大小-->
  11.     <maximumFileSize value="50GB" />
  12.     <layout type="log4net.Layout.PatternLayout">
  13.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline" />
  14.     </layout>
  15. </appender>

下面是RollingFileAppender类中的部分Public Instance Properties(公共属性)的说明,没有全部测试,难免谬误,如果你知道,请不要吝啬告写。
CountDirection : 定义当前文件是最小编号的文件还是最大编号的文件。默认为-1,总是以更小的编号。
datePattern : DateFormatter日期格式,string类型。
Encoding : 就是文件的编码,默认为Default,就是程序本身的编码了。
FilterHead : 分割符头部。
ImmediateFlush : 表示是否立即输出到文件,布尔型的。
LockingModel : 文件锁类型,RollingFileAppender本身不是线程安全的,如果在程序中没有进行线程安全的限制,可以在这里进行配置,确保写入时的安全。有两中类型:FileAppender.ExclusiveLockFileAppender.MinimalLock
Name
: 设置本Appander的名称。
SecurityContext : 比较少应用,对日志进行加密只类的,使用SecurityContextProvider转换。(对日志的保密要求比较高的时候应该可以应用上吧,Log4考虑的还挺周全)
Threshold : 设置内容级别的,比如:DEBUG,INFO等等。

 

在Log4net的配置中有两种方法是等价的:
<param name="File" value="log.txt" />
<File value="log.txt" />
个人更倾向后者。在一些数据库上的应用时还有许多Param呢。

 

追加:懒人ABC使用后的一些例子

组件的应用确实简单实用,在比较了企业库和Log4的日志功能后,个人觉得Log4的功能更加强大点.补充说明下,我使用的企业库是2.0版本,Log4net是1.2.1版本的.

在Log4net的应用上,已经有人做了说明分析了,在本文中,主要解析下Log4net中的RollingFileAppender的应用.

主要参考了Log4net的帮助文档.在项目中的log4net-1.2.10\doc文件下有.


RollingFileAppender主要是基于FileAppender构建的,很多属性方法都是继承于FileAppender,所以在选项设置上,也有许多是相同的.

下面的例子使日志文件名为log.txt,日志文件名是以文件大小进行变换的,如果旧日志文件大小到100KB时,就会变换文件名为log.txt.1,log.txt.2,log.txt.3...,一直到10为止

  1. <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">  
  2.         <!--日志文件名-->
  3.     <file value="log.txt"/>
  4.     <!--是否在文件中追加-->
  5.     <appendToFile value="true"/>
  6.     <!--按照文件的大小进行变换日志文件-->
  7.     <rollingStyle value="Size"/>
  8.     <!--最大变换数量-->
  9.     <maxSizeRollBackups value="10"/>
  10.     <!--最大文件大小-->
  11.     <maximumFileSize value="100KB"/>
  12.     <!--日志文件名是否为静态-->
  13.     <staticLogFileName value="true"/>
  14.     <layout type="log4net.Layout.PatternLayout">
  15.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline"/>
  16.     </layout>
  17. </appender>

下面的例子以时间周期变换日志文件名,每分钟都改变日志的文件名,日志文件名为logfileyyyyMMdd-HHmm,这里补充说明下,如果要在这个文件名后面加上.log后缀,必须使用转义字符,比如<datePattern value="yyyyMMdd-HHmm&quot;.log&quot;" />

  1. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  2.         <!--日志文件名开头-->
  3.     <file value="logfile" />
  4.     <!--是否追加到文件-->
  5.     <appendToFile value="true" />
  6.     <!--变换的形式为日期-->
  7.     <rollingStyle value="Date" />
  8.     <!--日期的格式-->
  9.     <datePattern value="yyyyMMdd-HHmm" />
  10.     <layout type="log4net.Layout.PatternLayout">
  11.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline" />
  12.     </layout>
  13. </appender>

下面的例子综合使用使用日期和文件大小变换日志文件名。

  1. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  2.     <!--日志文件名开头-->
  3.     <file value="logfile" />
  4.     <!--是否追加到文件-->
  5.     <appendToFile value="true" />
  6.     <!--混合使用日期和文件大小变换日志文件名-->
  7.     <rollingStyle value="Composite" />
  8.     <!--日期的格式-->
  9.     <datePattern value="yyyyMMdd" />
  10.     <!--最大变换数量-->
  11.     <maxSizeRollBackups value="10" />
  12.     <!--最大文件大小-->
  13.     <maximumFileSize value="1MB" />
  14.     <layout type="log4net.Layout.PatternLayout">
  15.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline" />
  16.     </layout>
  17. </appender>

下面例子是在每次程序运行的时候,都会备份原先的日志文件,当运行的日志文件大于50G的时候才会变换日志文件名。

  1. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  2.     <!--日志文件名-->
  3.     <file value="logfile.txt" />
  4.     <!--不追加到原文件-->
  5.     <appendToFile value="false" />
  6.     <!--以日志文件大小变换文件名-->
  7.     <rollingStyle value="Size" />
  8.     <!--最大变换数量,-1为不限制-->
  9.     <maxSizeRollBackups value="-1" />
  10.     <!--最大文件大小-->
  11.     <maximumFileSize value="50GB" />
  12.     <layout type="log4net.Layout.PatternLayout">
  13.         <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] %message%newline" />
  14.     </layout>
  15. </appender>

下面是RollingFileAppender类中的部分Public Instance Properties(公共属性)的说明,没有全部测试,难免谬误,如果你知道,请不要吝啬告写。
CountDirection : 定义当前文件是最小编号的文件还是最大编号的文件。默认为-1,总是以更小的编号。
datePattern : DateFormatter日期格式,string类型。
Encoding : 就是文件的编码,默认为Default,就是程序本身的编码了。
FilterHead : 分割符头部。
ImmediateFlush : 表示是否立即输出到文件,布尔型的。
LockingModel : 文件锁类型,RollingFileAppender本身不是线程安全的,如果在程序中没有进行线程安全的限制,可以在这里进行配置,确保写入时的安全。有两中类型:FileAppender.ExclusiveLockFileAppender.MinimalLock
Name
: 设置本Appander的名称。
SecurityContext : 比较少应用,对日志进行加密只类的,使用SecurityContextProvider转换。(对日志的保密要求比较高的时候应该可以应用上吧,Log4考虑的还挺周全)
Threshold : 设置内容级别的,比如:DEBUG,INFO等等。

 

在Log4net的配置中有两种方法是等价的:
<param name="File" value="log.txt" />
<File value="log.txt" />
个人更倾向后者。在一些数据库上的应用时还有许多Param呢。

这篇关于Log4日志配置(转)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1004992

相关文章

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

在Spring中配置Quartz的三种方式

《在Spring中配置Quartz的三种方式》SpringQuartz是一个任务调度框架,它允许我们定期执行特定的任务,在Spring中,我们可以通过多种方式来配置Quartz,包括使用​​@Sche... 目录介绍使用 ​​@Scheduled​​ 注解XML 配置Java 配置1. 创建Quartz配置

Kibana的安装和配置全过程

《Kibana的安装和配置全过程》Kibana是一个开源的数据分析和可视化平台,它与Elasticsearch紧密集成,提供了一个直观的Web界面,使您可以快速地搜索、分析和可视化数据,在本文中,我们... 目录Kibana的安装和配置1.安装Java运行环境2.下载Kibana3.解压缩Kibana4.配

tomcat在nginx中的配置方式

《tomcat在nginx中的配置方式》文章介绍了如何在Linux系统上安装和配置Tomcat,并通过Nginx进行代理,首先,下载并解压Tomcat压缩包,然后启动Tomcat并查看日志,接着,配置... 目录一、下载安装tomcat二、启动tomcat三、配置nginx总结提示:文章写完后,目录可以自动

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。