Asp .Net Core 集成 NLog

简介

NLog是一个基于.NET平台编写的日志记录类库,它可以在应用程序中添加跟踪调试代码,以便在开发、测试和生产环境中对程序进行监控和故障排除。NLog具有简单、灵活和易于配置的特点,支持在任何一种.NET语言中输出带有上下文的调试诊断信息,并能够将这些信息发送到一个或多个输出目标(target)中,如文件、数据库、控制台等。

NLog的API非常类似于log4net,但配置方式更加简单,使用路由表(routing table)进行配置,使得配置文件易于阅读和维护。此外,NLog还支持结构化日志记录,可以方便地记录复杂的数据类型,如对象、集合等。它还提供了可扩展性,允许用户编写自定义目标或传递自定义值,以满足特定的日志记录需求。

NLog支持多种平台,包括.NET Framework、.NET Core、Xamarin、ASP.NET等,可以在各种应用程序中使用。同时,NLog还遵从BSD license,允许商业应用且完全开放源代码,因此得到了广泛的应用和支持。

NLog 支持结构化日志 记录和传统日志记录。

NLog的重点是:高性能、易于使用、易于扩展和灵活配置

 

NLog配置文件说明

文件位置

启动时,NLog 在各种文件中搜索其配置,如下所述。它加载找到的第一个 nlog 配置。当找到第一个 nlog 配置时,搜索结束。如果未找到配置,NLog 将不会执行任何日志记录。

对于独立的 *.exe 应用程序,按如下方式搜索文件:

  • 标准应用程序配置文件 app.config(例如 applicationname.exe.config)
  • 应用程序目录中的 applicationname.exe.nlog
  • 应用程序目录中的 NLog.config
  • NLog.dll.nlog 位于 NLog.dll 所在目录中(仅当 NLog 未安装在 GAC 中时)

对于 ASP.NET 应用程序,按如下方式搜索文件:

  • 标准 Web 应用程序配置文件 web.config
  • web.nlog 与 web.config 位于同一目录
  • 应用程序目录中的 NLog.config
  • NLog.dll.nlog 位于 NLog.dll 所在目录中(仅当 NLog 未安装在 GAC 中时)

另请参阅显式 NLog 配置加载(包括有关assetsXamarin Android 的 -folder 的详细信息)

元素说明

您可以使用以下元素作为 的子元素nlogtargetsrules在任何配置中都是必需的 其他是可选的,并且在高级场景中很有用。

  • targets– 定义日志目标/输出
  • rules– 定义日志路由规则
  • extensions– 从 *.dll 文件加载 NLog 扩展
  • include– 包括外部配置文件
  • variable– 设置配置变量的值
Targets:定义日志目标/输出
<targets><target name="f"xsi:type="File"fileName="${basedir}/logs/${shortdate}.log"layout="${longdate} ${uppercase:${level}} ${message}" maxArchiveFiles="5"archiveAboveSize="10240"archiveEvery="Day"/>
</targets>0

Nlog允许用户配置单个文件大小, 放置在内容过长效率过慢,配置了大小之后, Nlog会自动创建一个新的文件副本,插入新的日志输出。

maxArchiveFiles:允许生成的副本文件最大数量

archiveAboveSize:允许单个文件得最大容量

archiveEvery:按天生成

name:输出目标的名称,用于rules中路由规则writeTo指定

fileName:包含完整的生成文件的路径和文件名

xsi:type:输出类型如下

Chainsaw
ColoredConsole 
Console
Database
Debug
Debugger
EventLog
File
LogReceiverService
Mail
Memory
MethodCall
Network
NLogViewer
Null
OutputDebugString
PerfCounter
Trace
WebService

layout:用来规定输出内容格式,语法“${属性}”,可以把上下文信息插入到日志中。

系统变量参考:Config | NLog

Rules– 定义日志路由规则

路由顺序会对日志打印产生影响。路由匹配逻辑为顺序匹配。

日志可以分不同级别进行输出,日志规则rules里面可以控制输出的日志级别。不同级别的日志代表日志的重要程度,比如一些debug级别的日志在生产环境就会被控制不输出,以减少日志文件的大小。

