在做目前的项目中用到别的小组开发的一个日记记录的类,今天打开源程序看了一下,原来是在组件外又包了一层,于是自已试了试组件的应用。
一.简介
是apache组织开发的日志组件, 可以从 //downloads.html下 载的源代码。
同log4j一样(java下的日志记录组件)用户要在自己的程序里加入日志功能,只需将.dll引入工程即 可。
是一个开源项目. 可以以插件的形式应用在你的系统中。
程序员在使用ErrorLog做日志记录的时候完全不用关心的工作方式,只需简单的调用即可。
二.配置
1. 引用.dll到项目中。
2. 加载配置,在使用做日志记录之前必须要对进行配置。
可在程序集中设置[assembly: .Config.DOMConfigurator()]
也可在使用前设置.Config.DOMConfigurator.Configure();
这句话也可放到global中Application_Start,在application启动时加载
3.可以看到上面的代码都没有参数. 是载入了缺省配置. 该配置必须设置于web.config或者app.config中。
在web.cofig根节点 configuration 中加入如下section:
<configSections>
<section name="" type=".Config.Log4NetConfigurationSectionHandler, " />
</configSections>
4.该 config section 声明了名为 的另外一个config section. 后者必须位于web.config根节点 configuration 下: 以下是一个示例:
< debug="false">
<appender name="LogFileAppender" type=".Appender.FileAppender" >
<param name="File" value="XxxxApplication.log.txt" />
<param name="datePattern" value="MM-dd HH:mm" />
<param name="AppendToFile" value="true" />
<layout type=".Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />
</layout>
</appender>
<appender name="HttpTraceAppender" type=".Appender.ASPNetTraceAppender" >
<layout type=".Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />
</layout>
</appender>
<appender name="EventLogAppender" type=".Appender.EventLogAppender" >
<layout type=".Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />
</layout>
</appender>
<appender name="RollingLogFileAppender" type=".Appender.RollingFileAppender">
<param name="File" value="_LogDataLog.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=".Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />
</layout>
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="LogFileAppender" />
</root>
</>
5. 以上定义了多个appender. 简单来说, 每一个 appender 都是一种输出介质。
6. root节点指定了选用的 appender. 本例选用了LogFileAppender. (文本文件输出). 在Appender定义中定义了输出的格式. 和目标文本文件所在位置. (起始位置是应用程序根目录. (web.config所在目录).
如此便配置好了。
7、关于配置中ConversionPattern 的转换符
每种转换符号都以%开始,后面跟着一个格式符号和换符号。
%-数字 :该项的最小长度,小于最小长度的用空格填充
%m(message):输出的日志消息
%n(new line):换行
%d(datetime):输出当前语句运行的时刻
%r(run time):输出程序从运行到执行到当前语句时消耗的毫秒数
%t(thread id):当前语句所在的线程ID
%p(priority): 日志的当前优先级别,即DEBUG、INFO、WARN…等
%c(class):当前日志对象的名称,
%L(line ):输出语句所在的行号
%F(file name):输出语句所在的文件名
如 "%-5p [%t]- %m%n"
.ILog M_Log = LogManager.GetLogger(this.GetType());
M_Log .Debug("Test");
生成输出为
DEBUG [main]- Test
8、level级别
在配置文件的ROOT里有<level value="DEBUG" />设置级别的语句
level 有 ALL<DEBUG <INFO<WARN<ERROR<FATAL<OFF 这么几级,大小关系也是这样 如果你调用 m_log.Info("message") 即是INFO级别,如果设置的级别为<level value="ERROR" />那就输出不到日志文件,相反如果低于就能输出
三,使用
调用类的Debug、Info、Warn、Error、Fatal等方法,如果级别高于设置级别即可将日志写入日志文件。
各种方法实现后的效果是一样的,仅是在日志文件中标注出等级。
2022年春节假期陆续结束,根据惯例在春节之后各大云服务商会继续开始一年的促销活动。今年二月中旬会开启新春采购季的活动,我们已经看到腾讯云商家在春节期间已经有预告活动。当时已经看到有抢先优惠促销活动,目前我们企业和个人可以领取腾讯云代金券满减活动,以及企业用户可以领取域名优惠低至.COM域名1元。 直达链接 - 腾讯云新春采购活动抢先看活动时间:2022年1月20日至2022年2月15日我们可以在...
天上云怎么样?天上云隶属于成都天上云网络科技有限公司,是一家提供云服务器及物理服务器的国人商家,目前商家针对香港物理机在做优惠促销,香港沙田机房采用三网直连,其中电信走CN2,带宽为50Mbps,不限制流量,商家提供IPMI,可以自行管理,随意安装系统,目前E3-1225/16G的套餐低至572元每月,有做大规模业务的朋友可以看看。点击进入:天上云官方网站天上云香港物理机服务器套餐:香港沙田数据中...
VPSMS最近在做两周年活动,加上双十一也不久了,商家针对美国洛杉矶CN2 GIA线路VPS主机提供月付6.8折,季付6.2折优惠码,同时活动期间充值800元送150元。这是一家由港人和国人合资开办的VPS主机商,提供基于KVM架构的VPS主机,美国洛杉矶安畅的机器,线路方面电信联通CN2 GIA,移动直连,国内访问速度不错。下面分享几款VPS主机配置信息。CPU:1core内存:512MB硬盘:...