1) 创建配置文件,可以放在任意位置,名字可以任意的xml文件

例如,文件名 Log.Config.xml,内容如下

<?xml version="1.0" encoding="utf-8"?>

<log4net name="DefaultLogger">

<root>

<level value="ALL"/>

</root>

<logger name="Doraemon.Hardware">

<appender-ref ref="HardwareLogger"/>

</logger>

<logger name="Doraemon.Software">

<appender-ref ref="UILogger"/>

</logger>

<!--硬件日志-->

<appender name="HardwareLogger" type="log4net.Appender.RollingFileAppender">

<param name="File" value="Log\Hardware\" />

<param name="AppendToFile" value="true" />

<param name="rollingStyle" value="Date" />

<param name="datePattern" value="yyyy-MM-dd_'Log.txt'" />

<param name="staticLogFileName" value="false"/>

<param name="ImmediateFlush" value="true" />

<!-- 增加这个,可以立即写日志,好像不起作用 -->

这个模板,可以省略日期

<layout type="log4net.Layout.PatternLayout">

<param name="Header" value="[开始] "/>

<param name="Footer" value="[结尾] "/>

<!--

<param name="ConversionPattern"  value="%d %-5p - %m%n" />

<param name="ConversionPattern"  value="%d [%t] %-5p %c [%x] - %m%n" />

<param name="ConversionPattern"  value="%d{HH:mm:ss,fff} [%t] %-5p %c [%x] - %m%n" />

-->

<param name="ConversionPattern"  value="%d{HH:mm:ss,fff} %-5p - %m%n" />

</layout>

<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

<!--使用最小锁定模型(minimal locking model),以允许多个进程可以写入同一个文件。 -->

<filter type="log4net.Filter.LevelRangeFilter">

<param name="LevelMin" value="DEBUG" />

<param name="LevelMax" value="FATAL" />

<!-- WARN  ERROR-->

</filter>

</appender>

<!--UI & Workflow日志-->

<appender name="UILogger" type="log4net.Appender.RollingFileAppender">

<param name="File" value="Log\Software\" />

<param name="AppendToFile" value="true" />

<param name="rollingStyle" value="Date" />

<param name="datePattern" value="yyyy-MM-dd_'Log.txt'" />

<param name="staticLogFileName" value="false"/>

<param name="ImmediateFlush" value="true" />

<!-- 增加这个,可以立即写日志,好像不起作用 -->

<layout type="log4net.Layout.PatternLayout">

<param name="Header" value="[开始] "/>

<param name="Footer" value="[结尾] "/>

<param name="ConversionPattern"  value="%d{HH:mm:ss,fff} %-5p - %m%n" />

</layout>

<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

<!--使用最小锁定模型(minimal locking model),以允许多个进程可以写入同一个文件。 -->

<filter type="log4net.Filter.LevelRangeFilter">

<param name="LevelMin" value="DEBUG" />

<param name="LevelMax" value="FATAL" />

<!-- WARN  ERROR-->

</filter>

</appender>

</log4net>

2)       程序入口,增加 Log4net 配置入口

/// 应用程序的主入口点。

/// </summary>

///

[STAThread]

static void Main()

{

Application.EnableVisualStyles();

Application.SetCompatibleTextRenderingDefault(false);

//log4net.Config.XmlConfigurator.Configure( ); //为LOG4NET增加的,这个是 配置文件放在 app.config.xml的方式

System.IO.FileInfo fi = new System.IO.FileInfo(@"C:\Users\James\source\repos\WindowsFormsApp_log4net_多个_外部配置\bin\Debug\Log.Config.xml");

log4net.Config.XmlConfigurator.Configure(fi);

//或者

//XmlConfigurator.Configure(new System.IO.FileInfo(@"C:\Users\James\source\repos\WindowsFormsApp_log4net_多个_外部配置\bin\Debug\Log.Config.xml"););

Application.Run(new Form1());

与配置文件的

LogerName 关联

3)      
增加静态的记录器

private static readonly ILog log = LogManager.GetLogger(@"Doraemon.Hardware");//@"Doraemon.UI");
begins by importing log4net related classes.

private static readonly ILog log2 = LogManager.GetLogger(@"Doraemon.Software");//@"Doraemon.UI");
begins by importing log4net related classes.

4)      
开始使用

log.Error("Log1");

log2.Error("log2");