<rules><logger name="*" minlevel="Debug" writeTo="file" />
</rules>name:记录者的名字。
  • ame– 匹配记录器对象的记录器名称 - 可能包含通配符(* 和 ?)
  • minlevel– 记录的最低级别(与指定级别和上面的级别匹配)
  • maxlevel– 记录的最大级别(与指定级别和下面的级别匹配)
  • level– 单级记录
  • levels- 以逗号分隔的要记录的级别列表
  • writeTo– 以逗号分隔的要写入的目标列表
  • final– 最终规则匹配后不处理任何规则
  • enabled- 设置为false禁用规则而不删除它
  • ruleName- 允许使用 Configuration.FindRuleByName和进行规则查找的规则标识符Configuration.RemoveRuleByName。NLog 4.6.4 中引入
  • FinalMinLevel - 记录器匹配将被限制为以下规则的指定最低级别。NLog 5.0中引入

日志级别有如下,自上而下,等级递增。

  • Trace - 最常见的记录信息,一般用于普通输出
  • Debug - 同样是记录信息,不过出现的频率要比Trace少一些,一般用来调试程序
  • Info - 信息类型的消息
  • Warn - 警告信息,一般用于比较重要的场合
  • Error - 错误信息
  • Fatal - 致命异常信息。一般来讲,发生致命异常之后程序将无法继续执行。

日志过滤器:可以在路由当中, 为每个路由配置自定义得日志过滤器fliter,如下所示

<rules><logger name="*" writeTo="file"><filters><when condition="length('${message}') > 100" action="Ignore" /><when condition="equals('${logger}','MyApps.SomeClass')" action="Ignore" /><when condition="(level >= LogLevel.Debug and contains('${message}','PleaseDontLogThis'))" action="Ignore" /><when condition="not starts-with('${message}','PleaseLogThis')" action="Ignore" /></filters></logger>
</rules>

Asp .Net Core 集成 NLog

安装 NLog.Web.AspNetCore 包

  1. 在您的项目中,通过 NuGet 包管理器安装 NLog.Web.AspNetCore 包。在 Visual Studio 中,您可以右键点击项目 -> 选择 "Manage NuGet Packages" -> 搜索 NLog.Web.AspNetCore -> 点击 "Install"。

    或者通过命令行安装:

    dotnet add package NLog.Web.AspNetCore
    
  2. 配置 NLog

    创建一个 nlog.config 文件在项目的根目录下,并添加您的 NLog 配置。例如:

<?xml version="1.0" encoding="utf-8" ?>  
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  autoReload="true"  throwExceptions="false"  internalLogLevel="Info" internalLogFile="internal-nlog.txt">  <!-- 定义日志输出目标 -->  <targets>  <target xsi:type="File" name="file" fileName="${basedir}/logs/nlog.txt"  layout="${longdate} ${level:uppercase=true} ${message} ${exception}" />  </targets>  <!-- 定义日志规则 -->  <rules>  <logger name="*" minlevel="Debug" writeTo="file" />  </rules>  
</nlog>
  1. 在 Program.cs 中配置 NLog

    // 添加 NLog  
    builder.Logging.ClearProviders();  
    //builder.Logging.SetMinimumLevel(LogLevel.Debug);  
    //NLogBuilder.ConfigureNLog("nlog.config");  
    builder.Host.UseNLog(); 
    
  2. 使用 NLog

    现在您可以在控制器、服务等中注入 ILogger 并使用它记录日志。NLog 将处理这些日志并记录到配置的目标中。

    using Microsoft.AspNetCore.Mvc;namespace NLogTest.Controllers
    {[ApiController][Route("[controller]")]public class WeatherForecastController : ControllerBase{private readonly ILogger<WeatherForecastController> _logger;public WeatherForecastController(ILogger<WeatherForecastController> logger){_logger = logger;}[HttpGet(Name = "GetWeatherForecast")]public IEnumerable<WeatherForecast> Get(){try{           int a = 1 / int.Parse("0");return null;}catch (Exception ex){_logger.LogDebug(ex, ex.Message);_logger.LogTrace(ex, ex.Message);_logger.LogInformation(ex, ex.Message);_logger.LogWarning(ex, ex.Message);_logger.LogError(ex, ex.Message);return Enumerable.Empty<WeatherForecast>();}}}
    }

NLog 自定义全局变量

            app.Use(async (context, next) =>{GlobalDiagnosticsContext.Set("TenantId", 1);GlobalDiagnosticsContext.Set("CreateUserId", 111);await next();});// 使用
${gdc:TenantId}

