.net6 引用log4net记录日志

1
2
3
4
5
6
7
第一步:nuget包引用
使用log4net 需要引用两个nuget包
 
1. Log4net
2. Microsoft.Extensions.Logging.Log4Net.AspNetCore
 
第二步:引用log4net的config配置文件 配置文件贴在下面了 需要自取

  

复制代码
<?xml version="1.0" encoding="utf-8"?>

    
    <!--站点日志配置部分-->
    <log4net>
        <!-- Define some output appenders -->
        <appender name="rollingAppender" type="log4net.Appender.RollingFileAppender">
            <file value="log4\log.txt" />
            <!--追加日志内容-->
            <appendToFile value="true" />

            <!--防止多线程时不能写Log,官方说线程非安全-->
            <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

            <!--可以为:Once|Size|Date|Composite-->
            <!--Composite为Size和Date的组合-->
            <rollingStyle value="Composite" />

            <!--当备份文件时,为文件名加的后缀-->
            <datePattern value="yyyyMMdd.TXT" />

            <!--日志最大个数,都是最新的-->
            <!--rollingStyle节点为Size时,只能有value个日志-->
            <!--rollingStyle节点为Composite时,每天有value个日志-->
            <maxSizeRollBackups value="20" />

            <!--可用的单位:KB|MB|GB-->
            <maximumFileSize value="10MB" />

            <!--置为true,当前最新日志文件名永远为file节中的名字-->
            <staticLogFileName value="true" />

            <!--输出级别在INFO和ERROR之间的日志-->
            <filter type="log4net.Filter.LevelRangeFilter">
                <param name="LevelMin" value="ALL" />
                <param name="LevelMax" value="FATAL" />
            </filter>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
            </layout>
        </appender>

        <!--SqlServer形式-->
        <!--log4net日志配置:http://logging.apache.org/log4net/release/config-examples.html -->
        <appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
            <!--日志缓存写入条数 设置为0时只要有一条就立刻写到数据库-->
            <bufferSize value="0" />
            <connectionType value="System.Data.SqlClient.SqlConnection,System.Data.SqlClient, Version=4.6.1.3, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
            <connectionString value="Data Source=DESKTOP-T2D6ILD;Initial Catalog=LogManager;Persist Security Info=True;User ID=sa;Password=sa123" />
            <commandText value="INSERT INTO Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
            <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="@message" />
                <dbType value="String" />
                <size value="4000" />
                <layout type="log4net.Layout.PatternLayout">
                    <conversionPattern value="%message" />
                </layout>
            </parameter>
            <parameter>
                <parameterName value="@exception" />
                <dbType value="String" />
                <size value="2000" />
                <layout type="log4net.Layout.ExceptionLayout" />
            </parameter>
        </appender>

        <root>

            <!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
            <!--OFF:0-->
            <!--FATAL:FATAL-->
            <!--ERROR: ERROR,FATAL-->
            <!--WARN: WARN,ERROR,FATAL-->
            <!--INFO: INFO,WARN,ERROR,FATAL-->
            <!--DEBUG: INFO,WARN,ERROR,FATAL-->
            <!--ALL: DEBUG,INFO,WARN,ERROR,FATAL-->
            <priority value="ALL"/>

            <level value="INFO"/>
            <appender-ref ref="rollingAppender" />
            <appender-ref ref="AdoNetAppender_SqlServer" />
        </root>
    </log4net>
    
复制代码
第三步 右键配置文件 找到属性选项  将“复制到输出目录” 更改为  "始终复制"
如下图

 

 

第四步:在program类中
添加如下代码

 

 到此,关于在.net6中 log4net的引用就结束喽!!!

posted @   有追求的小码农  阅读(364)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
点击右上角即可分享
微信分享提示