Log4Net记录日志的使用
Log4net 基本样式:
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.FileAppender">
<param name="File" value="Mylog/" />
<param name="AppenderToFile" value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="Header" value="[Header]\r\n" />
<param name="Footer" value="[Footer]\r\n" />
<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />
</layout>
<!--过滤器:将只记录level为DEBUG与WARN之间的日志-->
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="DEBUG">
<param name="LevelMax" value="WARN">
</filter>
</appender>
<root>
<!--缺省为DEBUG级别-->
<level value="DEBUG">
<!--声明了在其他地方定义的Appender对象的一个引用-->
<appender-ref ref="LogFileAppender">
</root>
<!-- logger标签不是必须的 Additivity的值缺省是true-->
<logger name="testApp.Logging" additivity="false">
<level value="DEBUG" />
</logger>
</log4net>
Log4net.config
Log4Net配置文件的书写
添加section
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
</configSections>
按日期分隔文件
<!-- 按日期分隔文件 -->
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="D:\\MyLogFiles\\ClientService\log4net\"/>
<!-- 是否在文件中追加 -->
<param name="AppendToFile" value="true"/>
<!-- 最小锁定模型以允许多个进程可以写入同一个文件 -->
<param name="LockingModel" value="log4net.Appender.FileAppender.MinimalLock" />
<!--最多生成(MaxSizeRollBackups的值+1)个文件。如果注释掉,那么只生成一个文件。到了轮训条件,会从最早的开始覆盖以前的信息-->
<!-- 好像只有按Size分隔文件,才有效果 -->
<param name="MaxSizeRollBackups" value="31"/>
<!--如果RollingStyle为Size,这里需要填写正数加上单位(KB,MB)-->
<param name="MaximumFileSize" value="-1"/>
<!--轮询方式,文件大小,超过MaximumFileSize的值,则重新生成一个文件-->
<!--<param name="RollingStyle" value="Size"/>-->
<!--轮询方式,日期,每天生成一个文件。非当天的文件,会在File的值后面加上20151215-->
<param name="RollingStyle" value="Date"/>
<param name="StaticLogFileName" value="false"/>
<param name="datePattern" value="'zsyylog'yyyyMMdd'.txt'" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%m%n"/>
</layout>
</appender>
添加到MSSQL数据库
<appender name="AdoNetAppender_SQLServer" type="log4net.Appender.AdoNetAppender">
<!-- 缓存大小 -->
<bufferSize value="300" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="SERVER=10.10.4.85;UID=zsyy;Pwd=zsyy*123;DATABASE=HandheldYonYou" />
<commandText value="INSERT INTO [HandheldYonYou].[dbo].[Log4net_Log]([Date],[RequestUID],[RequestPort],[RequestUri],[StringType],[RequestMethod],[ApiVersion],[Message],[Thread],[Level],[Logger],[Exception])
VALUES(@log_date ,@RequestUID ,@RequestPort ,@RequestUri,@StringType,@RequestMethod,@ApiVersion,@message ,@thread ,@log_level ,@logger ,@exception )" />
<parameter>
<!-- 字段名称 -->
<parameterName value="@RequestUID" />
<!-- 字段数据类型 -->
<dbType value="String" />
<!-- 字段数据长度 -->
<size value="50"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{RequestUID}" />
</layout>
</parameter>
<parameter>
<parameterName value="@RequestPort" />
<dbType value="String" />
<size value="50"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{RequestPort}" />
</layout>
</parameter>
<parameter>
<parameterName value="@RequestUri" />
<dbType value="String" />
<size value="2000"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{RequestUri}" />
</layout>
</parameter>
<parameter>
<parameterName value="@StringType" />
<dbType value="String" />
<size value="50"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{StringType}" />
</layout>
</parameter>
<parameter>
<parameterName value="@RequestMethod" />
<dbType value="String" />
<size value="50"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{RequestMethod}" />
</layout>
</parameter>
<parameter>
<parameterName value="@ApiVersion" />
<dbType value="String" />
<size value="50"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{ApiVersion}" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
</appender>
记录日志的方式
<root>
<!-- 日志的等级(ALL、DEBUG、WRONG、ERROR、INFO) -->
<level value="ALL"/>
<!-- 将日志记录到SQL -->
<appender-ref ref="AdoNetAppender_SQLServer"/>
<!-- 循环将日志添加到文件 -->
<appender-ref ref="RollingFileAppender"/>
</root>
Log4Net记录日志的使用的更多相关文章
- [转]C#使用Log4Net记录日志
第一步:下载Log4Net 下载地址:http://logging.apache.org/log4net/download_log4net.cgi 把下载的 log4net-1.2.11-bin-n ...
- C# 使用 log4net 记录日志
Ø 前言 在一般的开发应用中,都会涉及到日志记录,用于排查错误 或 记录程序运行时的日志信息.log4net 库是 Apache log4j 框架在 Microsoft .NET 平台的实现,是一个 ...
- ASP.NET Core使用log4net记录日志
.NET常用的日志组件有NLog.Log4net等,.NET CORE下微软也自带了日志组件,到目前为止还没用过,而我本人常用的是log4net,下面简单讲讲.NET CORE下怎么使用log4net ...
- 用log4net记录日志信息
在.net中用log4net记录日志信息,已经是很平常的事情了. log4net下载:http://logging.apache.org/log4net/download_log4net.cgi 百度 ...
- 将WebService部署到 SharePoint 2010 gac 缓存中,并用Log4Net记录日志到数据库
最近做了一个sharePoint项目,需要实现的功能是,第三方网站访问我们sharePoint中的数据,通过Webservice方式实现文件的上传和下载. 于是代码工作完成了之后,本地调试没什么问题, ...
- Windows服务使用log4net记录日志
该文章是系列文章 基于.NetCore和ABP框架如何让Windows服务执行Quartz定时作业 的其中一篇. 比较流行的日志组件有以下四种,Topshelf都有相应的组件提供 log4net NL ...
- 使用Log4net记录日志(非常重要)
使用Log4net记录日志 首先说说为什么要进行日志记录.在一个完整的程序系统里面,日志系统是一个非常重要的功能组成部分.它可以记录下系统所产生的所有行为,并按照某种规范表达出来.我们可以使用日志 ...
- Log4net 记录日志
配置文件 备注,需要放到根目录下面 <?xml version="1.0" encoding="utf-8"?> <configuration ...
- 使用 Log4Net 记录日志
第一步:下载Log4Net 下载地址:http://logging.apache.org/log4net/download_log4net.cgi 把下载的 log4net-1.2.11-bin-n ...
随机推荐
- React的井字过三关(3)
这是React井字棋项目的最后一篇笔记,记述AI实现. 一. 是开头都会说的原理 但凡懂一点围棋的人都知道"大场"这个概念,可以浅显地把它理解为布局时棋盘上各处的要点.棋谚&quo ...
- showPrompt弹框提示
工作中会有很多的弹框,用来添加模板,用来信息提示,,我现在用的模板有dialog(用来添加数据模板内容),还有一个就是自写的showPrompt用来判断错误或者正确的信息~~ 样子大概就是这样的,, ...
- RabbitMQ常用命令行
打印了一些rabbitmq服务状态信息,包括内存,硬盘,和使用erlong的版本信息rabbitmqctl -q status 各个参数说明:http://www.rabbitmq.com/man/r ...
- db2look导出ddl 详细用法(转)
DB2的db2look命令诠释如下:db2look 版本 8.2db2look:生成 DDL 以便重新创建在数据库中定义的对象语法: db2look -d DBname [-e] [-u Creato ...
- RN8209校正软件开发心得(1)
最近领导突然让我做软件了,头大啊.以前也没怎么自己独立做过软件,这次来的突然啊,面对这么大的任务量自己只能加把劲了,还等着领导给涨工资呢,哈哈... 作为编程的小白,要自己做一款上位机的软件实属不易啊 ...
- 用RMAN备份EBS数据库的脚本
rman_bak.sh rman target / nocatalog log=/d01/rmanbak/bak_`date +%m%d%H%M`.log<< EOF run { c ...
- PV、EV、AC、BAC、EAC、ETC等计算公式含义
PV.EV.AC.BAC.EAC.ETC等计算公式含义 PV Planned Value:计划值 应该完成多少工作, (按照计划截止目前应该花费的预算) AC Actual Cost:实际成本, 完成 ...
- Python爬虫利器三之Xpath语法与lxml库的用法
前面我们介绍了 BeautifulSoup 的用法,这个已经是非常强大的库了,不过还有一些比较流行的解析库,例如 lxml,使用的是 Xpath 语法,同样是效率比较高的解析方法.如果大家对 Beau ...
- css负边距之详解
自从1998年CSS2作为推荐以来,表格的使用渐渐退去,成为历史.正因为此,从那以后CSS布局成为了优雅代码的代名词. 对于所有设计师使用过的CSS概念,负边距作为最少讨论到的定位方式要记上一功.这就 ...
- Maven的Missing artifact问题解决
Maven的Missing artifact问题解决 今天在创建一个新的Maven项目时,在其中添加了很多依赖.刚开始为了避免错误就每添加一次,保存一下,Eclipse就会下载相应的包.最后为了 ...