将日志消息写入MySQL数据库

Database target · NLog/NLog Wiki · GitHub

安装Nuget包

dotnet add package NLog.Database
dotnet add package MySql.Data

数据库准备(MySQL)

create database mcode_log;
use mcode_log;
create table if not exists erp_log
(Id              bigint auto_increment comment '主键'primary key,TenantId        bigint       null comment '租户Id',ApplicationName varchar(100) null comment '程序名称',HostName        varchar(100) null comment '主机',Ip              varchar(100) null comment 'Ip地址',Message         text         null comment '信息',Level           varchar(50)  null comment '级别',ExceptionInfo   text         null comment '异常信息',CallInfo        text         null comment '调用信息',RequestMethod   varchar(20)  null comment '请求方法',RequestUrl      varchar(512) null comment '请求地址',RequestBody     text         null comment '请求主体',CreateTime      datetime     null comment '创建时间',CreateUserId    bigint       null comment '创建用户',CreateUserName  varchar(50)  null comment '创建用户名称'
);

配置NLog

<?xml version="1.0" encoding="utf-8"?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"autoReload="true"throwExceptions="false" throwConfigExceptions="true"internalLogLevel="warn"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><!--生产环境 throwExceptions 建议为false --><extensions><add assembly="NLog.Web.AspNetCore"/><add assembly="NLog.Database"/></extensions><!--internalLogFile="logfiles"--><targets async="true"><!--屏幕打印消息--><target name="console" xsi:type="ColoredConsole"layout="${newline}=======================================================================${newline} 【当前时间】: [${date:format=yyyy-MM-dd HH\:mm\:ss}]                           ${newline} 【 级 别 】:[${level}]                            ${newline} 【 调 用 】:[${callsite}] [${callsite-linenumber}] [${callsite-filename}] [${stacktrace}]                                                            ${newline} 【 消 息 】:[${message}]   ${newline} 【 异 常 】:[${exception:format=ToString}] [${threadname}] [${threadid}]" /><!--VS输出窗口--><target name="debugger" xsi:type="Debugger"layout="${newline}=======================================================================${newline} 【当前时间】: [${date:format=yyyy-MM-dd HH\:mm\:ss}]                           ${newline} 【 级 别 】:[${level}]                            ${newline} 【 调 用 】:[${callsite}] [${callsite-linenumber}] [${callsite-filename}] [${stacktrace}]                                                            ${newline} 【 消 息 】:[${message}]   ${newline} 【 异 常 】:[${exception:format=ToString}] [${threadname}] [${threadid}]" /><!--保存至文件--><target name="info" xsi:type="File" maxArchiveFiles="30"fileName="${basedir}/Logs/Info/${shortdate}.txt"layout="${newline}=======================================================================${newline} 【当前时间】: [${date:format=yyyy-MM-dd HH\:mm\:ss}]                           ${newline} 【 级 别 】:[${level}]                            ${newline} 【 调 用 】:[${callsite}] [${callsite-linenumber}] [${callsite-filename}] [${stacktrace}]                                                            ${newline} 【 消 息 】:[${message}]   ${newline} 【 异 常 】:[${exception:format=ToString}] [${threadname}] [${threadid}]" /><!--保存至文件--><target name="error" xsi:type="File" maxArchiveFiles="30"fileName="${basedir}/Logs/Error/${shortdate}.txt"layout="${newline}=======================================================================${newline} 【当前时间】: [${date:format=yyyy-MM-dd HH\:mm\:ss}]                           ${newline} 【 级 别 】:[${level}]                            ${newline} 【 调 用 】:[${callsite}] [${callsite-linenumber}] [${callsite-filename}] [${stacktrace}]                                                            ${newline} 【 消 息 】:[${message}]   ${newline} 【 异 常 】:[${exception:format=ToString}] [${threadname}] [${threadid}]" /><!--写入数据库--><target xsi:type="Null" name="blackhole"/><target name="database" xsi:type="Database"dbProvider="MySql.Data.MySqlClient.MySqlConnection, MySql.Data"connectionString="server=110.41.14.13;Database=mcode_log;user id=root;password=123456;SslMode=none"><!--<target name="database" xsi:type="Database"dbProvider="MySqlConnector.MySqlConnection, MySqlConnector"connectionString="server=127.0.0.1;Database=mcode_log;user id=root;password=123456;SslMode=none">--><commandText>insert into erp_log (TenantId, ApplicationName, HostName, Ip, Message, Level, ExceptionInfo, CallInfo,RequestMethod, RequestUrl, RequestBody, CreateTime, CreateUserId, CreateUserName)values (@TenantId,@ApplicationName,@HostName,@Ip,@Message,@Level,@ExceptionInfo,@CallInfo,@RequestMethod,@RequestUrl,@RequestBody,@CreateTime,@CreateUserId,@CreateUserName);</commandText><!--注意:对于非字符串,要指定dbType"--><parameter name="@TenantId" layout="${gdc:TenantId}"  dbType="DbType.Int64" /><parameter name="@ApplicationName" layout="${gdc:ApplicationName}"   /><parameter name="@HostName" layout="${hostname}" /><parameter name="@Ip" layout="${gdc:Ip}" /><parameter name="@Message" layout="${message}" /><parameter name="@Level" layout="${level}" /><parameter name="@ExceptionInfo" layout="[${exception:format=ToString}] [${threadname}] [${threadid}]" /><parameter name="@CallInfo" layout="[${callsite}] [${callsite-linenumber}] [${callsite-filename}] [${stacktrace}]" /><parameter name="@RequestMethod" layout="${gdc:RequestMethod}" /><parameter name="@RequestUrl" layout="${gdc:RequestUrl}" /><parameter name="@RequestBody" layout="${gdc:RequestBody}" /><parameter name="@CreateTime" layout="${date}"  dbType="DbType.DateTime" /><parameter name="@CreateUserId" layout="${gdc:CreateUserId}" dbType="DbType.Int64" /><parameter name="@CreateUserName" layout="${gdc:CreateUserName}" /></target></targets><!--规则--><rules><logger name="*" minlevel="Warn" writeTo="console" /><logger name="NLogTest.*" minlevel="Debug"  writeTo="debugger" /><logger name="NLogTest.*" minlevel="Info" maxlevel="Info"  writeTo="info" /><logger name="*" minlevel="Warn" writeTo="error" /><logger name="NLogTest.*" minlevel="Warn" writeTo="database" /></rules>
</nlog>

