当前位置: 首页 > news >正文

MySQL六大日志的功能介绍。

前言

首先,MySQL的日志应该包括二进制日志(Binary Log)、错误日志(Error Log)、查询日志(General Query Log)、慢查询日志(Slow Query Log)、重做日志(Redo Log)和回滚日志(Undo Log)。不过我不确定是否这六个是正确的,或者有没有遗漏或者不同的分类方式。

  1. 二进制日志(Binary Log):这个我记得是用来记录所有对数据库的更改操作的,比如INSERT、UPDATE、DELETE等,主要用于主从复制(Replication)和某些数据恢复场景。二进制日志是逻辑日志,记录的是SQL语句或者行的变更。不过具体细节可能要看不同的格式设置,比如statement、row或者mixed模式。

  2. 错误日志(Error Log):这个应该记录MySQL运行过程中出现的错误信息,比如启动、关闭过程中的问题,或者运行时的严重错误。比如当MySQL无法启动时,查看错误日志就能找到原因。

  3. 查询日志(General Query Log):这个日志会记录所有的客户端连接和执行的SQL语句,不管是SELECT还是其他操作。不过开启这个日志可能会对性能有影响,因为所有查询都会被记录,所以在生产环境中可能不会一直开启。

  4. 慢查询日志(Slow Query Log):这个记录执行时间超过设定阈值的查询,以及可能没有使用索引的查询。这个日志对优化数据库性能很有帮助,可以通过分析慢查询日志找到需要优化的SQL语句。

  5. 重做日志(Redo Log):这个是InnoDB存储引擎特有的日志,用于事务的持久性。当发生系统崩溃时,可以通过重做日志来恢复未写入数据文件的事务操作。重做日志是物理日志,记录的是数据页的修改。

  6. 回滚日志(Undo Log):同样属于InnoDB,用于事务的回滚和MVCC(多版本并发控制)。当事务需要回滚时,Undo Log可以恢复到事务开始前的状态。同时,在MVCC中,其他事务可能需要读取旧版本的数据,这时Undo Log提供了所需的历史版本。

  • 二进制日志:记录所有数据变更操作,用于主从复制和数据恢复。可以用于时间点恢复(PITR),将数据库恢复到某个特定时间点的状态。此外,二进制日志还支持多种格式,比如基于语句(statement)、基于行(row)或者混合模式(mixed)。

  • 错误日志:记录MySQL服务启动、运行、停止时的错误信息,警告信息,或者其他诊断信息。比如,当数据库无法启动时,查看错误日志可以找到具体的错误原因,如配置错误、端口被占用等。

  • 查询日志:记录所有连接到MySQL服务器的客户端请求和执行的SQL语句。这个日志对于审计和调试非常有用,但因为记录所有操作,可能会占用大量磁盘空间,影响性能,所以通常只在需要调试的时候开启。

  • 慢查询日志:记录执行时间超过long_query_time参数设置的阈值,或者没有使用索引的查询语句。帮助DBA优化数据库性能,通过分析这些慢查询,可以找出需要优化的SQL语句或者索引缺失的情况。

  • 重做日志(Redo Log):InnoDB引擎使用,保证事务的持久性。在事务提交时,先将变更写入重做日志,然后再慢慢刷新到磁盘的数据文件中。当系统崩溃时,通过重做日志可以恢复那些已经提交但尚未写入数据文件的事务,确保数据不丢失。重做日志是循环写入的,有固定的大小。

  • 回滚日志(Undo Log):同样由InnoDB引擎管理,用于事务回滚和MVCC。当事务需要回滚时,利用Undo Log中的信息撤销已经执行的操作。此外,在并发事务中,当其他事务需要读取数据的历史版本时,Undo Log提供旧版本的数据,从而实现一致性读。

不过,有没有可能混淆了重做日志和二进制日志?比如,二进制日志是服务器层的,而重做日志是存储引擎层的。它们的用途不同,二进制日志用于复制和恢复,而重做日志用于崩溃恢复。

另外,事务的ACID特性中,持久性(Durability)是通过重做日志来保证的,原子性(Atomicity)是通过回滚日志实现的。隔离性(Isolation)则通过锁和MVCC来实现,其中MVCC又依赖Undo Log,通常情况下,日志之间是相互作用的,以保证数据库的并发数据的可靠性问题。

