.NET 6.0 使用log4net配置日志记录方法

news2024/9/27 6:35:24

1.包管理器引入相关包

2.添加Log4net文件夹和log4net.config配置文件(配置文件属性设为始终复制)。

 

3.替换 log4net.config的内容(3.1与3.2选择一个就好,只是创建日志文件有所区别)

        3.1:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
	<log4net>
		<!--根配置-->
		<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-->
			<level value="ALL"/>
			<appender-ref ref="ErrorLog" />
			<appender-ref ref="WarnLog" />
			<appender-ref ref="InfoLog" />
			<appender-ref ref="DebugLog" />
			<appender-ref ref="FATALLog" />
		</root>
		<!-- 错误 Error.log-->
		<appender name="ErrorLog" type="log4net.Appender.RollingFileAppender">
			<!--日志文件路径,可以是相对路径或绝对路径-->
			<file value="Logs\Error"/>
			<encoding value="utf-8"/>
			<!--文件名,按日期生成文件夹-->
			<datePattern value="/yyyy-MM-dd/'Error.log'" />
			<!--追加日志内容到文件-->
			<appendToFile value="true"/>
			<!--防止多线程时不能写Log,官方说线程非安全-->
			<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
			<!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]-->
			<rollingStyle value="Composite"/>
			<!--分割文件时在扩展名之前-->
			<preserveLogFileNameExtension value="true" />
			<!--日志最大个数,都是最新的,设为"-1"则不限-->
			<!--rollingStyle节点为Size时,只能有value个日志-->
			<!--rollingStyle节点为Composite时,每天有value个日志-->
			<maxSizeRollBackups value="-1"/>
			<!--单个文件大小。单位:KB|MB|GB-->
			<maximumFileSize value="200MB"/>
			<!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字-->
			<staticLogFileName value="false"/>

			<!--日志格式-->
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
			</layout>
			<!--输出级别是ERROR的日志,-->
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="ERROR" />
				<param name="LevelMax" value="ERROR" />
			</filter>
		</appender>

		<!-- 警告 Warn.log-->
		<appender name="WarnLog" type="log4net.Appender.RollingFileAppender">
			<!--日志文件路径,可以是相对路径或绝对路径-->
			<file value="Logs\Warn"/>
			<encoding value="utf-8"/>
			<!--文件名,按日期生成文件夹-->
			<datePattern value="/yyyy-MM-dd/'Warn.log'" />
			<!--追加日志内容到文件-->
			<appendToFile value="true"/>
			<!--防止多线程时不能写Log,官方说线程非安全-->
			<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
			<!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]-->
			<rollingStyle value="Composite"/>
			<!--分割文件时在扩展名之前-->
			<preserveLogFileNameExtension value="true" />
			<!--日志最大个数,都是最新的,设为"-1"则不限-->
			<!--rollingStyle节点为Size时,只能有value个日志-->
			<!--rollingStyle节点为Composite时,每天有value个日志-->
			<maxSizeRollBackups value="-1"/>
			<!--单个文件大小。单位:KB|MB|GB-->
			<maximumFileSize value="200MB"/>
			<!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字-->
			<staticLogFileName value="false"/>

			<!--日志格式-->
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
			</layout>
			<!--输出级别是Warn的日志,-->
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="WARN" />
				<param name="LevelMax" value="WARN" />
			</filter>
		</appender>
		
		<!-- 信息 Info.log-->
		<appender name="InfoLog" type="log4net.Appender.RollingFileAppender">
			<!--日志文件路径,可以是相对路径或绝对路径-->
			<file value="Logs\Info"/>
			<encoding value="utf-8"/>
			<!--文件名,按日期生成文件夹-->
			<datePattern value="/yyyy-MM-dd/'Info.log'" />
			<!--追加日志内容到文件-->
			<appendToFile value="true"/>
			<!--防止多线程时不能写Log,官方说线程非安全-->
			<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
			<!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]-->
			<rollingStyle value="Composite"/>
			<!--分割文件时在扩展名之前-->
			<preserveLogFileNameExtension value="true" />
			<!--日志最大个数,都是最新的,设为"-1"则不限-->
			<!--rollingStyle节点为Size时,只能有value个日志-->
			<!--rollingStyle节点为Composite时,每天有value个日志-->
			<maxSizeRollBackups value="-1"/>
			<!--单个文件大小。单位:KB|MB|GB-->
			<maximumFileSize value="200MB"/>
			<!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字-->
			<staticLogFileName value="false"/>

			<!--日志格式-->
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
			</layout>
			<!--输出级别是INFO的日志,-->
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="INFO" />
				<param name="LevelMax" value="INFO" />
			</filter>
		</appender>

		<!-- 调试 Debug.log-->
		<appender name="DebugLog" type="log4net.Appender.RollingFileAppender">
			<!--日志文件路径,可以是相对路径或绝对路径-->
			<file value="Logs\Debug"/>
			<encoding value="utf-8"/>
			<!--文件名,按日期生成文件夹-->
			<datePattern value="/yyyy-MM-dd/'Debug.log'" />
			<!--追加日志内容到文件-->
			<appendToFile value="true"/>
			<!--防止多线程时不能写Log,官方说线程非安全-->
			<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
			<!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]-->
			<rollingStyle value="Composite"/>
			<!--分割文件时在扩展名之前-->
			<preserveLogFileNameExtension value="true" />
			<!--日志最大个数,都是最新的,设为"-1"则不限-->
			<!--rollingStyle节点为Size时,只能有value个日志-->
			<!--rollingStyle节点为Composite时,每天有value个日志-->
			<maxSizeRollBackups value="-1"/>
			<!--单个文件大小。单位:KB|MB|GB-->
			<maximumFileSize value="200MB"/>
			<!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字-->
			<staticLogFileName value="false"/>

			<!--日志格式-->
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
			</layout>
			<!--输出级别是DEBUG的日志,-->
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="DEBUG" />
				<param name="LevelMax" value="DEBUG" />
			</filter>
		</appender>
		
		<!-- 严重错误 FATAL.log-->
		<appender name="FATALLog" type="log4net.Appender.RollingFileAppender">
			<!--日志文件路径,可以是相对路径或绝对路径-->
			<file value="Logs\FATAL"/>
			<encoding value="utf-8"/>
			<!--文件名,按日期生成文件夹-->
			<datePattern value="/yyyy-MM-dd/'FATAL.log'" />
			<!--追加日志内容到文件-->
			<appendToFile value="true"/>
			<!--防止多线程时不能写Log,官方说线程非安全-->
			<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
			<!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]-->
			<rollingStyle value="Composite"/>
			<!--分割文件时在扩展名之前-->
			<preserveLogFileNameExtension value="true" />
			<!--日志最大个数,都是最新的,设为"-1"则不限-->
			<!--rollingStyle节点为Size时,只能有value个日志-->
			<!--rollingStyle节点为Composite时,每天有value个日志-->
			<maxSizeRollBackups value="-1"/>
			<!--单个文件大小。单位:KB|MB|GB-->
			<maximumFileSize value="200MB"/>
			<!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字-->
			<staticLogFileName value="false"/>

			<!--日志格式-->
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
			</layout>
			<!--输出级别是FATAL的日志,-->
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="FATAL" />
				<param name="LevelMax" value="FATAL" />
			</filter>
		</appender>
		<!--SqlServer形式,我这里没这要求,需要的可以使用,在之前根据配置字段和数据集信息创建自己的记录表-->
		<!--Nuget引入程序包:System.Data.Sqlclient-->
		<!--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=.;Initial Catalog=LogManager;Persist Security Info=True;User ID=sa;Password=123456" />
			<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>
	</log4net>