在这里插入图片描述
在这里插入图片描述

其它数据库

MySql and .NET Core

Install package: NuGet Gallery | MySql.Data 8.3.0

dbProvider="MySql.Data.MySqlClient.MySqlConnection, MySql.Data"

or if using packages: NuGet Gallery | MySqlConnector 2.3.5 and NuGet Gallery | MySqlConnector.Logging.NLog 2.0.0

dbProvider="MySqlConnector.MySqlConnection, MySqlConnector"
System.Data.SQLite and .NET Core

Install package: NuGet Gallery | System.Data.SQLite 1.0.118

dbProvider="System.Data.SQLite.SQLiteConnection, System.Data.SQLite"
Microsoft.Data.SqlClient and .NET Core

Install package: NuGet Gallery | Microsoft.Data.SqlClient 5.1.5

dbProvider="Microsoft.Data.SqlClient.SqlConnection, Microsoft.Data.SqlClient"
Microsoft.Data.Sqlite and .NET Core

Install package: NuGet Gallery | Microsoft.Data.Sqlite 8.0.1

dbProvider="Microsoft.Data.Sqlite.SqliteConnection, Microsoft.Data.Sqlite"
Npgsql and .NET core

Install package: NuGet Gallery | Npgsql 8.0.1

dbProvider="Npgsql.NpgsqlConnection, Npgsql"
Oracle.ManagedDataAccess and .NET
dbProvider="Oracle.ManagedDataAccess.Client.OracleConnection, Oracle.ManagedDataAccess"
Mono.Data.Sqlite and .NET
dbProvider="Mono.Data.Sqlite.SqliteConnection, Mono.Data.Sqlite"

INI 复制 全屏

记录故障排除

有时我们的应用程序不会向日志文件写入任何内容,即使我们应该正确配置了日志记录。日志未写入的原因可能有很多。最常见的问题是权限问题,通常在 ASP.NET 进程中,其中aspnet_wp.exew3wp.exe进程可能没有对我们要存储日志的目录的写访问权限。