所以,这六大日志各自在数据库的不同方面发挥作用,比如数据恢复、性能优化、错误诊断、事务处理等。理解每个日志的作用,有助于在运维和开发过程中更好地利用这些日志解决问题。

MySQL的六大日志在数据库的运行、维护和优化中扮演着关键角色。以下是它们的详细功能介绍:


1. 二进制日志(Binary Log)

  • 功能
    • 主从复制:记录所有对数据库的更改操作(如INSERT、UPDATE、DELETE),从库通过重放这些操作实现数据同步。
    • 数据恢复:支持时间点恢复(PITR),可将数据库恢复到特定时间点的状态。
    • 审计:追踪数据变更历史,用于安全审计。
  • 日志格式
    • Statement-Based:记录SQL语句(节省空间,但可能因函数调用导致主从不一致)。
    • Row-Based:记录行级别的变更(安全,但日志量大)。
    • Mixed:混合模式,自动选择最优方式。
  • 配置参数
    [mysqld]
    log_bin = /var/lib/mysql/mysql-bin  # 启用二进制日志
    binlog_format = ROW                 # 设置日志格式
    

2. 错误日志(Error Log)

  • 功能
    • 错误诊断:记录MySQL启动、运行、关闭过程中的错误和警告信息。
    • 运维监控:帮助快速定位服务异常(如权限问题、端口冲突、存储引擎崩溃等)。
  • 默认路径
    • Linux:/var/log/mysql/error.log
    • Windows:C:\ProgramData\MySQL\MySQL Server 8.0\Data\<hostname>.err
  • 配置参数
    [mysqld]
    log_error = /var/log/mysql/error.log  # 指定错误日志路径
    

3. 查询日志(General Query Log)

  • 功能
    • 全量SQL记录:记录所有客户端连接和执行的SQL语句(包括SELECT、CONNECT等)。
    • 调试与审计:用于分析应用行为或排查异常请求。
  • 注意:开启后可能显著增加磁盘I/O和空间占用。
  • 配置参数
    [mysqld]
    general_log = ON                     # 启用查询日志
    general_log_file = /var/log/mysql/query.log
    

4. 慢查询日志(Slow Query Log)

  • 功能
    • 性能优化:记录执行时间超过阈值(默认10秒)或未使用索引的SQL。
    • 索引分析:通过日志发现缺失索引或低效查询。
  • 配置参数
    [mysqld]
    slow_query_log = ON                  # 启用慢查询日志
    slow_query_log_file = /var/log/mysql/slow.log
    long_query_time = 2                  # 超过2秒的查询视为慢查询
    log_queries_not_using_indexes = ON   # 记录未使用索引的查询
    

5. 重做日志(Redo Log)

  • 功能
    • 崩溃恢复:确保事务的持久性(Durability),在系统崩溃后通过重做日志恢复已提交但未写入磁盘的事务。
    • 物理日志:记录数据页的物理修改(如页号、偏移量、修改内容)。
  • 结构
    • 日志文件组:通常由ib_logfile0ib_logfile1组成,循环写入。
    • Write-Ahead Logging (WAL):事务提交前必须将日志写入磁盘。
  • 配置参数
    [mysqld]
    innodb_log_file_size = 512M    # 单个重做日志文件大小
    innodb_log_files_in_group = 2  # 日志文件数量
    

6. 回滚日志(Undo Log)

  • 功能
    • 事务回滚:保存事务修改前的旧值,支持事务的原子性(Atomicity)。
    • MVCC实现:为其他事务提供数据的历史版本,实现一致性非锁定读(Read View)。
  • 存储位置:默认在系统表空间(ibdata1)或独立Undo表空间。
  • 配置参数
    [mysqld]
    innodb_undo_directory = /var/lib/mysql/undo  # Undo日志路径
    innodb_undo_tablespaces = 2                  # Undo表空间数量
    

对比总结