</configuration>

创建目录根目录(Logs/下):

        3.2

<?xml version="1.0" encoding="utf-8"?>
<configuration>
	<log4net>
		<!-- Define some output appenders -->
		<appender name="rollingAppender" type="log4net.Appender.RollingFileAppender">
			<!--日志文件路径-->
			<file value="Logs\" />
			<encoding value="utf-8"/>
			<!--文件名,按日期生成文件夹-->
			<datePattern value="/yyyy-MM-dd/'filename.log'" />

			<!--追加日志内容-->
			<appendToFile value="true" />

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

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

			<!--分割文件时在扩展名之前-->
			<preserveLogFileNameExtension value="true" />
			<!--当备份文件时,为文件名加的后缀-->
			<!--<datePattern value="yyyyMMdd.TXT" />-->

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

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

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

			<!--输出级别在INFO和ERROR之间的日志-->
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="INFO" />
				<param name="LevelMax" value="FATAL" />
			</filter>
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
			</layout>
			<!--<layout type="log4net.Layout.PatternLayout">
			<conversionPattern value="[%d{HH:mm:ss}]%m%n"/>
		</layout>-->
		</appender>
		<root>
			<priority value="ALL"/>
			<level value="ALL"/>
			<appender-ref ref="rollingAppender" />
		</root>
	</log4net>