Log4net采用外部配置文件和多记录器的方法的更多相关文章

  1. spark读取外部配置文件的方法

    spark读取外部配置文件的方法 spark-submit  --files /tmp/fileName /tmp/test.jar 使用spark提交时使用--files参数,spark会将将本地的 ...

  2. 19、属性赋值-@PropertySource加载外部配置文件

    19.属性赋值-@PropertySource加载外部配置文件 加载外部配置文件的注解 19.1 [xml] 在原先的xml 中需要 导入context:property-placeholder 声明 ...

  3. SpringBoot常用配置,引入外部配置文件信息,热加载

    SpringBoot的配置文件格式 yml规范 SpringBoot的配置文件支持properties和yml,甚至还支持json. 更推荐使用yml文件格式: yml文件,会根据换行和缩进帮助咱们管 ...

  4. springboot加载外部配置文件

    网上搜集和整理如下(自己已验证过) 1. war包在tomcat中加载外部配置文件 war包运行在独立tomcat下时,如何加载war包外部配置application.properties,以达到每次 ...

  5. 通过外部配置文件做mybatis的基础配置,以及Mapper代理接口的实现

    1.通过外部配置文件做mybatis的基础性的配置. 1)先编写config.properties的文件(做一些动态的配置). 配置的内容如下: jdbc.jdbcUrl=jdbc:oracle:th ...

  6. 为什么要采用外部js文件

    这篇文章主要讲的是为什么要采用外部js文件,有什么好处. 为什么不把js内嵌在html中呢,这样不是好分析吗?对,这样你是好分析,同样的别人呢?不内嵌在html中有如下原因:   安全性: 只要查看页 ...

  7. Spring配置文件中如何使用外部配置文件配置数据库连接

    直接在spring的配置文件中applicationContext.xml文件中配置数据库连接也可以,但是有个问题,需要在url后带着使用编码集和指定编码集,出现了如下问题,&这个符号报错-- ...

  8. application.properties多环境配置文件、jar包外部配置文件、配置项加密、程序中配置使用

    一.简介 spring boot项目application.properties文件存放及使用介绍 二.方法一多环境配置文件 我们一般都会有多个应用环境,开发环境.测试环境.生产环境,各个环境的配置会 ...

  9. jar包读取jar包内部和外部的配置文件,springboot读取外部配置文件的方法

    jar包读取jar包内部和外部的配置文件,springboot读取外部配置文件的方法 用系统属性System.getProperty("user.dir")获得执行命令的目录(网上 ...

随机推荐

  1. netframework webapi IogAttribute记录request参数和错误信息

    参考博客 https://www.cnblogs.com/hnsongbiao/p/7039666.html 书写LogFilterAttribute public class LogFilterAt ...

  2. Hide()方法不生效

    有时候Jquery中的.hide()不起作用,有时是因为在函数中包括着,   $(".select-dropdown").hide(); 在hide中加一个1就行了   文章来源: ...

  3. 如何规避同时使用v-if与v-for?

    先将结果过滤,再用v-if循环 遇到问题:使用Vue -computed传参数不成功, 后来将参数放在compute里面方法名里再构造参数进行传递

  4. linux下的什么工具可以用来查看PostScript文件?

    答: ghostview,官网在这里

  5. mac下不允许安装除了app store之外的软件设置:

    1.dock栏的系统偏好设置. 2.找到安全性与隐私 3.点击面板中的通用,在点击左小角的锁按钮, 4.选择任何来源,确定就可以了.[如果只有两个选项,而没有任何来源的话,打开终端,执行:sudo s ...

  6. 阶段5 3.微服务项目【学成在线】_day04 页面静态化_22-页面静态化-静态化测试-静态化程序测试

    测试service内些的静态化的方法 先新建一个测试类 模板的id 放到下拉的静态数据里面 这样这条数据 就是用用的轮播图005这个模板 把这条数据静态化 进入到断点里面.先获取数据模型 获取模板时 ...

  7. 苹果系统安装虚拟机 Mac如何安装虚拟机教程 (含系统镜像的下载地址)

    镜像下载地址 http://www.itellyou.cn 1.前言    大家在用 Mac 系统的时候,可能有时难免还是要用到 Windows 系统.在 Mac 上使用 Windows 系统有二种方 ...

  8. PAT 甲级 1030 Travel Plan (30 分)(dijstra,较简单,但要注意是从0到n-1)

    1030 Travel Plan (30 分)   A traveler's map gives the distances between cities along the highways, to ...

  9. nginx rewrite正则子组最多匹配到$9

    nginx rewrite正则匹配()匹配子组最多匹配到$9,就是从$0到$9 当需要匹配更多子组时,可通过变量来实现 if ($uri ~ ^/forum-15/sortid-74/(.*?)(la ...

  10. QFramework 使用指南 2020(八):Res Kit(2)模拟模式与非模拟模式

    在上一篇,介绍了 Res Kit 的基本使用,相信大家已经体会到了 Res Kit 的简便之处了. 在这一篇,我们试着探讨一下 Res Kit 的设计背后原理. AssetBundle 的不便之处 在 ...