NLog 旨在吞掉日志记录可能导致的运行时异常。以下设置可以更改此行为和/或重定向这些消息。

  • <nlog throwExceptions="true" />-throwExceptions在配置文件中添加该属性会导致 NLog 停止屏蔽异常并将其传递给调用应用程序。该属性在部署时非常有用,可以快速定位任何问题。至关重要的是,一旦应用程序正确配置throwExceptions"false"运行,就应立即进行配置,这样意外的日志记录问题就不会导致应用程序挂起或崩溃。
  • <nlog throwConfigExceptions="true" /> - 类似于throwExceptions但仅与配置异常隔离。与此不同的是throwExceptions,启用它并不危险,建议在生产环境中启用,因为在生产环境中,日志记录配置的初始设置成功至关重要。NLog 4.3 中引入。默认null(表示未配置,而是使用 的值throwExceptions
  • <nlog internalLogLevel="Trace|Debug|Info|Warn|Error|Fatal" />– 确定内部日志级别。级别越高,内部日志输出越不详细。当需要诊断日志记录问题时,输出通常非常有帮助。有关设置输出到文件或控制台的选项,请参阅内部日志记录。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/253511.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MATLAB语音去噪系统

目录 一、背景 二、GUI页面 三、程序 3.1 LMS滤波程序 3.2 GUI程序 四、附录 一、背景 本文介绍了一种最佳的自适应滤波器结构&#xff0c;该结构采用最小均方差&#xff08;LMS&#xff09;作为判据&#xff0c;通过不断迭代自适应结构来调整得到最佳滤波器…

升级Oracle 单实例数据库19.3到19.22

需求 我的Oracle Database Vagrant Box初始版本为19.3&#xff0c;需要升级到最新的RU&#xff0c;当前为19.22。 以下操作时间为为2024年2月5日。 补丁下载 补丁下载文档参见MOS文档&#xff1a;Primary Note for Database Proactive Patch Program (Doc ID 888.1)。 补丁…

RTE2023第九届实时互联网大会:揭秘未来互联网趋势,PPT分享引领行业新思考

随着互联网的不断发展&#xff0c;实时互动技术正逐渐成为新时代的核心驱动力。 在这样的背景下&#xff0c;RTE2023第九届实时互联网大会如期而至&#xff0c;为业界人士提供了一个探讨实时互联网技术、交流创新理念的绝佳平台。 本文将从大会内容、PPT分享价值等方面&#…

队列---数据结构

定义 队列&#xff08;Queue&#xff09;简称队&#xff0c;也是一种操作受限的线性表&#xff0c;只允许在表的一端进行插入&#xff0c;而在表的另一端进行删除。向队列中插入元素称为入队或进队&#xff1b;删除元素称为出队或离队。 队头&#xff08;Front&#xff09;&a…

【蓝桥杯冲冲冲】Invasion of the Milkweed G

【蓝桥杯冲冲冲】Invasion of the Milkweed G 蓝桥杯备赛 | 洛谷做题打卡day30 文章目录 蓝桥杯备赛 | 洛谷做题打卡day30[USACO09OCT] Invasion of the Milkweed G题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 题解代码我的一些话 [USACO09OCT] Invasion of the Mi…

前端JavaScript篇之addEventListener()方法的参数和使用

目录 addEventListener()方法的参数和使用参数和使用typelisteneroptionsuseCapturewantsUntrusted addEventListener()方法的参数和使用 addEventListener() 是 JavaScript 中用于向指定元素添加事件监听器的方法。这个方法通常用于处理用户交互&#xff0c;比如点击、鼠标悬…

Unity类银河恶魔城学习记录4-1,4-2 Attack Logic,Collider‘s collision excepetion源代码 P54 p55

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释&#xff0c;可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili Entity.cs using System.Collections; using System.Collections.Generic; u…

统计数字出现次数的数位动态规划解法-数位统计DP

在处理数字问题时,我们经常遇到需要统计一定范围内各个数字出现次数的情况。这类问题虽然看起来简单,但当数字范围较大时,直接遍历统计的方法就变得不再高效。本文将介绍一种利用数位动态规划(DP)的方法来解决这一问题,具体来说,是统计两个整数a和b之间(包含a和b)所有…

JavaScript中call、apply、bind方法的应用与区别

在JavaScript中&#xff0c;call、apply和bind是函数的三个重要方法&#xff0c;它们虽然功能不同&#xff0c;但都可以用来改变函数的执行上下文或者传递参数。本文将分别介绍call、apply和bind方法的应用和区别&#xff0c;并附带示例代码。 一、call方法 call方法的作用是…

Java注解之@PathVariable,一文掌握@PathVariable注解知识(1)

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

【漏洞复现】多语言药房管理系统MPMS文件上传漏洞

Nx01 产品简介 多语言药房管理系统 (MPMS) 是用 PHP 和 MySQL 开发的, 该软件的主要目的是在药房和客户之间提供一套接口&#xff0c;客户是该软件的主要用户。该软件有助于为药房业务创建一个综合数据库&#xff0c;并根据到期、产品等各种参数提供各种报告。 Nx02 漏洞描述 …

【动态规划】【前缀和】【C++算法】LCP 57. 打地鼠

作者推荐 视频算法专题 本文涉及知识点 动态规划汇总 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 LCP 57. 打地鼠 勇者面前有一个大小为3*3 的打地鼠游戏机&#xff0c;地鼠将随机出现在各个位置&#xff0c;moles[i] [t,x,y] 表…

JDK版本如何在IDEA中切换

JDK版本在IDEA中切换 一、项目结构设置 1.Platform——Settings 项目结构---SDKS 2.Project——SDK 3.Modules——SDK——Sources 4.Modules——SDK——Dependencies 二、设置--编译--字节码版本 Settings——Build,——Java Compiler

scikit-learn 1.3.X 版本 bug - F1 分数计算错误

如果您正在使用 scikit-learn 1.3.X 版本&#xff0c;在使用 f1_score() 或 classification_report() 函数时&#xff0c;如果参数设置为 zero_division1.0 或 zero_divisionnp.nan&#xff0c;那么函数的输出结果可能会出错。错误的范围可能高达 100%&#xff0c;具体取决于数…

通过docker-compose部署NGINX服务,并使该服务开机自启

要在通过docker-compose部署的NGINX服务实现开机自启&#xff0c;你需要确保Docker守护进程在系统启动时自动运行&#xff0c;并配置docker-compose.yml文件以在容器中运行NGINX服务。以下是步骤&#xff1a; 确保Docker守护进程开机启动&#xff1a; 在Ubuntu/Debian上&#x…

龙测科技荣获2023年度技术生态构建奖

本月&#xff0c;由极客传媒举办的“有被Q到”2024 InfoQ 极客传媒合作伙伴年会顺利举办&#xff0c;龙测科技喜获2023年度技术生态构建奖。 InfoQ是首批将Node.js、HTML5、Docker等技术全面引入中国的技术媒体之一&#xff0c;秉承“扎根社区、服务社区、引领社区”的理念&…

Oracle篇—logminer日志挖掘恢复误操作数据

☘️博主介绍☘️&#xff1a; ✨又是一天没白过&#xff0c;我是奈斯&#xff0c;DBA一名✨ ✌✌️擅长Oracle、MySQL、SQLserver、Linux&#xff0c;也在积极的扩展IT方向的其他知识面✌✌️ ❣️❣️❣️大佬们都喜欢静静的看文章&#xff0c;并且也会默默的点赞收藏加关注❣…

第三篇:跨平台QT开发-正则表达式和文件处理

正则表达式 正则表达式即一个文本匹配字符串的一种模式&#xff0c;Qt 中 QRegExp 类实现使用正则表达式 进行模式匹配&#xff0c;且完全支持 Unicode&#xff0c;主要应用&#xff1a;字符串验证、搜索、查找替换、分割。 正则表达式中字符及字符集 元素含义 c 匹配字符本…

beep蜂鸣器驱动实验-蜂鸣器驱动代码框架测试

一. 简介 上一篇文章学习了编译蜂鸣器驱动框架代码&#xff0c;并进行了编译。文章地址如下&#xff1a; beep蜂鸣器驱动实验-蜂鸣器驱动框架代码实现-CSDN博客 本文对上一篇所实现的蜂鸣器框架代码进行测试。 二. 蜂鸣器驱动代码框架测试 1. 拷贝驱动程序 注意&#xf…

Android开发--实时监测系统+部署故障诊断算法

0.项目整体思路介绍&#xff1a; 搭建无人装备模拟实验平台&#xff0c;使用采集器对数据进行采集&#xff0c;通过网络通信Udp协议发送到安卓端&#xff0c;安卓端作界面显示&#xff0c;算法使用matlab仿真后&#xff0c;用C语言实现。将采集器采集到的数据经过处理后训练&a…