当前位置: 首页 > news >正文

Log4Net使用教程

简介

为方便跟踪程序运行情况,我们可以记录系统运行异常日志,winform和web都可以通过继承异常或者try来实现。

官方网站:http://logging.apache.org/log4net/

使用方法

第一步,安装dll

Install-Package log4net

或者右键引用,选择nuget来添加。

第二步,新建配置文件,并填写配置

我的配置:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
  </configSections>

  <log4net>
    <!--其中layout节点的配置说明:
    %m(message):输出的日志消息;
    %n(newline):换行;
    %d(datetime):输出当前语句运行的时刻;
    %r(runtime):输出程序从运行到执行到当前语句时消耗的毫秒数;
    %t(threadid):当前语句所在的线程ID ;
    %p(priority): 日志的当前日志级别;
    %c(class):当前日志对象的名称;
    %L:输出语句所在的行号;
    %F:输出语句所在的文件名;
    %-10:表示最小长度为10,如果不够,则用空格填充;-->
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <!--日志路径-->
      <param name= "File" value= "App_Log/"/>
      <!--多线程时采用最小锁定-->
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <!--是否是向文件中追加日志-->
      <param name= "AppendToFile" value= "true"/>
      <!--log保留天数-->
      <!--<param name= "MaxSizeRollBackups" value= "10"/>-->
      <!--日志文件名是否是固定不变的-->
      <param name= "StaticLogFileName" value= "false"/>
      <!--日志文件名格式为:2008-08-31.log-->
      <param name= "DatePattern" value= "yyyy-MM-dd&quot;.log&quot;"/>
      <!--日志根据日期滚动-->
      <param name= "RollingStyle" value= "Date"/>
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n%d [%t] %-5p %c - %m %loggername%n" />
      </layout>
    </appender>

    <!--定义输出到控制台命令行中-->
    <!--<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    --><!--定义输出到windows事件中--><!--
    <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    --><!--定义输出到数据库中,这里举例输出到Access数据库中,数据库为C盘的log4net.mdb--><!--
    <appender name="AdoNetAppender_Access" type="log4net.Appender.AdoNetAppender">
      <connectionString value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:log4net.mdb" />
      <commandText value="INSERT INTO LogDetails ([LogDate],[Thread],[Level],[Logger],[Message]) VALUES (@logDate, @thread, @logLevel, @logger,@message)" />
    </appender>-->
    <!-- 控制台前台显示日志 -->
    <!--<appender name="ColoredConsoleAppender" type="log4net.Appender.ColoredConsoleAppender">
      <mapping>
        <level value="ERROR" />
        <foreColor value="Red, HighIntensity" />
      </mapping>
      <mapping>
        <level value="Info" />
        <foreColor value="Green" />
      </mapping>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%n%date{HH:mm:ss,fff} [%-5level] %m" />
      </layout>

      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="Info" />
        <param name="LevelMax" value="Fatal" />
      </filter>
    </appender>-->

    <root>
      <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) -->
      <level value="all" />
      <!--<appender-ref ref="ColoredConsoleAppender"/>-->
      <appender-ref ref="RollingLogFileAppender"/>
    </root>
  </log4net>
</configuration>

第三步,新建日志类,编写日志写入函数。

public class LogHelper
    {
        public ILog Logger { get; set; }
        public LogHelper()
        {
       //设置配置文件
var logCfg = new FileInfo(AppDomain.CurrentDomain.BaseDirectory + "log4net.config"); XmlConfigurator.ConfigureAndWatch(logCfg); Logger = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); } }

 第四步,使用

  1. 新建LogHelper类
  2. 调用

logger.Info("消息");
logger.Warn("警告");
logger.Error("异常");
logger.Fatal("错误");

第五步,结果展示

 

转载于:https://www.cnblogs.com/birdofparadise/p/7144062.html

相关文章:

  • 面试——经典问题1
  • AI行为树
  • solr和es的区别
  • 于ccexp.WebView调用loadURL的清除本地缓存
  • c#Code Contracts代码协定
  • Sql Server中集合的操作(并集、差集、交集)学习
  • Linux下汇编语言学习笔记1 ---
  • angularJs-route路由详解
  • python 博客
  • P1198 [JSOI2008]最大数(单调栈)
  • Windows内存管理的方式
  • [POJ2104]K-th Number
  • window10 java 环境变量配置
  • Codeforces Round #423 (Div. 2, rated, based on VK Cup Finals) C. String Reconstruction 并查集
  • STC15F2K60S2与USART HMI串口屏之间的通信
  • 10个最佳ES6特性 ES7与ES8的特性
  • 11111111
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • Centos6.8 使用rpm安装mysql5.7
  • Java 11 发布计划来了,已确定 3个 新特性!!
  • js如何打印object对象
  • PHP的类修饰符与访问修饰符
  • python 装饰器(一)
  • 短视频宝贝=慢?阿里巴巴工程师这样秒开短视频
  • 简析gRPC client 连接管理
  • 聊聊flink的TableFactory
  • 三分钟教你同步 Visual Studio Code 设置
  • 使用Swoole加速Laravel(正式环境中)
  • 通过npm或yarn自动生成vue组件
  • 物联网链路协议
  • 职业生涯 一个六年开发经验的女程序员的心声。
  • 直播平台建设千万不要忘记流媒体服务器的存在 ...
  • ​LeetCode解法汇总307. 区域和检索 - 数组可修改
  • ​如何防止网络攻击?
  • #define、const、typedef的差别
  • #Linux(Source Insight安装及工程建立)
  • (3)选择元素——(17)练习(Exercises)
  • (Forward) Music Player: From UI Proposal to Code
  • (八)Spring源码解析:Spring MVC
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (附源码)计算机毕业设计SSM基于java的云顶博客系统
  • (九)One-Wire总线-DS18B20
  • (一)基于IDEA的JAVA基础1
  • ***原理与防范
  • .NET 4 并行(多核)“.NET研究”编程系列之二 从Task开始
  • .NET CORE 3.1 集成JWT鉴权和授权2
  • .NET Core Web APi类库如何内嵌运行?
  • .NET Core 网络数据采集 -- 使用AngleSharp做html解析
  • .NET gRPC 和RESTful简单对比
  • .NET Micro Framework初体验
  • .NET 程序如何获取图片的宽高(框架自带多种方法的不同性能)
  • .NET学习教程二——.net基础定义+VS常用设置
  • .NET运行机制
  • .net中调用windows performance记录性能信息
  • [ vulhub漏洞复现篇 ] Celery <4.0 Redis未授权访问+Pickle反序列化利用