Log4net 写文件日志与数据库日志

一、数据库日志表结构

[sql] view plaincopy

  1. CREATE TABLE [dbo].[WebLog_Msg](
  2. [LogID] [int] IDENTITY(1,1) NOT NULL,
  3. [Date] [datetime] NOT NULL,
  4. [Thread] [nvarchar](255) NULL,
  5. [Level] [nvarchar](50) NULL,
  6. [Logger] [nvarchar](255) NULL,
  7. [Message] [nvarchar](2000) NULL,
  8. [Exception] [nvarchar](4000) NULL,
  9. CONSTRAINT [PK_WebLog_Msg] PRIMARY KEY CLUSTERED
  10. (
  11. [LogID] ASC
  12. ))

二、测试类库LoggHelper

[csharp] view plaincopy

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using log4net;
  6. namespace LogHelper
  7. {
  8. public class LoggHelper
  9. {
  10. //static LoggHelper()
  11. //{
  12. //    log4net.Config.XmlConfigurator.Configure();
  13. //}
  14. private static readonly log4net.ILog log = log4net.LogManager.GetLogger(typeof(LoggHelper));
  15. public static void LogInfo()
  16. {
  17. log.Info("log日志getretertretrree");
  18. }
  19. public static void LogWarn()
  20. {
  21. log.Warn("log警告WARNaaaaaaaaaad;");
  22. }
  23. public static void LogFatal()
  24. {
  25. log.Fatal("log警告WARNaaaaaaaaaad;");
  26. }
  27. public static void LogError()
  28. {
  29. log.Error("log错误sfsfsfsdfafasdfdsfadffafdsaffasf><><>2eewewjklsfaaaaaaaaaaaaaaaaaaaaaaaaaaaaad;");
  30. }
  31. }
  32. }

三、控制台测试项目

[csharp] view plaincopy

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using LogHelper;
  6. namespace TestLog4Net
  7. {
  8. class Program
  9. {
  10. static void Main(string[] args)
  11. {
  12. log4net.Config.XmlConfigurator.Configure();
  13. try
  14. {
  15. LoggHelper.LogInfo();
  16. LoggHelper.LogWarn();
  17. LoggHelper.LogError();
  18. LoggHelper.LogFatal();
  19. Console.ReadLine();
  20. }
  21. catch (Exception ex)
  22. {
  23. Console.Write(ex);
  24. }
  25. }
  26. }
  27. }

配置文件内容如下:

