LOG4NET

         

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <!--log4net配置-->
    <log4net>
        <!--定义输出到文件中-->
        <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
            <!--定义文件存放位置-->
            <!--保存路径:下面路径项目启动的时候自动在C盘中创建log、logError文件-->
            <file value="Logs/INFO/" />
            <!-- 追加到文件 -->
            <appendToFile value="true" />
            <!--记录日志写入文件时,不锁定文本文件,防止多线程时不能写Log,官方说线程非安全-->
            <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
            <!--使用Unicode编码-->
            <Encoding value="GBK" />
            <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
            <rollingStyle value="Composite" />
            <!--这是按日期产生文件夹-->
            <datePattern value="yyyy-MM-dd/yyyyMMdd&quot;.log&quot;" />
            <!--是否只写到一个文件中-->
            <staticLogFileName value="false" />
            <!--保留的log文件数量 超过此数量后 自动删除之前的   好像只有在 按Size分割时有效 设定值value="-1"为不限文件数-->
            <param name="MaxSizeRollBackups" value="100" />
            <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志-->
            <maximumFileSize value="1MB" />
            <!--日志的等级,它们由高到底分别为:
      
OFF > FATAL > ERROR > WARN > INFO > DEBUG  > ALL 

高于等级设定值方法(如何设置参见“配置文件详解”)都能写入日志, Off所有的写入方法都不写到日志里,ALL则相反。例如当我们设成Info时,logger.Debug就会被忽略而不写入文件,但是FATAL,ERROR,WARN,INFO会被写入,因为他们等级高于INFO。

在具体写日志时,一般可以这样理解日志等级:

FATAL(致命错误):记录系统中出现的能使用系统完全失去功能,服务停止,系统崩溃等使系统无法继续运行下去的错误。例如,数据库无法连接,系统出现死循环。

ERROR(一般错误):记录系统中出现的导致系统不稳定,部分功能出现混乱或部分功能失效一类的错误。例如,数据字段为空,数据操作不可完成,操作出现异常等。

WARN(警告):记录系统中不影响系统继续运行,但不符合系统运行正常条件,有可能引起系统错误的信息。例如,记录内容为空,数据内容不正确等。

INFO(一般信息):记录系统运行中应该让用户知道的基本信息。例如,服务开始运行,功能已经开户等。

DEBUG (调试信息):记录系统用于调试的一切信息,内容或者是一些关键数据内容的输出。
-->


            <!--过滤设置,LevelRangeFilter为使用的过滤器。 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <param name="LevelMin" value="DEBUG" />
                <param name="LevelMax" value="FATAL" />
            </filter>
            <!-- layout 控制Appender的输出格式,也可以是xml  一个Appender只能是一个layout-->
            <layout type="log4net.Layout.PatternLayout">
                <!--每条日志末尾的文字说明-->
                <!--输出格式-->
                <!--样例:2008-03-26 13:42:32,111 [10] INFO  Log4NetDemo.MainClass [(null)] - info-->
                <conversionPattern value="时间:%date___描述:%message%newline" />
            </layout>
        </appender>
        <appender name="ERRORFileAppender" type="log4net.Appender.RollingFileAppender">
            <!--定义文件存放位置-->
            <!--保存路径:下面路径项目启动的时候自动在C盘中创建log、logError文件-->
            <file value="Logs/ERROR/" />
            <!-- 追加到文件 -->
            <appendToFile value="true" />
            <!--记录日志写入文件时,不锁定文本文件,防止多线程时不能写Log,官方说线程非安全-->
            <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
            <!--使用Unicode编码-->
            <Encoding value="GBK" />
            <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
            <rollingStyle value="Composite" />
            <!--这是按日期产生文件夹-->
            <datePattern value="yyyy-MM-dd/yyyyMMdd&quot;.log&quot;" />
            <!--是否只写到一个文件中-->
            <staticLogFileName value="false" />
            <!--保留的log文件数量 超过此数量后 自动删除之前的   好像只有在 按Size分割时有效 设定值value="-1"为不限文件数-->
            <param name="MaxSizeRollBackups" value="100" />
            <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志-->
            <maximumFileSize value="1MB" />
            <!--过滤设置,LevelRangeFilter为使用的过滤器。 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <param name="LevelMin" value="DEBUG" />
                <param name="LevelMax" value="FATAL" />
            </filter>
            <!-- layout 控制Appender的输出格式,也可以是xml  一个Appender只能是一个layout-->
            <layout type="log4net.Layout.PatternLayout">
                <!--每条日志末尾的文字说明-->
                <!--输出格式-->
                <!--样例:2008-03-26 13:42:32,111 [10] INFO  Log4NetDemo.MainClass [(null)] - info-->
                <!--<conversionPattern value="%newline时间:%date 线程ID:[%thread] 日志级别:%-5level 出错类:%logger property:[%property{NDC}] - 错误描述:%message%newline" />-->
                <conversionPattern value="%newline时间:%date  %newline线程ID:[%thread] %newline出错类方法:[%class.%method]%newline错误描述:%message%newline"/>

            </layout>
        </appender>


        <logger name="LogFile">
            <appender-ref ref="LogFileAppender" />
        </logger>
        <logger name="LogError">
            <appender-ref ref="ERRORFileAppender" />
        </logger>
    </log4net>
</configuration>

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Properties/LogConfigure.xml", ConfigFileExtension = "config", Watch = true)]

 public static class LogHelper
    {
        public static ConcurrentQueue<string[]> logQueue = new ConcurrentQueue<string[]>();
        private static readonly log4net.ILog debug = log4net.LogManager.GetLogger("LogFile");
        public static void Info(string info)
        {
            if (debug.IsErrorEnabled)
            {
                debug.Info(info);
                logQueue.Enqueue(new string[2] { DateTime.Now.ToString("yy-MM-dd HH:mm:ss"),info});
                Console.WriteLine(info);
            }
        }
        public static readonly log4net.ILog error = log4net.LogManager.GetLogger("LogError");
        private static void Error(string info, Exception exception)
        {
            if (error.IsErrorEnabled)
            {
                error.Error(info, exception);
                Console.WriteLine(info + "__" + exception.Message);
            }
        }

        private static readonly log4net.ILog data = log4net.LogManager.GetLogger("LogData");
        public  static void Datainfo(string info)
        {
            if (data.IsErrorEnabled)
            {
                data.Info(info);
                logQueue.Enqueue(new string[2] { DateTime.Now.ToString("yy-MM-dd HH:mm:ss"), info });
                Console.WriteLine(info);
            }
        }
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

橘子酸呢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值