日志类型存储引擎主要功能数据级别
二进制日志MySQL Server主从复制、时间点恢复逻辑日志(SQL/行)
错误日志MySQL Server错误诊断与监控文本日志
查询日志MySQL Server全量SQL审计与调试文本日志
慢查询日志MySQL Server性能优化与索引分析文本日志
重做日志InnoDB崩溃恢复、事务持久性物理日志(数据页)
回滚日志InnoDB事务回滚、MVCC支持逻辑日志(旧数据)

应用场景示例

  • 主从同步异常:检查二进制日志是否正常生成及传输。
  • 数据库崩溃恢复:依赖重做日志恢复未落盘的事务。
  • 性能调优:分析慢查询日志优化SQL和索引。
  • 事务回滚:通过Undo Log撤销未提交的事务操作。

理解这些日志的作用和配置方式,有助于高效运维MySQL数据库,保障数据安全与系统稳定。

结束语

本篇是一个总结性的文章,后面会详细分析二进制日志、重做日志以及回滚日志以及MVCC的原理。

相关文章:

MySQL六大日志的功能介绍。

前言 首先&#xff0c;MySQL的日志应该包括二进制日志&#xff08;Binary Log&#xff09;、错误日志&#xff08;Error Log&#xff09;、查询日志&#xff08;General Query Log&#xff09;、慢查询日志&#xff08;Slow Query Log&#xff09;、重做日志&#xff08;Redo …...

ChatGPT客户端无法在微软应用商店下载的解决方法

最近网页端的GPT4o只会用how can I assist you 回复了&#xff0c;查了一下发现是类似IP封锁/模型降级等等问题&#xff0c;总之解决方法就是下载客户端。客户端需要通过微软应用商店下载&#xff0c;但是下载时总会出现如下情况&#xff1a; 1.区域和语言没有设置为美国/英语导…...

数仓搭建(hive):DWS层(服务数据层)