</configuration>

创建目录根目录(Logs/下):

        3.3:对配置信息不熟悉的可以参考:【C#】.net core 6.0 使用第三方日志插件Log4net,配置文件详细说明_log4net 日志文件路径-CSDN博客

4.Program下注入(两种方式,哪个有效用哪个):

#region 将Log4Net加入Logging程序集
//方式1:注入Log4Net
//AddLog4Net函数中的参数是配置文件的路径
//如果这个文件创建在根目录下则不用输入参数
//builder.Logging.AddLog4Net("Log4net/log4net2.config");


//方式2:注入Log4Net
builder.Services.AddLogging(cfg =>
{
     cfg.ClearProviders();//删除所有其他的关于日志记录的配置
     cfg.SetMinimumLevel(LogLevel.Trace);//设置最低的log级别

    //默认的配置文件路径是在根目录,且文件名为log4net.config
    //cfg.AddLog4Net();

    //如果文件路径或名称有变化,需要重新设置其路径或名称
    //比如在项目根目录下创建一个名为Log4net的文件夹,将log4net.config文件移入其中
    //则配置如下:
    cfg.AddLog4Net(new Log4NetProviderOptions()
    {
        Log4NetConfigFileName = "Log4net/log4net.config",
        Watch = true
    });
});
#endregion

 5.使用方式:

 [ApiController]
 [Route("[controller]")]
 public class WeatherForecastController : ControllerBase
 {
     private static readonly string[] Summaries = new[]
     {
     "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
 };
     //方式1依赖注入
     private readonly ILogger<WeatherForecastController> _logger;
     //方式二直接载入
     private static ILog _log = log4net.LogManager.GetLogger(typeof(WeatherForecastController));
     public WeatherForecastController(ILogger<WeatherForecastController> logger)
     {
         _logger = logger;
     }

     [HttpGet(Name = "GetWeatherForecast")]
     public IEnumerable<WeatherForecast> Get()
     {
         _logger.LogInformation("11");
         _logger.LogWarning( "22");
         _logger.LogDebug( "33");
         _logger.LogError( "444");
         _log.Info("AA");
         _log.Warn("BB");
         _log.Debug("CC");
         _log.Error("DD");
         return Enumerable.Range(1, 5).Select(index => new WeatherForecast
         {
             Date = DateTime.Now.AddDays(index),
             TemperatureC = Random.Shared.Next(-20, 55),
             Summary = Summaries[Random.Shared.Next(Summaries.Length)]
         })
         .ToArray();
     }
 }

6.两种使用方式的区别(ILogger是.NET框架提供的一个接口,用于统一不同日志库的调用方式。它本身并不提供具体的日志记录功能,而是通过实现它的类来执行这些操作。):

log4net的ILog接口和依赖注入的ILogger接口主要区别在于它们的实现方式、使用场景和灵活性。

  • 实现方式‌:log4net的ILog接口是log4net库中的一个接口,用于日志记录。它通常是通过直接引入log4net.dll并在代码中手动创建和使用Logger对象来实现的。这种方式下,Logger对象的创建和使用都集中在应用程序代码中。

  • 使用场景‌:log4net的ILog接口更适合于传统的.NET应用程序,其中日志记录是应用程序的一部分,需要通过log4net提供的API来手动控制日志的输出。

  • 灵活性‌:由于log4net的ILog接口是直接集成在应用程序中的,因此它的配置和使用相对固定,不太容易进行灵活的配置更改。例如,如果需要更改日志的输出目标(如文件、数据库等),可能需要修改应用程序代码。

