2023-02-25 458
log4net是Apache log4j的.net版,是一套XML配置型的日志引擎,正好最近有个程序需要日志系统,为了整合方便,就决定研究一下。感谢郝伟推荐。
log4net系统划分了7个日志等级,如设置为”WARN”,则DEBUG,INFO不会被记录。如下: 1. ALL 2. DEBUG 3. INFO 4. WARN 5. ERROR 6. FATAL 7. OFF Creating the Sample Application Step 1: 下载log4net 去logging.apache.org/log4net,来获取他们的最近版,在例子里我用的是incubating-log4net-1.2.9-beta.zip,期待正式版。 Step 2: 创建 ASP.NET Web 应用程序 创建这个就不多说了,在log4net-1.2.0-beta8\bin\net如图。找到对应的dll,添加到引用里。有的版本没有编译好的dll,那就自己编一下吧,用.NET V1.0的那个版本转换成1.1或2.0的。我觉得这不是工作失误,是故意的。他们玩java玩惯了的人好多都是这样。 Configuring the Sample Application Step 3: 添加Assembly信息 打开AssemblyInfo.cs文件,添加: [assembly: log4net.Config.DOMConfigurator()] [assembly:log4net.Config.DOMConfigurator(ConfigFile=”filename”,ConfigFileExtension=”log4net”,Watch=true)] Step 4: 添加配置信息 要编辑Web.config文件了,真是每次看见它都有惊喜啊。找到configuration标签,configSections要紧挨着写到它下面(一点都不替别人考虑,要在有一个也跟他一样霸道怎么办?那就单写个它的日志配置文件吧!我估计APACHE他们就是这么想的)。看看例子吧: <?xml version=”1.0″ encoding=”utf-8″ ?> <configuration> <configSections> <section name=”log4net” type=”log4net.Config.Log4NetConfigurationSectionHandler, log4net-net-1.0″ /> </configSections> <!– This section contains the log4net configuration settings –> <log4net> <!– Define some output appenders –> <appender name=”ConsoleAppender” type=”log4net.Appender.ConsoleAppender”> <layout type=”log4net.Layout.PatternLayout”> <param name=”ConversionPattern” value=”%d [%t] %-5p %c [%x] <%X{auth}> – %m%n” /> </layout> </appender> <!– RollingFileAppender looks after rolling over files by size or date –> <appender name=”RollingFileAppender” type=”log4net.Appender.RollingFileAppender”> <param name=”File” value=”C:\\log\\RollingLogHelloWorld.log” /> <param name=”AppendToFile” value=”true” /> <param name=”MaxSizeRollBackups” value=”10″ /> <param name=”MaximumFileSize” value=”1000″ /> <param name=”RollingStyle” value=”Size” /> <param name=”StaticLogFileName” value=”true” /> <layout type=”log4net.Layout.PatternLayout”> <param name=”ConversionPattern” value=”%d [%t] %-5p %-45c [%x] – %m%n” /> </layout> </appender> <!– FileAppender appends to a log and it is manually managed or size –> <appender name=”FileAppender” type=”log4net.Appender.FileAppender”> <param name=”File” value=”LogHelloWorld.log” /> <!– Example using environment variables in params –> <!– <param name=”File” value=”${TMP}\\ApplicationKit.log” /> –> <param name=”AppendToFile” value=”true” /> <layout type=”log4net.Layout.PatternLayout”> <param name=”ConversionPattern” value=”%d [%t] %-5p %c [%x] – %m%n” /> </layout> </appender> <!– Setup the root category, add the appenders and set the default level –> <root> <level value=”INFO” /> <appender-ref ref=”ConsoleAppender” /> </root> <!– ApplicationKit category – the presentation UI –> <logger name=”WebForm1″> <level value=”INFO” /> <appender-ref ref=”FileAppender” /> </logger> </log4net> </configuration> 注意Logger节点的NAME属性设的是WebForm1,这里指的是类名。要给每一个需要添加LOG的类都添加一个这样的节点。想起了OSWORKFLOW工作流了,灵活与方便实用往往不可兼得。这里的级别是INFO,也就是说,INFO以下的不会被记录。 Running the Sample Application Step 5: 添加一个 Log 类 首先是添加引用 using log4net;using log4net.Config; //然后是实例化如果认真研究了配置文件,那么这个声明方式就很好理解了:private static readonly ILog log = LogManager.GetLogger(“WebForm1”); Step 6: 使用 Log对象 到了现在,所有的配置工作都已经完成了,接下来的工作就是测试一下,把他和应用层连起来。随便加一个按钮在响应事件Button1_Click event handler.中添加 log.Info(“Hello World, I am a logger”); Step 7: Run the Application 现在可以运行了,应该是个这样子的: 这样每次点击按钮,在日至文件中就会出现 2006-02-13 10:12:30,671 [1228] INFO WebForm1 [] – Hello World, I am a logger这样一条记录。 总结: 简单易用,过一阵再研究SQL日志吧,DB才素王道,呵呵。 更多信息参见http://logging.apache.org/log4net/
这句话的意思是log4net系统会自动寻找配置文件Web.config从而获得并加载其中的配置信息。如果想log4net随时监视配置文件以便重新加载的话就
稍微麻烦点了要这样写:
原文链接:https://77isp.com/post/34308.html
=========================================
https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。
数据库技术 2022-03-28
网站技术 2022-11-26
网站技术 2023-01-07
网站技术 2022-11-17
Windows相关 2022-02-23
网站技术 2023-01-14
Windows相关 2022-02-16
Windows相关 2022-02-16
Linux相关 2022-02-27
数据库技术 2022-02-20
抠敌 2023年10月23日
嚼餐 2023年10月23日
男忌 2023年10月22日
瓮仆 2023年10月22日
簿偌 2023年10月22日
扫码二维码
获取最新动态