DWS层示例: 搭建日主题宽表 需求 维度 步骤 在hive中建数据库dws >>建表 CREATE DATABASE if NOT EXISTS DWS; 建表sql CREATE TABLE yp_dws.dws_sale_daycount( --维度 city_id string COMMENT 城市id, city_name string COMMENT 城市name, trade_area_id string COMME…...

Ollama+DeepSeek+Open-WebUi

环境准备 Docker Ollama Open-WebUi Ollama 下载地址&#xff1a;Ollama docker安装ollama docker run -d \ -v /data/ollama/data:/root/.ollama \ -p 11434:11434 \ --name ollama ollama/ollama 下载模型 Ollama模型仓库 # 示例&#xff1a;安装deepseek-r1:7b doc…...

【笔记】LLM|Ubuntu22服务器极简本地部署DeepSeek+联网使用方式

2025/02/18说明&#xff1a;2月18日~2月20日是2024年度博客之星投票时间&#xff0c;走过路过可以帮忙点点投票吗&#xff1f;我想要前一百的实体证书&#xff0c;经过我严密的计算只要再拿到60票就稳了。一人可能会有多票&#xff0c;Thanks♪(&#xff65;ω&#xff65;)&am…...

FreeSwitch中mod_dptools和mod_easyroute两个模块及应用场景

FreeSWITCH 中的 mod_dptools 和 mod_easyroute 是两个功能不同的模块&#xff0c;分别服务于呼叫控制和动态路由场景。以下是详细介绍&#xff1a; mod_dptools 功能概述 mod_dptools&#xff08;Dialplan Tools&#xff09;是 FreeSWITCH 最核心的模块之一&#xff0c;提供了…...

【Java】泛型与集合篇 —— Set 接口

目录 Set 接口及实现类HashSet 类特点内部实现构造方法LinkedHashSet 类基本概念特点构造方法常用方法适用场景用 Set 对象实现集合运算TreeSet 类特性构造方法常用方法注意事项对象顺序自然排序定制排序注意事项Set 接口及实现类 HashSet 类 HashSet 是 Java 集合框架中 Set…...

DeepSeek 助力 Vue 开发:打造丝滑的右键菜单(RightClickMenu)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…...

数据结构与算法面试专题——堆排序

完全二叉树 完全二叉树中如果每棵子树的最大值都在顶部就是大根堆 完全二叉树中如果每棵子树的最小值都在顶部就是小根堆 设计目标&#xff1a;完全二叉树的设计目标是高效地利用存储空间&#xff0c;同时便于进行层次遍历和数组存储。它的结构使得每个节点的子节点都可以通过简…...

【Mysql】索引

【Mysql】索引 一、索引的简介二、索引结构2.1 Hash2.2 二叉搜索树2.3 B树2.4 B树 三、索引分类3.1 主键索引3.2 普通索引3.3 唯一索引3.4 全文索引3.5 聚集索引3.6 非聚集索引3.7 索引覆盖 四、使用索引4.1 自动创建索引4.2 手动创建索引4.2.1 主键索引4.2.2 唯一索引4.2.3 普…...

qt的下载安装详细介绍

下载 我们可以在国内的镜像网站上下载qt安装包&#xff0c;按需下载&#xff1a; 我的需求是在windows上运行&#xff0c;x64的qt5.15.2,所以我下载的是qt-unified-windows-x64-4.6.0-online.exe 下载完成之后&#xff0c;我们来到存放该exe文件的目录&#xff0c;打开命令窗…...

Eclipse插件开发六:使用Web前端技术开发AI助手页面

之前的过程中&#xff0c;我们都不怎么熟悉Eclipse的哪些API&#xff0c;样式也没发怎么去修改&#xff0c;现在我们要修改为用html的方式来编写. 准备一个AI助手聊天页面的html.css,js代码 效果如下所示。 1.快速demo 1.1.准备前端代码 确保准备的前端代码可以在浏览器正常…...

Jackson使用

Jackson 是一个功能强大的 JSON 处理库&#xff0c;除了基本的序列化和反序列化功能外&#xff0c;它还提供了许多其他功能&#xff0c;以满足不同的需求。以下是一些常用的高级功能&#xff1a; 0.普通序列化反序列化 序列化 import com.fasterxml.jackson.databind.ObjectM…...

Maven——Maven开发经验总结(1)

摘要 本文总结了 Maven 开发中的多个关键经验&#xff0c;包括如何根据版本号决定推送到 releases 或 snapshots 仓库&#xff0c;如何在构建过程中跳过测试&#xff0c;父项目如何控制子项目依赖版本&#xff0c;父项目依赖是否能传递到子项目&#xff0c;如何跳过 Maven dep…...

MyBatis-Plus之通用枚举

MyBatis-Plus之通用枚举 前言 MyBatis-Plus中提供了通用枚举&#xff0c;简单来说就是将数据库中的某一字段的代替的含义转换成真实的含义将数据展示给用户&#xff0c;用户在存储时也会将真实值转换成代替的数字存入到数据库中。举个例子&#xff1a;用户性别在数据库中存储…...

React通用登录/注销功能实现方案(基于shadcn/ui)

React通用登录/注销功能实现方案&#xff08;基于shadcn/ui&#xff09; 一、功能需求分析二、通用功能封装1. 通用登录表单组件2. 认证Hook封装 三、功能使用示例1. 登录页面实现2. 用户菜单实现 四、路由保护实现五、方案优势 一、功能需求分析 需要实现以下核心功能&#x…...

AI工具篇:利用DeepSeek+Kimi 辅助生成综述汇报PPT

随着科研和学术报告需求的增加&#xff0c;如何高效地准备一份结构清晰、内容充实的PPT已成为许多研究者的挑战。 传统的PPT制作过程繁琐&#xff0c;需要大量文献收集、数据分析和设计工作&#xff0c;而AI工具能够帮助提升效率&#xff0c;减少重复劳动。 本文将介绍如何使用…...

审计级别未启用扩展模式导致查询 DBA_AUDIT_TRAIL 时 SQL_TEXT 列为空

如果查询 DBA_AUDIT_TRAIL 时发现 SQL_TEXT 列为空&#xff0c;但其他字段&#xff08;如 OS_USERNAME、USERNAME、TIMESTAMP 等&#xff09;有数据&#xff0c;可能是由于以下原因之一。以下是可能的原因及解决方法&#xff1a; 1. 审计级别未启用扩展模式 默认情况下&#x…...

HTTP 和RESTful API 基础,答疑

一文搞懂RESTful API - bigsai - 博客园 1. API 路径 开头必须 /&#xff0c;表示绝对路径&#xff0c;不支持 . 或 ..&#xff08;相对路径&#xff09;。API 结尾 / 通常不需要&#xff0c;但部分框架会自动处理 / → 无 /。 ✅ 推荐 GET /api/v1/products # 资源集合…...

手写简易RPC(实践版)

首先了解rpc rpc-远程过程调用&#xff0c;openFeign&#xff0c;Dubbo都可以算作rpc&#xff0c;以微服务来具体说明&#xff0c;就是在本地不需要去发送请求&#xff0c;通过rpc框架&#xff0c;像调用本地方法一样调用其他服务的方法&#xff0c;本质上还是要经过网络&…...

Day6 25/2/19 WED

【一周刷爆LeetCode&#xff0c;算法大神左神&#xff08;左程云&#xff09;耗时100天打造算法与数据结构基础到高级全家桶教程&#xff0c;直击BTAJ等一线大厂必问算法面试题真题详解&#xff08;马士兵&#xff09;】https://www.bilibili.com/video/BV13g41157hK?p4&v…...

【DL】浅谈深度学习中的知识蒸馏 | 输出层知识蒸馏

目录 一 核心概念与背景 二 输出层知识蒸馏 1 教师模型训练 2 软标签生成&#xff08;Soft Targets&#xff09; 3 学生模型训练 三 扩展 1 有效性分析 2 关键影响因素 3 变体 一 核心概念与背景 知识蒸馏&#xff08;Knowledge Distillation, KD&#xff09;是一种模…...

机器学习PCA和LDA

主成分分析&#xff08;PCA, Principal Component Analysis&#xff09;和线性判别分析&#xff08;LDA, Linear Discriminant Analysis&#xff09;是两种常用的降维方法&#xff0c;它们虽然都用于数据降维&#xff0c;但核心思想和应用场景不同。 PCA&#xff08;主成分分析…...

tcp协议连接,和传输数据

1、连接 这个是通用的 2、传送数据 当连接建立后&#xff0c;客户端和服务器都可以主动发送数据&#xff0c;分别如下 1》客户端先发送数据 这里是单向的&#xff0c;服务器没有对客户端的数据内容进行应答&#xff0c;只是单纯的对报文应答ack 2》服务器先发送数据...

【异常错误】pycharm debug view变量的时候显示不全,中间会以...显示

异常问题&#xff1a; 这个是在新版的pycharm中出现的&#xff0c;出现的问题&#xff0c;点击view后不全部显示&#xff0c;而是以...折叠显示 在setting中这么设置一下就好了&#xff1a; 解决办法&#xff1a; https://youtrack.jetbrains.com/issue/PY-75568/Large-stri…...

Java基础——代理模式

代理模式是一种比较好理解的设计模式。简单来说就是 我们使用代理对象来代替对真实对象(real object)的访问&#xff0c;这样就可以在不修改原目标对象的前提下&#xff0c;提供额外的功能操作&#xff0c;扩展目标对象的功能。 一、代理模式的主要作用 控制访问&#xff1a;通…...

解锁机器学习核心算法|主成分分析(PCA):降维的魔法棒

一、引言 在机器学习的庞大算法体系中&#xff0c;有十种算法被广泛认为是最具代表性和实用性的&#xff0c;它们犹如机器学习领域的 “十大神器”&#xff0c;各自发挥着独特的作用。这十大算法包括线性回归、逻辑回归、决策树、随机森林、K - 近邻算法、K - 平均算法、支持向…...

sql注入漏洞

目录 一、SQL注入概述 例子背景 正常情况下的查询 SQL注入攻击 利用优先级进行攻击 二、解决SQL注入 使用PreparedStatement接口 步骤和方法 1. 创建PreparedStatement对象 2. 向占位符传入值 3. 执行SQL语句 示例 总结 SQL 注入是一种常见的网络攻击手段。通俗来…...

spring微服务+dubbo框架,某一服务启动时提示多个bean存在

在java的springboot项目中使用DubboService的注解的实现类中&#xff0c;在引用本模块的类时&#xff0c;使用的DubboRefrence注解&#xff0c;在启动项目时报错&#xff0c;提示该类需要以一个bean对象&#xff0c;但是存在了两个&#xff0c;把DubboRefrence的注解改成Autowi…...

React useState 和 useEffect 使用坑点注意总结

React Hooks 使用注意事项 Area: Hooks Date: February 10, 2025 Important: &#x1f31f;&#x1f31f;&#x1f31f; React Hooks 注意事项 要点&#xff1a; useState 的初始化值 只在第一次渲染时计算&#xff0c;并且这个值不会随着组件重新渲染而更新。useEffect 可…...

使用rknn进行yolo11-pose部署

文章目录 概要生成ONNX生成RKNN实测效果概要 使用 RKNN 进行 YOLOv11 Pose 部署的必要性在于,RKNN 能将 YOLOv11 Pose 模型转化为适合 Rockchip 硬件平台(如 RV1109、RV1126)执行的格式,充分利用其 AI 加速功能,显著提高推理速度和效率。此外,RKNN 提供模型优化(如量化…...

开源语音克隆项目 OpenVoice V2 本地部署

#本机环境 WIN11 I5 GPU 4060ti 16G 内存 32G #开始 git clone https://github.com/myshell-ai/OpenVoice.git conda create -n opvenv python3.9 -y conda activate opvenv pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/…...

YOLOv12从入门到入土(含结构图)

论文链接&#xff1a;https://arxiv.org/abs/2502.12524 代码链接&#xff1a;https://github.com/sunsmarterjie/yolov12 文章摘要&#xff1a; 长期以来&#xff0c;增强YOLO框架的网络架构一直至关重要&#xff0c;但一直专注于基于cnn的改进&#xff0c;尽管注意力机制在建…...

8.【线性代数】——求解Ax=b

八 求解Axb 1. 解Axb求特解 x p x_p xp​求特解 x n x_n xn​所有解 2. Axb什么时候有解3. A m ∗ n A_{m * n} Am∗n​不同秩的Axb解分析3.1 列满秩 rn<m3.2 行满秩 rm<n3.3 rmn3.4 r<m 且 r < n3.5 综述 1. 解Axb 求解 { x 1 2 x 2 2 x 3 2 x 4 b 1 2 x 1…...

【Quest开发】全身跟踪

软件&#xff1a;Unity 2022.3.51f1c1、vscode、Meta XR All in One SDK V72 硬件&#xff1a;Meta Quest3 最终效果&#xff1a;能像meta的操作室沉浸场景一样根据头盔移动来推断用户姿势&#xff0c;实现走路、蹲下、手势匹配等功能 需要借助UnityMovement这个包 GitHub …...

Spring Boot 示例项目:从零开始构建 Web 应用

一、项目概述 本文档将指导您通过一个示例项目,了解如何使用 Spring Boot 框架构建一个简单的 Web 应用程序。该项目涵盖了从数据模型定义到控制器、服务层以及数据访问层的完整开发流程,帮助您快速掌握 Spring Boot 的基本使用方法。 二、项目结构 1. 项目模块 本示例项…...

Windows 启动 SSH 服务报错 1067

Windows 启动 SSH 服务报错 1067 一、原本安装的 Windows 自带的 SSH 服务 按 Windows 键 -> 设置 -> 系统 -> 可选功能 在 添加的功能 查看是否安装了 OpenSSH 服务 一开始 执行 net start sshd 是可以正常启动的 并且其他机器也可以通过 ssh 访问 这个电脑 但是有…...

【AI战略思考15】我对做自媒体视频博主的初步探索和一些思考

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】【读书与思考】【AI应用】 导言 因为自己找工作可能没那么快和顺利&#xff0c;事实是比我之前想象的要难很多&#xff0c;所以这几天探索了下自己能否尝试做自媒体或者视频博主来尝试赚点钱&#xff0c;如果做…...

零基础学QT、C++(一)安装QT

目录 如何快速学习QT、C呢&#xff1f; 一、编译器、项目构建工具 1、编译器&#xff08;介绍2款&#xff09; 2、项目构建工具 二、安装QT 1、下载QT安装包 2、运行安装包 3、运行QT creator 4、导入开源项目 总结 闲谈 如何快速学习QT、C呢&#xff1f; 那就是项目驱动法&…...

Word接入DeepSeek(API的作用)

1.打开”Word”&#xff0c;点击“文件”。 2.点击“选项”。 3.点击“信任中心”——“信任中心设置”。 4. 勾选”启用所有宏“&#xff0c;点击”确定“。 5.点击“自定义功能区”&#xff0c;勾选上“开发工具”&#xff0c;点击“确定”。 6.返回“文件——开发工具“下的…...

ok113i——交叉编译音视频动态库

提示&#xff1a;buildroot支持ffmpeg和SDL&#xff0c;但博主的ffmpeg是按下面方法编译通过&#xff0c;SDL使用buildroot直接编译也通过&#xff1b; 1. 下载ffmpeg源码 下载链接&#xff1a;https://github.com/FFmpeg/FFmpeg/tags 根据版本需要自行下载压缩包&#xff0c…...

CSS中五种定位方式(position)对比分析

在 CSS 中&#xff0c;定位方式&#xff08;position&#xff09;决定了元素如何相对于其参照物进行定位&#xff0c;同时影响文档流的布局。以下是五种定位方式的对比、参照物说明及代码示例&#xff1a; 1. position: static&#xff08;默认定位&#xff09; 参照物&#x…...

Jest单元测试

由于格式和图片解析问题&#xff0c;可前往 阅读原文 前端自动化测试在提高代码质量、减少错误、提高团队协作和加速交付流程方面发挥着重要作用。它是现代软件开发中不可或缺的一部分&#xff0c;可以帮助开发团队构建可靠、高质量的应用程序 单元测试&#xff08;Unit Testi…...

Lineageos 22.1(Android 15) 开机向导制作

一、前言 开机向导原理其实就是将特定的category的Activity加入ComponentResolver&#xff0c;如下 <category android:name"android.intent.category.SETUP_WIZARD"/>然后我们开机启动的时候&#xff0c;FallbackHome结束&#xff0c;然后启动Launcher的时候…...

前沿计组知识入门

这份PDF文件是一份关于计算机体系结构的讲义&#xff0c;涵盖了从基础概念到高级主题的多个方面。以下是详细的总结和分析&#xff1a; 计算机体系结构概述 定义&#xff1a;计算机体系结构是计算机系统的理论组成部分&#xff0c;根据其属性和功能进行划分&#xff0c;包括计…...

力扣 最长递增子序列

动态规划&#xff0c;二分查找。 题目 由题&#xff0c;从数组中找一个最长子序列&#xff0c;不难想到&#xff0c;当这个子序列递增子序列的数越接近时是越容易拉长的。从dp上看&#xff0c;当遍历到这个数&#xff0c;会从前面的dp选一个最大的数加上当前数&#xff0c;注意…...

在项目中调用本地Deepseek(接入本地Deepseek)

前言 之前发表的文章已经讲了如何本地部署Deepseek模型&#xff0c;并且如何给Deepseek模型投喂数据、搭建本地知识库&#xff0c;但大部分人不知道怎么应用&#xff0c;让自己的项目接入AI模型。 文末有彩蛋哦&#xff01;&#xff01;&#xff01; 要接入本地部署的deepsee…...

已解决IDEA无法输入中文问题(亲测有效)

前言 在使用IDEA的时候&#xff0c;比如我们想写个注释&#xff0c;可能不经意间&#xff0c;输入法就无法输入中文了&#xff0c;但是在其他地方打字&#xff0c;输入法仍然能够正常工作。这是什么原因呢&#xff0c;这篇文章带你解决这个问题&#xff01; 快捷键 如果你的I…...

Java 语法新特性(Records、Pattern Matching、Sealed Classes)深度解析(11/17/21)✨

一、Records&#xff08;Java 16&#xff09; &#x1f4dd; 核心价值&#xff1a;简化不可变数据载体的定义 // 传统POJO vs Record public record User(String name, int age) {} // 自动生成&#xff1a;构造方法/equals()/hashCode()/toString() User user new User(&qu…...

书评与笔记:《如何有效报告Bug》

文章目录 书评笔记核心原则1. 首要目标&#xff1a;让程序员亲眼看到问题2. 次要目标&#xff1a;详细描述问题3. 保持冷静&#xff0c;避免误操作4. 提供额外信息5. 清晰、准确地表达 实用建议不要自作聪明地诊断问题类比&#xff1a;看医生时的症状描述程序员的心理 总结 原文…...