相比之下,依赖注入的ILogger接口是.NET Core及以后版本推荐使用的日志记录方式,它提供了更高的灵活性和扩展性:

  • 实现方式‌:ILogger是通过依赖注入的方式实现的,它是一个接口,可以通过不同的实现类来提供不同的日志记录功能。例如,可以使用Serilog、NLog等第三方库来实现ILogger接口的具体类,从而满足不同的日志记录需求。

  • 使用场景‌:ILogger更适合于现代的应用程序开发,特别是那些需要高度可配置和可扩展的日志记录系统。通过依赖注入,ILogger可以很容易地集成到应用程序中,并且可以通过配置文件或代码进行灵活的配置更改。

  • 灵活性‌:由于ILogger是一个接口,可以通过依赖注入来替换具体的实现类,这使得日志记录系统的更换和升级变得非常容易。此外,由于ILogger接口定义了一组标准的日志记录方法,包括信息、警告、错误等不同级别的日志记录,这为应用程序的开发提供了便利,同时也为日志的分析和处理提供了标准化的数据格式。

总的来说,log4net的ILog接口更适合于传统的.NET应用程序开发,而依赖注入的ILogger接口则更适合于现代应用程序开发,特别是那些需要高度可配置和可扩展的日志记录系统‌

END..........

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaWeb美食推荐管理系统

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 spring-mybatis.xml3.5 spring-mvc.xml3.5 login.jsp 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍&#xff1a;CSDN认证博客专家&#xff0c;CSDN平台Java领域优…

OceanBase技术解析:自适应分布式下压技术

在《OceanBase 数据库源码解析》这本书中&#xff0c;关于SQL执行器的深入剖析相对较少&#xff0c;因此&#xff0c;希望增添一些实用且详尽的补充内容。 上一篇博客《 OceanBase技术解析&#xff1a; 执行器中的自适应技术》中&#xff0c;已初步介绍了执行器中几项典型的自适…

HarmonyOS异常处理实践

一、HarmonyOS应用异常处理框架 全面检测、精准记录异常传播路径、日志精简 二、FaultLog FaultLog是应用异常日志查询接口&#xff0c;提供QuerySelfFaultLog接口以查询自身故障。 JS_CRASH&#xff1a;ArkTS程序故障类型 CPP_CRASH&#xff1a;C程序故障类型 APP_FREEZE&…

csv导入导出

一、csv 1、介绍 CSV&#xff08;Comma-Separated Values&#xff0c;逗号分隔的值&#xff09;是一种简单、实用的文件格式&#xff0c;用于存储和表示包括文本、数值等各种类型的数据。CSV 文件通常以 .csv 作为文件扩展名。这种文件格式的一个显著特点是&#xff1a;文件内…

JavaSE——Arrays类、System类

目录 一、Arrays类 1.Arrays.toString() 2.Arrays.sort() 3.Arrays实现冒泡排序的定制排序 4.Arrays.binarySearch()——二叉查找 5.Arrays.copyOf()——数组元素的复制 6.Arrays.fill()——数组的填充 7.Arrays.equals(arr1,arr2)——比较2个数组元素内容是否完全一致…

java中的ArrayList和LinkedList的底层剖析

引入: 数据结构的分类&#xff0c;数据结构可以分成&#xff1a;线性表&#xff0c;树形结构&#xff0c;图形结构。 线性结构(线性表)包括:数组、链表、栈队列 树形结构:二叉树、AVL树、红黑树、B树、堆、Trie、哈夫曼树、并查集 图形结构:邻接矩阵、邻接表 线性表是具有存…

通信工程学习:什么是TDD时分双工

TDD:时分双工 TDD(时分双工,Time Division Duplexing)是一种在移动通信系统中广泛使用的全双工通信技术。以下是TDD的详细解释: 一、定义与原理 TDD是一种通过时间划分来实现双向通信的技术。在TDD模式中,接收和传送在同一频率信道(即载波)的不同时隙…

新品上市!智能无线接入型路由器ZX7981EP,WIFI6技术双频频段

在这个快节奏的时代 每一次点击都渴望即刻响应&#xff0c;每一份数据都期待安全传输 我们希望大家都能享有顶尖的网络体验&#xff0c;由此 启明智显ZX7891EP智能无线接入型路由器新品上市&#xff01; 2.4G/5G双频段&#xff0c;WAN口/LAN口皆齐全 最新802.1ax WiFi6技术…

【Linux】Linux工具——CMake入门

目录 1.什么是CMake 2.CMakeflie的安装和版本的查看 3.几个简单示例 3.1.编译一个.cc文件 3.2.编译一个.hpp文件和一个.cc文件 3.3.编译一个.hpp文件和两个.cc文件 3.4.编译两个.hpp文件和一个.cc文件 4.CMakeLists.txt 4.1.CMakeLists.txt常用的几条指令 4.2.变量和…

