Log4net配置

简介:
< DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd>

几乎所有的项目都需要以 log 的形式保留一些系统纪录,实现这类功能的API又以Log4J最为出名。对于.NET平台上,值得庆幸的是,Apache组织已经把Log4J迁移到.NET平台上,从而诞生了:og4j的姐妹-Log4net.下面的文字仅仅作为快速入门的参考,更详细的应用可以访问apache的站点。

1. 首先你应该下载log4net.dll并引入到你的项目References中.

2. 需要修改你的global.asa.cs. 配置application对象启动的时候加载log4net配置. 这一步是不可以缺少的.

代码

protected void Application_Start(Object sender, EventArgs e)   
  
   log4net.Config.XmlConfigurator.Configure();   

对于Application程式,则在main入口点加载配置。

3. Log4net 的配置应设置于web.config或App.config中,以Web.Config为例在根节点 configuration 中加入如下section:

代码

<configSections>  
   <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />  
</configSections>  

4. 该config section 声明了名为 log4net的一个Section,其必须位于web.config根节点 configuration 下。
以下是一个sample:

代码 <log4net debug="false">  
     <appender name="LogFileAppender" type="log4net.Appender.FileAppender" >  
         <param name="File" value="XxxxApplication.log.txt" />  
         <param name="datePattern" value="MM-dd HH:mm" />  
         <param name="AppendToFile" value="true" />  
         <layout type="log4net.Layout.PatternLayout">  
             <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />  
         </layout>  
     </appender>  
     <appender name="HttpTraceAppender" type="log4net.Appender.ASPNetTraceAppender" >  
         <layout type="log4net.Layout.PatternLayout">  
             <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />  
         </layout>  
     </appender>  
     <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender" >  
         <layout type="log4net.Layout.PatternLayout">  
             <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />  
         </layout>  
     </appender>  
     <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">  
         <param name="File" value="_LogData\Log.txt" />  
         <param name="AppendToFile" value="true" />  
         <param name="MaxSizeRollBackups" value="10" />  
         <param name="MaximumFileSize" value="5MB" />  
         <param name="RollingStyle" value="Size" />  
         <param name="StaticLogFileName" value="true" />  
         <layout type="log4net.Layout.PatternLayout">  
             <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />  
         </layout>  
     </appender>  
     <root>  
         <level value="DEBUG" />  
         <appender-ref ref="LogFileAppender" />  
     </root>  
</log4net>  

5. 上面的配置定义了多个appender. 简单来说, 每一个 appender 都是一个输出管道。

6. root节点指定了选用的 appender. 本例选用了LogFileAppender. (文本文件输出).

在Appender定义中定义了输出的格式. 和目标文本文件所在位置. (起始位置是应用程序根目录. (web.config所在目录).

7. 到目前位置就配置好了log4net. 可以在我们的应用中直接使用了.

8. 以下说明应用方法:
要输出日志, 必须首先得到带有一个别名的logger. 使用以下命令:

代码

log4net.ILog Logger logger = log4net.LogManager.GetLogger(typeof(XXXX));   

之后调用

代码

logger.Info(string message);   
logger.Error(string message);   
logger.Debug(string message);   
...   


即可输出日志.

本文转自 netcorner 博客园博客,原文链接: http://www.cnblogs.com/netcorner/archive/2007/08/10/2912316.html ,如需转载请自行联系原作者

相关文章
|
2月前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
566 31
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
1月前
|
SQL
南大通用GBase 8a配置gcware日志等级,减少日志输出,节省磁盘IO
南大通用GBase 8a配置gcware日志等级,减少日志输出,节省磁盘IO
|
1月前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
51 5
|
3月前
|
网络协议 Linux Windows
Rsyslog配置不同端口收集不同设备日志
Rsyslog配置不同端口收集不同设备日志
|
3月前
|
开发工具 git
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
49 1
|
3月前
|
数据采集 监控 Java
SpringBoot日志全方位超详细手把手教程,零基础可学习 日志如何配置及SLF4J的使用......
本文是关于SpringBoot日志的详细教程,涵盖日志的定义、用途、SLF4J框架的使用、日志级别、持久化、文件分割及格式配置等内容。
244 0
SpringBoot日志全方位超详细手把手教程,零基础可学习 日志如何配置及SLF4J的使用......
|
5月前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决
Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决
|
5月前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之配置Logback以在控制台输出日志的问题如何解决
Java应用结构规范问题之配置Logback以在控制台输出日志的问题如何解决
|
5月前
|
开发框架 .NET Docker
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
|
5月前
|
存储 Ubuntu Apache
如何在 Ubuntu VPS 上配置 Apache 的日志记录和日志轮转
如何在 Ubuntu VPS 上配置 Apache 的日志记录和日志轮转
61 6