我在C#应用中一般使用log4net来记录日志,但如果项目中有个多个工程,那么没有工程都需要引用log4neg,感觉很不爽。不过今日在开spring.net的时候,看到了有个通用日志接口Common Logging,可以很好的解决项目中多个工程的问题。由于Common Logging是一个日志的基础设施接口,因此更换到其他日志框架,也不需要修改程序代码。
因为我不愿意将所有的配置参数都写入到app.config.xml,那样会把配置文件弄得很大、很乱。我的思路是:在配置文件中加载Common Logging, 通过Common Logging的Adapter的参数制定Log4net文件的位置,而spring的配置文件可以通过应用程序加载或者在app.config.xml中加载都可以。
Common Logging的配置如下:(ver:1.2.0.0,该版本有spring决定)
<?xml version="1.0" encoding="utf-8" ?> |
<sectionGroup name="common"> |
<section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging" /> |
<factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4net"> |
<arg key="configType" value="FILE" /> <!-- FILE,FILE-WATCH,INLINE,EXTERNAL--> |
<arg key="configFile" value="~/log4net.xml" /> |
<arg key="level" value="INFO" /> |
而Log4net的配置也终于实现了将错误日志和业务日志分离的功能。具体配置如下:(ver:1.2.10)
<?xml version="1.0" encoding="utf-8" ?> |
<appender name="debugLog" type="log4net.Appender.RollingFileAppender,log4net" > |
<param name="File" value="logs\debug.log" /> |
<param name="AppendToFile" value="true" /> |
<param name="RollingStyle" value="Date" /> |
<param name="DatePattern" value="yyyyMMdd" /> |
<param name="StaticLogFileName" value="true" /> |
<layout type="log4net.Layout.PatternLayout,log4net"> |
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}%newline%message%n" /> |
<filter type="log4net.Filter.LevelRangeFilter"> |
<param name="LevelMin" value="DEBUG" /> |
<appender name="infoLog" type="log4net.Appender.RollingFileAppender,log4net" > |
<param name="File" value="logs\info.log" /> |
<param name="AppendToFile" value="true" /> |
<param name="RollingStyle" value="Date" /> |
<param name="DatePattern" value="yyyyMMdd" /> |
<param name="StaticLogFileName" value="true" /> |
<layout type="log4net.Layout.PatternLayout,log4net"> |
<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" /> |
<filter type="log4net.Filter.LevelRangeFilter"> |
<param name="LevelMin" value="INFO" /> |
<param name="LevelMax" value="INFO" /> |
<appender name="errorLog" type="log4net.Appender.RollingFileAppender,log4net" > |
<param name="File" value="logs\error.log" /> |
<param name="AppendToFile" value="true" /> |
<param name="RollingStyle" value="Date" /> |
<param name="DatePattern" value="yyyyMMdd" /> |
<param name="StaticLogFileName" value="true" /> |
<layout type="log4net.Layout.PatternLayout,log4net"> |
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}%newline%message%n" /> |
<filter type="log4net.Filter.LevelRangeFilter"> |
<param name="LevelMin" value="ERROR" /> |
<param name="LevelMax" value="ERROR" /> |
<appender-ref ref="debugLog" /> |
<appender-ref ref="infoLog"/> |
<appender-ref ref="errorLog" /> |
</log4net>
- 使用Common.Logging+log4net规范日志管理
Common.Logging+(log4net/NLog/) common logging是一个通用日志接口,log4net是一个强大的具体实现,也可以用其它不同的实现,如EntLib的日志.NLog ...
- 使用Common.Logging+log4net规范日志管理【转载】
使用Common.Logging+log4net规范日志管理 Common.Logging+(log4net/NLog/) common logging是一个通用日志接口,log4net是一个强大 ...
- Common.Logging.dll----------配置方式,可选引用,用于日志输出
1.简介common logging是一个通用日志接口,log4net是一个具体实现. common logging可以把输出连接到其他非log类上, 如EntLib的日志.NLog等 2.使用接下来 ...
- 基于Common.Logging + Log4Net实现的日志管理
前言 Common.Logging 是Commons-Logging(apache最早提供的日志门面接口,提供了简单的日志实现以及日志解耦功能) 项目的.net版本.其目的是为 "所有的.n ...
- Python 中 logging 日志模块在多进程环境下的使用
因为我的个人网站 restran.net 已经启用,博客园的内容已经不再更新.请访问我的个人网站获取这篇文章的最新内容,Python 中 logging 日志模块在多进程环境下的使用 使用 Pytho ...
- Python中内置的日志模块logging用法详解
logging模块简介 Python的logging模块提供了通用的日志系统,可以方便第三方模块或者是应用使用.这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如文件,HTTP GET/P ...
- python中的logging日志模块
日志是程序不可或缺的一部分.它可以记录程序的运行情况,帮助我们更便捷地发现问题,而python中的logging日志模块给我们提供了这个机会. logging给我们提供了五种函数用来输出日志:debu ...
- 使用Common.Logging与log4net的组件版本兼容问题
引用: http://www.cnblogs.com/shijun/p/3713830.html 近期使用了Common.Logging的ILog接口做日志接口,同时利用其log4net适配器与lo ...
- Common.Logging源码解析二
Common.Logging源码解析一分析了LogManager主入口的整个逻辑,其中第二步生成日志实例工厂类接口分析的很模糊,本随笔将会详细讲解整个日志实例工厂类接口的生成过程! (1).关于如何生 ...
随机推荐
- python事件调度库sched
事件调度 sched模块内容很简单,只定义了一个类.它用来最为一个通用的事件调度模块. class sched.scheduler(timefunc, delayfunc)这个类定义了调度事件的通用接 ...
- vue爬坑之input组件
本篇写给第一次用VUE写输入框组件的朋友们 正常情况我们vue2.0是怎么样取到input框的值的呢? 很简单只需要给input框设置v-model="val" 我们就能从data ...
- light oj 1095 组合数学
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <math.h> ...
- Error-Idea:Process finished with exit code 1
ylbtech-Error-Idea:Process finished with exit code 1 1.返回顶部 1. log4j:WARN No appenders could be foun ...
- 转载https://www.luogu.org/problemnew/solution/P1665,http://bailian.openjudge.cn/practice/2002/的新解法
不知道为什么O(n^4)O(n4)的玄学方法能过,正解显然是O(n^2)O(n2)的,枚举对角线,然后算出另外两点判断存不存在. 关键就在怎么通过对角线算出另外两点的坐标. 先贴公式. int mid ...
- Python PIL 怎么知道写入图片格式的kb大小
把图片数据写入一个IO,读这个IO的长度大小: #-*-coding:utf-8-*- from PIL import Image import io img = Image.open("1 ...
- MapReduce 图解流程超详细解答(2)-【map阶段】
接上一篇讲解:http://blog.csdn.net/mrcharles/article/details/50465626 map任务:溢写阶段 正如我们在执行阶段看到的一样,map会使用Mappe ...
- 周期串Uva455 P37 3-4
A character string is said to have period k if it can be formed by concatenating one or more repetit ...
- Odoo文档管理/知识管理应用实践 - 上传附件
测试环境: Odoo8.0 Odoo中的文档管理/知识管理可用于保存采购.销售.生产等一系列业务流程中产生的文件.凭证,可关联到具体的每一笔业务操作:也能用于管理公司的合同.资料,创建知识库以分享内部 ...
- leyou_01_自定义异常处理器
1.自定义异常处理器,当程序发生异常时可以我们可以自己定义返回的,状态码和状态信息 2.当异常发生时调用我们的自定义异常 @RestController @RequestMapping("i ...