Log4Net写入到数据库配置过程中的一些小问题备忘
- <log4net>
- <root>
- <level value="WARN"/>
- <level value="INFO"/>
- <level value="DEBUG"/>
- <level value="FINE"/>
- <!--<appender-ref ref="LogFileAppender" />-->
- <appender-ref ref="ADONetAppender" />
- </root>
- <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
- <!--文件名称-->
- <file value="log.txt" />
- <!--所有新的日志都进行追加-->
- <appendToFile value="true" />
- <!--文件名称格式-->
- <datePattern value="-yyyy.MM.dd" />
- <!--文件名按日期滚动-->
- <rollingStyle value="Date" />
- <maxSizeRollBackups value="10" />
- <!--文件名称不固定,可变-->
- <staticLogFileName value="false" />
- <layout type="log4net.Layout.PatternLayout">
- <param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
- </layout>
- </appender>
- <appender name="ADONetAppender" type="log4net.Appender.ADONetAppender">
- <!--BufferSize为缓冲区大小,只有日志记录超1条才会一块写入到数据库-->
- <bufferSize value="1"/>
- <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
- <connectionString value="Data Source=****;Initial Catalog=***;Persist Security Info=True;User ID=sa;Password=***;MultipleActiveResultSets=True"/>
- <commandText value="INSERT INTO edu_log (Date,Thread,Level,Logger,Message,SchoolID,SysTypeID) values(@log_date,@thread,@log_level,@logger,@content,@s_id,@t_id)"/>
- <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="@content" />
- <dbType value="String" />
- <size value="4000" />
- <layout type="FuNong.Framework.Logger.CustomLayout">
- <conversionPattern value="%property{content}" />
- </layout>
- </parameter>
- <parameter>
- <parameterName value="@s_id" />
- <dbType value="String" />
- <size value="50" />
- <layout type="FuNong.Framework.Logger.CustomLayout">
- <conversionPattern value="%property{s_id}" />
- </layout>
- </parameter>
- <parameter>
- <parameterName value="@t_id" />
- <dbType value="String" />
- <size value="50" />
- <layout type="FuNong.Framework.Logger.CustomLayout">
- <conversionPattern value="%property{t_id}" />
- </layout>
- </parameter>
- </appender>
- </log4net>
注意上面配置代码中:log4net.Layout.PatternLayout 是log4net本身提供的配置模板,如果你有的字段需要用到其本身的模板字段的话,就可以使用。
还需要注意这段话: <conversionPattern value="%property{s_id}" />,它表明,我们将会利用log4net提供的已有的property转义模板来识别我们的字段。
但是如果你有自定义字段的话,你就需要自己写layout和converter了。在上面的配置文件中,content,s_id,t_id是我自定义的三个字段,如何让这三个字段也写入到数据库呢,我们一步一步来配置。
首先,需要将三个自定义字段放到一个entity类中:
- namespace FuNong.Framework.Logger
- {
- public class LogContent
- {
- public LogContent(string content, string s_id, string t_id)
- {
- this.content = content;
- this.s_id = s_id;
- this.t_id = t_id;
- }
- public string content { get; set; }
- public string s_id { get; set; }
- public string t_id { get; set; }
- }
- }
然后,定义我们自己的layout,由于我们使用了property字段模板,所以我们这里需要按照如下方式添加:
- namespace FuNong.Framework.Logger
- {
- public class CustomLayout:PatternLayout
- {
- public CustomLayout()
- {
- this.AddConverter("property", typeof(XPatternConverter));
- }
- }
- }
最后,就是我们的Converter实现了:
- namespace FuNong.Framework.Logger
- {
- public class XPatternConverter : PatternLayoutConverter
- {
- protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent)
- {
- if (this.Option != null)
- {
- // Write the value for the specified key
- WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));
- }
- else
- {
- // Write all the key value pairs
- WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());
- }
- }
- /// <summary>
- /// 通过反射获取传入的日志对象的某个属性的值
- /// </summary>
- /// <param name="property"></param>
- /// <returns></returns>
- private Object LookupProperty(String property, log4net.Core.LoggingEvent loggingEvent)
- {
- Object propertyValue = String.Empty;
- PropertyInfo propertyInfo;
- propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
- if (propertyInfo != null)
- {
- propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null);
- }
- return propertyValue;
- }
- }
- }
从上面代码,我们可以看到,log4net会通过反射来识别我们logContent这个entity中的字段,然后逐个赋值,再写到数据库的。
下面我们稍微包装一下:
- namespace FuNong.Framework.Logger
- {
- public interface ILoggerService
- {
- void Debug(object message);
- void Error(object message);
- void Fatal(object message);
- void Info(object message);
- void Warn(object message);
- }
- }
- namespace FuNong.Framework.Logger
- {
- public class LoggerService:ILoggerService
- {
- public LoggerService()
- {
- log4net.Config.XmlConfigurator.Configure();
- logger = LogManager.GetLogger(typeof(LoggerService));
- }
- private readonly ILog logger;
- public void Info(object message)
- {
- logger.Info(message);
- }
- public void Warn(object message)
- {
- logger.Warn(message);
- }
- public void Debug(object message)
- {
- logger.Debug(message);
- }
- public void Error(object message)
- {
- logger.Error(message);
- }
- public void Fatal(object message)
- {
- logger.Fatal(message);
- }
- }
- }
由于我用了autofac做ioc,所以我们就直接看使用方法吧:
- protected override void OnAuthorization(AuthorizationContext filterContext)
- {
- if (auth)
- {
- var collection = cookie.GetCookieCollection("FuNong.UserInfo.Login");
- if (collection == null)
- {
- logger.Warn(new LogContent("用户登陆信息提取失败,将会跳转到登陆界面...", "1", "2"));
- filterContext.Result = new RedirectResult("Home/Login");
- }
- else
- {
- logger.Info(new LogContent("用户验证成功,请继续之前操作...","1","2"));
- }
- }
- }
这样,当我们运行起来后,我们就发现,程序已经将数据写入数据库了。
整个配置不难,但是细节挺多,稍微不小心,就可能导致写入不到数据库。
Log4Net写入到数据库配置过程中的一些小问题备忘的更多相关文章
- 使用log4net连接Mysql数据库配置
log4net配置: //Author:GaoBingBing [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net ...
- 菜鸟帮你跳过openstack配置过程中的坑
一:前言 对于一个以前做java全栈工程师而言,而且没学过Linux,很少用虚拟机(还是在大学的时候简单的用过),去配置openstack我想我入的坑肯定比有基础的一定要多,躺在每个坑中徘徊思索的时间 ...
- 菜鸟帮你跳过openstack配置过程中的坑[文末新添加福利]
一:前言 对于一个以前做java全栈工程师而言,而且没学过Linux,很少用虚拟机(还是在大学的时候简单的用过),去配置openstack我想我入的坑肯定比有基础的一定要多,躺在每个坑中徘徊思索的时间 ...
- Redis配置过程中的问题
记录一下配置过程中的坑~~ 当Redis在服务器上安装完成后,get.set没有问题了,接下来在程序中使用看看... 首先 在配置文件redis.conf中,默认的bind 接口是127.0.0.1, ...
- CAS SSO:汇集配置过程中的错误解决方法
本教程为gevin.me原创文章,转载请注明: CAS SSO:配置过程中的错误解决方法 | Gevin’s Blog 本文将收集在配置CAS SSO遇到的所有错误,希望对大家有帮助,也方便下次搭建的 ...
- ESXi与物理交换机静态链路聚合配置过程中的小陷阱
作者:陆斌文章来自微信公众号:平台人生 内容简介:ESXi与物理交换机之间配置静态链路聚合时,因为静态链路聚合的特点,在进行down网卡和从虚拟交换机移除网卡的操作时,可能会无法完成故障流量切换,影响 ...
- springmvc配置过程中遇到的一些问题总结
springmvc配置过程中遇到的一些问题总结 1.配置tomcat过程中的错误: 2.配置web.xml中DispatchServlet报红(配置好已有依赖条件下) 解决的办法: 因为新添加依赖,m ...
- ACM 做题过程中的一些小技巧。
ACM做题过程中的一些小技巧. 1.一般用C语言节约空间,要用C++库函数或STL时才用C++; cout.cin和printf.scanf最好不要混用. 2.有时候int型不够用,可以用long l ...
- 使用Mac的过程中的一些小操作
前言:使用Mac的过程中的一些小操作 查看Mac系统是32位还是64位: 方法1: 点击左上角的苹果按钮->关于本机->概览->系统报告->软件->偏好设置面板:右侧有提 ...
随机推荐
- svn错误
在myEclipse客户端第一次连到SVN时,如:svn://192.168.20.242/MyProject1,然后要求输入用户名和密码.如果用户名和密码输入出错了,强行确定后.问题来了!会出现,以 ...
- 【转】Python开发指南:最佳实践精选
总体原则 价值 “为别人开发你也想要使用的工具.” ——Kenneth Reitz "简洁总是胜过可用." ——Pieter Hintjens "满足90%的使用场景.忽 ...
- Android开源项目汇总【转】
主要介绍那些不错个性化的View,包括ListView.ActionBar.Menu.ViewPager.Gallery.GridView.ImageView.ProgressBar.TextView ...
- 深入剖析 Spring 框架的 BeanFactory
说到Spring框架,人们往往大谈特谈一些似乎高逼格的东西,比如依赖注入,控制反转,面向切面等等.但是却忘记了最基本的一点,Spring的本质是一个bean工厂(beanFactory)或者说bean ...
- Oracle与SQL SERVER编程差异分析(入门)
网上有关Oracle与SQL SERVER性能差异的文章很多,结论往往是让你根据数据量与预算来选择数据库.但实际项目中,特别是使用 .Net 开发的系统,支持以上两种数据库或者更多已经成为Boss的普 ...
- ERP产品价格成本计算的几个方法(转)
一般财务计算产品价格又很多方法,我这里做了几个供参考,实体属性主要是编号.数量.价格等,这里就不列出了. /// <summary> /// 先进先出算法 /// </s ...
- Redis系列(二)—— 数据类型及其使用
Redis数据类型及其使用 参考:http://www.cnblogs.com/jackluo/p/3173436.html Redis支持五种数据类型:string(字符串),hash(哈希),li ...
- ElasticSearch Filter Aggregations
类似于sql语句中where子句的作用 { "query": { "match_all": {} }, "aggs": { "ag ...
- nyoj 120 校园网络
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=120 思路:先将原图强连通缩点为新图,统计新图中入度,出度为0的点的个数,两者取最大值即为 ...
- 虚拟机Linux----Ubuntu1204----安装jdk1.8
1.介绍 这里主要讲一下,如何在Ubuntu1204下通过压缩包的方式安装jdk1.8,rpm的直接运行就行了. 2.步骤 2.1 下载 地址:http://www.oracle.com/techne ...