[csharp] view plaincopy

  1. <?xml version="1.0"?>
  2. <configuration>
  3. <!--Log4Net config section-->
  4. <configSections>
  5. <!--<sectionGroup name="common">
  6. <section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging" />
  7. </sectionGroup>-->
  8. <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
  9. </configSections>
  10. <!--<common>
  11. <logging>
  12. <factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4Net">
  13. <arg key="configType" value="INLINE"/>
  14. </factoryAdapter>
  15. </logging>
  16. </common>-->
  17. <log4net>
  18. <root>
  19. <!--OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
  20. <level value="ALL"/>
  21. <appender-ref ref="AdoNetAppender_SqlServer"/>
  22. <appender-ref ref="RollingLogFileAppender"/>
  23. </root>
  24. <!--<logger name="ErrorInfo">
  25. <level value="ALL" />
  26. <appender-ref ref="RollingLogFileAppender" />
  27. </logger>-->
  28. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  29. <filter type="log4net.Filter.LevelRangeFilter">
  30. <levelMin value="Debug" />
  31. <levelMax value="Info" />
  32. </filter>
  33. <param name="File" value="log\errorInfo.txt"/>
  34. <param name="AppendToFile" value="true"/>
  35. <param name="MaxSizeRollBackups" value="10"/>
  36. <param name="MaximumFileSize" value="2MB"/>
  37. <param name="RollingStyle" value="Size"/>
  38. <param name="StaticLogFileName" value="true"/>
  39. <layout type="log4net.Layout.PatternLayout">
  40. <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n"/>
  41. </layout>
  42. </appender>
  43. <appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
  44. <filter type="log4net.Filter.LevelRangeFilter">
  45. <levelMin value="Warn" />
  46. <levelMax value="Fatal" />
  47. </filter>
  48. <bufferSize value="0" />
  49. <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
  50. <connectionString value="server=XXXXX;database=WebLog;user id=UID;password=PSW;Connect Timeout=15;"/>
  51. <commandText value="INSERT INTO WebLog_Msg([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
  52. <parameter>
  53. <parameterName value="@log_date" />
  54. <dbType value="DateTime" />
  55. <layout type="log4net.Layout.RawTimeStampLayout" />
  56. </parameter>
  57. <parameter>
  58. <parameterName value="@thread" />
  59. <dbType value="String" />
  60. <size value="255" />
  61. <layout type="log4net.Layout.PatternLayout">
  62. <conversionPattern value="%thread" />
  63. </layout>
  64. </parameter>
  65. <parameter>
  66. <parameterName value="@log_level" />
  67. <dbType value="String" />
  68. <size value="50" />
  69. <layout type="log4net.Layout.PatternLayout">
  70. <conversionPattern value="%level" />
  71. </layout>
  72. </parameter>
  73. <parameter>
  74. <parameterName value="@logger" />
  75. <dbType value="String" />
  76. <size value="255" />
  77. <layout type="log4net.Layout.PatternLayout">
  78. <conversionPattern value="%logger" />
  79. </layout>
  80. </parameter>
  81. <parameter>
  82. <parameterName value="@message" />
  83. <dbType value="String" />
  84. <size value="2000" />
  85. <layout type="log4net.Layout.PatternLayout">
  86. <conversionPattern value="%message" />
  87. </layout>
  88. </parameter>
  89. <parameter>
  90. <parameterName value="@exception" />
  91. <dbType value="String" />
  92. <size value="4000" />
  93. <layout type="log4net.Layout.ExceptionLayout" />
  94. </parameter>
  95. </appender>
  96. </log4net>
  97. <!--Log4Net config section end-->
  98. </configuration>

四、运行结果

1、文件

[plain] view plaincopy

  1. 2011-12-31 14:40:17,440 [10] INFO  LogHelper.LoggHelper [(null)] - log日志getretertretrree

2、数据库

五、优化log4net在项目中的配置

关注封装日志操作的类库LogHelper:

