• 【新阁教育】基于Log4Net实现日志信息双向存储(含源码)


    1、引言

    在上位机开发中,日志记录是必不可少的,我们可以通过日志记录做日志分析及错误追踪。初学者会采用txt文本写入来实现日志保存,但是文本写入不是线程安全,当存在多个线程同时写入日志时,就会出现一些问题。Log4net库是.Net下一个非常优秀的开源日志记录组件,是一个帮助开发者将日志信息输出到各种目标(控制台、文件、数据库等)的工具。本节主要采用开源组件Log4Net来实现错误ERROR信息文本存储,并结合SQLite数据库,将日志INFO信息存储到数据库中,便于后续的查询。+vx:xiketang777领取源码

    2、开发准备

    • 首先新建一个Windows窗体应用,取名为thinger.cn.Log4NetSQLitePro,UI界面设计如下所示:

    • 通过Nuget添加Log4Net开源组件,如下所示:

    • 通过Nuget添加SQLite组件,如下所示:

    3、文本存储

    一般情况下,我们可以将一些错误及异常信息存储在文本中,便于随时打开文件进行查询,文本存储将自动以天为单位,每天对应一个文件,步骤如下:

    • 添加一个应用程序配置文件项目右击添加新建项,项目类型选择应用程序配置文件,名称为log4net.config,如下所示:

    • 配置文件编写日志配置文件增加相关节点,如下所示:

    配置文件规定了日志信息的相关属性、存储方式、日志内容格式等,配置信息如下所示:

    其中,较为重要的是日志信息的格式,对应上面文件中的ConversionPattern,值为"[%d]%n%m%n%n",每个占位符有对应的含义,如下所示:+vx:xiketang777领取源码

    字符格式

    说明%m(message)输出的日志消息%n(newline)换行%d(datetime)输出当前语句运行的时刻%r(runtime)输出程序执行到当前消耗的毫秒数%t(threadid)当前语句所在的线程ID%p(priority)日志的当前日志级别%c(class)当前日志对象的名称%L输出语句所在的行号%F输出语句所在的文件名%-10最小长度为10,不够空格填充

    • 配置文件属性中的复制到输出目录,设置为始终复制或如果较新则复制,如下图所示:

    • 项目的AssemblyInfo.cs类中添加一行代码,如下所示:

    • 添加一个LogHelper类,编写2个Error的方法,如下所示:

    • 在ini文本存储按钮事件下,调用错误日志写入,如下所示:

    • 执行完成后,在项目目录,LogError目录下,产生一条当天日志命名的文件,打开如下所示:

    4、SQLite存储

    日志信息存储到数据库的好处在于便于用户通过界面进行查询,这里采用开源免费数据库SQLite,其他关系型数据库,如SQLServer、mysql,原理都是一样的,具体步骤如下所示:

    • 创建数据库及数据表通过SQLiteStudio软件创建一个数据库,取名为Log4NetSQLite,执行以下脚本创建一个Log数据表:

    • 将数据库文件复制到项目根目录下的DataBase文件夹中
    • 修改log4net.config文件,增加数据库存储相关配置,如下所示:

    bufferSize:日志缓存写入条数 设置为0时只要有一条就立刻写到数据库

    connectionString:SQLite指向的是数据库文件的绝对路径

    • LogHelper类中增加一个Info方法,如下所示:

    • 在SQLite存储按钮事件下,调用Info日志写入,如下所示:

    • 执行完成后,打开数据库,查看是否有相关记录:

    5、实际应用

    通过上面一系列的描述,相信大家对Log4Net的应用有了一些了解,Log4Net构建的日志系统是很多项目必备的一个功能,对项目开发、调试及后续维护都有着至关重要的作用。实际使用时,我们还可以将Log4Ne作为一个简单的数据存储工具,甚至可以使用Log4Net做多表多库存储,这些内容后续再给大家进行介绍。

    6、写在最后【需要源码必看】

    最近发现越来越多的小伙伴投入到C#上位机学习中,初学者学习最大的困扰就是无人交流,可以+vx:xiketang777 拉你进入工控上位机学习交流群,欢迎各位小伙伴加入,仅限前200名,本文源码也可通过加群获取。

  • 相关阅读:
    生成文件的MD5文件
    磁场动 电子不动, 有 洛伦兹力 吗 ?
    牛顿水桶 的 水面凹陷 和 变轻 就是 个 离心力, 大家 这么 慌乱 干什么 ?
    《【竞价】宏观微观统一量子化波动方程》 回复
    一些有意义的课题 : 氢原子光谱 氢原子电子云 小孔衍射 双缝干涉
    调和级数 和 双盲测试
    webrtc降噪原理
    关于浏览器显示的图片点击下载
    Windows 下如何添加和删除服务
    领域驱动设计知识语境、限界上下文、领域
  • 原文地址:https://www.cnblogs.com/xiketang/p/13651638.html
Copyright © 2020-2023  润新知