软件测试之单元测试/系统测试/集成测试详解

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、单元测试的概念 单元测试是对软件基本组成单元进行的测试&#xff0c;如函数或一个类的方法。当然这里的基本单元不仅仅指的是一个函数或者方法&#xff0…

基于densenet模型在RML201610a数据集上的调制识别【代码+数据集+python环境+GUI系统】

基于densenet模型在RML201610a数据集上的调制识别【代码数据集python环境GUI系统】 Loss曲线 背景意义 随着社会的快速发展&#xff0c;人们在通信方面的需求逐渐增加&#xff0c;特别是在无线通信领域。通信环境的复杂化催生了多种通信形式和相关应用&#xff0c;这使得调制…

最新版无忧二级域名分发源码,支持包月续费

目前版本支持&#xff0c;开通会员&#xff0c;会员组可以解析哪些域名 比如 用普通域名引流&#xff0c;免费使用&#xff0c;就可以注册就是普通用户组 会员组可以设置价格比如10块钱买永久会员&#xff0c;没有别的特权&#xff0c;只是会员才可以租备案域名&#xff0c; 设…

有源蜂鸣器(5V STM32)

目录 一、介绍 二、模块原理 1.有/无源蜂鸣器介绍 2.原理图 3.引脚描述 三、程序设计 main.c文件 beep.h文件 beep.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 蜂鸣器是一种能将音频信号转化声音信号的发音器件&#xff0c;在家电器上&#xff0c;在银行…

直播 SDK

直播 SDK 是音视频终端 SDK&#xff08;腾讯云视立方&#xff09;针对移动直播场景专属打造的一体化产品&#xff0c;支持直播推拉流、主播观众互动连麦、主播跨房 PK 等能力&#xff0c;为用户提供高质量直播服务&#xff0c;快速满足手机直播的需求。更多关于直播 SDK 的文档…

Ubuntu 22.04无法连接网络(网络图标丢失)解决方案

对于Ubuntu 22.04而言&#xff1a; sudo service NetworkManager stop sudo rm /var/lib/NetworkManager/NetworkManager.state sudo service NetworkManager start

嵌入式项目:STM32平衡车详解 (基础知识篇) (基于STM32F103C8T6)

前言&#xff1a; 本文是基于B站草履虫编写的平衡车相关内容&#xff0c;包括模块和基础知识&#xff0c;结合代码进行讲解&#xff0c;将知识进行汇总 &#xff08;由于本篇内容较长&#xff0c;请结合目录使用) 注&#xff1a;基于开源精神&#xff0c;本文仅供学习参考 目…

基于Node.js+Express+MySQL+VUE实现的计算机毕业设计旅游推荐网站

猜你喜欢评论 登录注册搜索 推荐定制景点/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序 功能图如下所示&#xff1a; 一、设计目标 本次计算机毕业设计项目的主要目标是设计和开发一款功能完善、用户友好的旅游推荐网站。该网站旨在为广大旅游爱好者提供一个便捷、…

蓝桥杯--STM32G431RBT6(TIM定时器的输出频率和占空比,含详细原理介绍和使用方法)

目录 一、前言 二、代码 实现功能&#xff1a;​编辑 按如图配置 定义变量 编写执行代码 显示在LCD上 加入按键效果 三、效果展示 四、代码开源 一、前言 ARR 即自动重装载值&#xff08;Auto Reload Register&#xff09;。相当于一个水杯&#xff0c;水杯容量&am…

sqlserver迁移数据库文件存储位置

业务背景&#xff1a;由于C盘爆满&#xff0c;需要将数据库文件迁移到别处比如D盘 下面以某一个数据库转移为示例&#xff1a;&#xff08;可以用SSMS工具&#xff0c;新建查询配合使用&#xff09; 1.查询数据库文件存储路径 sql语句&#xff1a; -- 查询路径 USE QiangTes…

[Redis][哨兵][上]详细讲解

目录 0.前言1.基本概念1.相关名词解释2.主从复制的问题3.人工恢复主节点故障4.哨兵自动恢复主节点故障 0.前言 说明&#xff1a;该章节相关操作不需要记忆&#xff0c;理解流程和原理即可&#xff0c;用的时候能自主查到即可Redis的主从复制模式下&#xff0c;⼀旦主节点由于故…