在AssemblyInfo.cs文件中加入[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Configuration/Log4Net.config", Watch = true)],即加入log4net配置项。

在文件Log4Net.config中配置如下:

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <configuration>
  3. <!--Log4Net config section-->
  4. <configSections>
  5. <!--<sectionGroup name="common">
  6. <section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging" />
  7. </sectionGroup>-->
  8. <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
  9. </configSections>
  10. <!--<common>
  11. <logging>
  12. <factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4Net">
  13. <arg key="configType" value="INLINE"/>
  14. </factoryAdapter>
  15. </logging>
  16. </common>-->
  17. <log4net>
  18. <root>
  19. <!--OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
  20. <level value="ALL"/>
  21. <appender-ref ref="AdoNetAppender_SqlServer"/>
  22. <appender-ref ref="RollingLogFileAppender"/>
  23. </root>
  24. <!--<logger name="ErrorInfo">
  25. <level value="ALL" />
  26. <appender-ref ref="RollingLogFileAppender" />
  27. </logger>-->
  28. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  29. <param name="File" value="log\errorInfo.txt"/>
  30. <param name="AppendToFile" value="true"/>
  31. <param name="MaxSizeRollBackups" value="10"/>
  32. <param name="MaximumFileSize" value="2MB"/>
  33. <param name="RollingStyle" value="Size"/>
  34. <param name="StaticLogFileName" value="true"/>
  35. <layout type="log4net.Layout.PatternLayout">
  36. <!--"%d %t %p %l %m %n”:
  37. 1、%d输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss},输出类似:2005-7-19 17:49:27,刚好适合插入SQLServer;
  38. 2、%t  产生该日志事件的线程名;
  39. 3、%p 日志的log_level,如DEBUG、WARN或者INFO;
  40. 4、%c  输出所属的类目,通常就是所在类的全名,如“iNotes.Default”;
  41. 5、%m 日志的内容;
  42. 6、%l  输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。如write2database.main(write2database.java:33);
  43. 7、%n  输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
  44. -->
  45. <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n"/>
  46. </layout>
  47. </appender>
  48. <appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
  49. <filter type="log4net.Filter.LevelRangeFilter">
  50. <levelMin value="Warn" />
  51. <levelMax value="Fatal" />
  52. </filter>
  53. <bufferSize value="0" />
  54. <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
  55. <connectionString value="server=XXXX;database=Weblog;user id=UID;password=PSW"/>
  56. <commandText value="INSERT INTO WebLog_Msg([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
  57. <parameter>
  58. <parameterName value="@log_date" />
  59. <dbType value="DateTime" />
  60. <layout type="log4net.Layout.RawTimeStampLayout" />
  61. </parameter>
  62. <parameter>
  63. <parameterName value="@thread" />
  64. <dbType value="String" />
  65. <size value="255" />
  66. <layout type="log4net.Layout.PatternLayout">
  67. <conversionPattern value="%thread" />
  68. </layout>
  69. </parameter>
  70. <parameter>
  71. <parameterName value="@log_level" />
  72. <dbType value="String" />
  73. <size value="50" />
  74. <layout type="log4net.Layout.PatternLayout">
  75. <conversionPattern value="%level" />
  76. </layout>
  77. </parameter>
  78. <parameter>
  79. <parameterName value="@logger" />
  80. <dbType value="String" />
  81. <size value="255" />
  82. <layout type="log4net.Layout.PatternLayout">
  83. <conversionPattern value="%logger" />
  84. </layout>
  85. </parameter>
  86. <parameter>
  87. <parameterName value="@message" />
  88. <dbType value="String" />
  89. <size value="255" />
  90. <layout type="log4net.Layout.PatternLayout">
  91. <conversionPattern value="%message" />
  92. </layout>
  93. </parameter>
  94. <parameter>
  95. <parameterName value="@exception" />
  96. <dbType value="String" />
  97. <size value="4000" />
  98. <layout type="log4net.Layout.ExceptionLayout" />
  99. </parameter>
  100. </appender>
  101. </log4net>
  102. <!--Log4Net config section end-->
  103. </configuration>

即把应用程序config文件下有关log4net的所有配置项移除放到单一文件Log4Net.config中,这样给应用程序的配置文件“瘦身”不少,呵呵!

ok,编译类库LoggHelper(可在里面封装对log4net的所有操作),将控制台程序改为

[csharp] view plaincopy

  1. static void Main(string[] args)
  2. {
  3. //log4net.Config.XmlConfigurator.Configure(); //注释掉
  4. try
  5. {
  6. LoggHelper.LogInfo();
  7. LoggHelper.LogWarn();
  8. LoggHelper.LogError();
  9. LoggHelper.LogFatal();
  10. Console.ReadLine();
  11. }
  12. catch (Exception ex)
  13. {
  14. Console.Write(ex);
  15. }
  16. }

运行,一切ok!

附有关log4net的对数据库写日志的配置:

http://logging.apache.org/log4net/release/config-examples.html

时间: 2024-08-27 23:58:07

Log4net 写文件日志与数据库日志的相关文章

【Z13区】《Log4net写出适合自己的日志类》第一篇

我想先知道为什么要用log4net写日志类 1.上来就是干,先实践后理论 a.创建控制台应用

【Z13区】《Log4net写出适合自己的日志类》第二篇【没有理论的实践是盲目】

在第一篇中,已经真刀实枪用log4net干过了一次.也是希望大家能先感受到什么是log4net.但是只没有理论的实践肯定是盲目的,所以这一篇, 咱们好好谈谈log4net的配置等其他信息 log4net来源 log4net是Apache软件基金会Apache Logging Services工程的一部分.Apache日志服务工程致力于为程序调试和审计提供跨语言的日志服务. 详细说明,源码下载 可以参考官网:http://logging.apache.org/log4net/ Apache Log

【Z13区】《Log4net写出适合自己的日志类》第三篇【终】【怎样让它适合你自己需求】

第一篇   用特别简单的实例打开log4net的体验之门. 第二篇   用理论,让我们了解那些配置文件的意义所在,让我们回过头看懂了第一篇写的配置文件,和输出内容的格式. 本篇中,[由于大量代码和文字叙述,很容易忽略一些重要信息,所以本篇基本以源代码为中心,简单在博客中讲解重点步骤] 我将直接公布一份源码[包括大部分的常用apperder配置],如果大家看了前两篇. 基本也能看懂源码内容了[源码中会有大量备注]. GITHUB地址:https://github.com/tanshanli/Z13

log4net 写数据到sql数据库

最近需要把用户的一些行为添加到数据库中,所以想到了用log4net ,如果有别的好的方案,大家可以给我指正. 先看一下配置文件 我这个是控制台文件 app.config <layout type="LogTest.MyLayout, LogTest" > <param name="ConversionPattern" value="%property{Log_Type}"/> </layout> 这样的是自定义

Log4Net的应用教程之保存日志到数据库中

关于Log4Net的应用,网上有很多教程,但大多数都是拷贝复制,有些按照他的代码来,运行起来发现也出不来效果,但是Log4net的作用实在是非常大的,或者这里说的不对,应该说系统的日志功能是很重要的也很有必要的,当然设置系统的时候完全可以自己来开发一个日志功能,不外乎就是写日志到文件或者数据库中等等,如果写日志到数据库中,那么就需要使用ADO了,如果是三层架构的,那么这个日志添加就不能再任何地方都可以随便添加了,但是Log4net可以做到独立的链接数据库,并且在系统的任何地方都能够使用. 01

使用log4net写自定义日志

在使用log4net写Web服务器端日志的时候,通常需要一些自定义的参数,比如请求的url,method,以及用户名等等,而log4net中默认的Log接口只提供了很少的参数.    在网上找的其他的解决方案,都是要重写很多地方,而且经常都是不全,让人很难理解,我反正是看不懂...    对俺们这些整天玩黑科技的人来说,自然要用一些不那么正常的方式来解决问题. 在这里,黑科技的意思是指绕过API或者直接修改API,其中带有一定的危险性的代码. 简单研究了一下log4net的源码(使用ILSpy反

log4net 添加自定义日志到数据库

添加操作日志到数据库举例: (一)建立数据库的操作日志表,如下我建立了一个简单的日志表 (二)配置文件中的配置如下 <log4net> <!--错误日志记录数据库--> <logger name="OperateDB"> <level value="INFO"/> <appender-ref ref="AdoNetAppender_OperToSql" /> </logger>

数据库日志文件和内存刷新机制

1.错误日志 error log 错误日志 error.log :记录了MySQL启动.运行.关闭过程中出现的问题. 2.慢查询日志 记录超过阀值时间的所有SQL语句,默认10s,等于10s不记. 1.5.1记录到slow_log表中. log_output参数可以指定慢查询日志输出格式,默认FILE , 可以设置成TABLE,这样就可以查看表了. 3.查询日志 记录所有日志无论是否正确执行. 4.二进制日志  binary log 记录关于事务的具体操作内容,就是对事务操作的描述,并未记录数据

SQL Server 2008 R2 下如何清理数据库日志文件

USE [master] GO ALTER DATABASE [数据库名] SET RECOVERY SIMPLE WITH NO_WAIT GO ALTER DATABASE [数据库名] SET RECOVERY SIMPLE GO USE [数据库名] GO DBCC SHRINKFILE (N'[数据库日志文件名称]' , 0,TRUNCATEONLY) GO USE [master] GO ALTER DATABASE [数据库名] SET RECOVERY FULL WITH NO_