MySQL误删数据急救指南:基于Binlog日志的实战恢复详解
背景
数据误删是一个比较严重的场景
1.典型误操作场景
场景1:DELETE FROM orders WHERE status=0 → 漏写AND create_time>=‘2025-06-20’
场景2:DROP TABLE customer → 误执行于生产环境
认识 binlog
1.binlog 的核心作用
- 记录所有 DDL/DML 操作(不含 SELECT)
- ROW格式binlog记录数据行的完整镜像(例:DELETE操作保存被删行的所有字段值)
2.三种格式对比
- ROW格式:可解析具体数据变更(如DELETE的行数据),是数据恢复的前提。
- STATEMENT格式:仅记录SQL语句(如DELETE FROM user),无法还原误删的具体数据。
- MIXED格式:混合模式,可能无法保证所有操作记录完整数据3。
3.binlog恢复原理与前提条件
binlog为什么能恢复数据?
- ROW格式记录物理变更:保存每行数据的修改前/后镜像(DELETE记录完整被删行数据)。
- 事务连续性:通过start position和end position精准定位事务边界。
- 与Undo Log的区别:binlog持久化到磁盘,不受事务提交影响。
4.无法恢复的场景
- binlog未开启或格式为STATEMENT(仅记录SQL语句,无原始数据)
- TRUNCATE TABLE操作(直接清空物理文件,不记录行数据)
- binlog已被自动清理(expire_logs_days过期)或手动PURGE
- 大事务未提交时服务器崩溃(事务不完整)
- …
5.如何开启 binlog
- 修改 my.cnf 配置(代码示例):
[mysqld]
server_id=1
log_bin=mysql-bin
binlog_format=ROW # 必须为ROW格式才能解析具体数据
expire_logs_days=7 # 自动清理周期
- 验证是否开启:
SHOW VARIABLES LIKE '%log_bin%';
恢复步骤
1. 确定操作时间与特征
-
通过业务日志/监控系统确认误删时间(如 2025-06-16 18:30:00)
-
提取SQL特征(如 delete from employee_performance where department = ‘研发’)
-
查看最近执行的删除语句(需开启general_log)
SELECT * FROM mysql.general_log
WHERE argument LIKE '%DELETE FROM your_table%'
ORDER BY event_time DESC LIMIT 1;
2. 列出时间范围内的所有binlog文件
# Linux/Mac(需替换实际路径)
ls -l /var/lib/mysql/mysql-bin.0*
# 解析binlog索引文件(通常为mysql-bin.index )
cat /var/lib/mysql/mysql-bin.index # Windows(PowerShell)
dir
# 解析binlog索引文件(通常为mysql-bin.index )
cat .\mysql-binlog.index# mysql
SHOW BINARY LOGS; -- 列出所有binlog文件
3. 解析binlog找到误操作事件
举例
- 误删表:employee_performance
- 误删表所属库:test_demo
- 误删大致时间段:2025-06-17 23:00:00-2025-06-17 23:30:00
- 误删数据所属binlog文件名称:mysql-binlog.000002 (根据误删时间段推导)
- 误删数据量:124514行(根据delete sql执行结果得出)
从binlog提取SQL
使用mysqlbinlog解析binlog:
# 查找2025-06-18 23:00:00-2025-06-18 23:30:00间的binlog
#并输出到delete_sql.sql
mysqlbinlog --no-defaults --user=root -p -d test_demo --start-datetime="2025-06-17 23:00:00" --stop-datetime="2025-06-17 23:30:00" --base64-output=decode-rows -vv ../data/mysql-binlog.000002 > delete_sql.sql
输出文件内容示例
注意事项:
- –start/stop-datetime(时间范围)依赖系统时钟同步),受服务器时间漂移影响。
- 导出的文件并不一定是一个完整的事务(可能漏掉边界事务
) 观察此批delete from 末尾是否含有commit标志
数据恢复
在上一步我们已经导出了delete_sql.sql文件,接下来需要根据这个文件内容进行
过滤并重建数据
1.数据转换(java)
反转操作逻辑(将DELETE转为INSERT)
转换代码如下:
Path outputPath = Paths.get(outputFilePath);// 步骤一: 读取输入文件的所有行,使用 UTF-8 编码,并替换无法解析的字符。List<String> lines;try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(inputFilePath),StandardCharsets.UTF_8.newDecoder().onMalformedInput(CodingErrorAction.REPLACE).onUnmappableCharacter(CodingErrorAction.REPLACE)))) {lines = reader.lines().collect(Collectors.toList());}// 步骤二、三、四: 过滤并处理有效的 binlog 行记录。List<String> processedLines = lines.stream()// 仅保留以 "### " 开头的行,这些是我们要处理的 binlog DML 语句。.filter(line -> line.startsWith("### "))// 去掉行首的 "### " 标识。.map(line -> line.substring(4))// 使用正则表达式移除从 "/*" 开始到行尾的注释。.map(line -> line.replaceAll("(?s)/\\*.*", ""))// 将 "DELETE FROM" 替换为 "INSERT INTO",为逆向生成 INSERT 语句做准备。.map(line -> line.replace("DELETE FROM", "INSERT INTO")).collect(Collectors.toList());// 步骤五: 将所有处理过的行用换行符连接成一个单独的字符串,并将 "WHERE" 替换为 " VALUES ("。String text = String.join("\n", processedLines);text = text.replace("\nWHERE", " VALUES (");// 步骤六: 移除 binlog 中的字段位置标识,例如 "@1=", "@2=" 等。text = text.replaceAll("@[0-9]+=", "");// 步骤七: 对每一行进行整理,并在行尾添加逗号,为构建 VALUES 子句做准备。text = Stream.of(text.split("\n"))// 移除每行首尾的空白字符。.map(String::trim)// 过滤掉处理后可能产生的空行。.filter(line -> !line.isEmpty())// 如果行尾没有逗号,则添加一个,确保 VALUES 子句中的值都以逗号分隔。.map(line -> line.endsWith(",") ? line : line + ",").collect(Collectors.joining("\n"));// 步骤八: 修正由于前面步骤可能产生的 "VALUES (," 写法,将其规范为 "VALUES ("。text = text.replace("VALUES (,", "VALUES (");// 步骤九: 将多个 INSERT 语句正确地分隔开。将前一个 INSERT 的值与后一个 INSERT 语句用 ");" 连接。text = text.replace(",\nINSERT", ");\nINSERT");// 步骤十: 闭合最后一个 INSERT 语句。如果字符串以逗号结尾,则将其替换为 ");"。if (text.endsWith(",")) {text = text.substring(0, text.length() - 1) + ");";}// 将最终处理好的字符串以 UTF-8 编码写入到指定的输出文件中。Files.write(outputPath, text.getBytes(StandardCharsets.UTF_8));
详细转换代码见此项目(含测试用例)
mysql-binlog2sql
2.数据校验
运行完成后可以看到输入文件已经转换完成
条数也是对的 一条数据10行 1245140/10 = 1245410行和上面的模拟数据一致。
3.数据导入
重新执行转换的sql文件导入即可
SOURCE /tmp/restore.sql;
番外
binlog 文件分割机制
当通过 binlog 恢复误删数据时,binlog 文件的大小限制和跨文件存储问题是影响恢复完整性的关键因素。
文件大小限制
MySQL 默认通过 max_binlog_size 控制单个 binlog 文件大小(默认 1GB)
大事务跨文件存储
若单个事务(如大表 DELETE)产生的日志量超过当前要落入的binlog文件 的max_binlog_size,该事务会跨多个 binlog 文件存储。
示例:一个 5GB 的事务可能分布在 mysql-bin.000001~mysql-bin.000005 中。
文件命名规则
Binlog 按顺序生成:mysql-bin.000001 → mysql-bin.000002 → …
新文件在以下情况创建:
- 当前文件 ≥ max_binlog_size
- 执行 FLUSH LOGS 或重启 MySQL。
确认binlog是否开启(Value=ON)
SHOW VARIABLES LIKE 'log_bin';
查看MySQL的binlog模式是否为ROW
show global variables like "binlog%";
查询ROW格式需为FULL(记录完整行数据)
SHOW VARIABLES LIKE 'binlog_row_image';
检查binlog过期时间(确保日志未被自动清理)MySQL 8.0+默认30天
SHOW VARIABLES LIKE 'binlog_expire_logs_seconds';
常用解析binlog文件参数详解
-no-defaults:
–start-datetime:指定开始时间(过滤早于该时间的日志) 示例: --start-datetime=“2025-06-15 14:00:00”
–stop-datetime: 指定结束时间(过滤晚于该时间的日志) 示例: --stop-datetime=“2025-06-15 15:00:00”
–read-from-remote-server: 从远程MySQL服务器读取binlog(需配合–host)
示例:–read-from-remote-server --host=192.168.1.100
–user --password :指定连接MySQL的用户名和密码(远程解析时必填)示例: --user=root --password=your_password
-base64-output=decode-rows:解析ROW格式数据
-d :指定库
注意事项
时间格式必须精确
日期时间需用引号包裹,格式为 “YYYY-MM-DD HH:MM:SS”(如 “2025-06-15 14:00:00”)。
权限要求
本地解析:需操作系统用户有binlog文件读取权限。
远程解析:MySQL用户需有REPLICATION CLIENT权限[]。
大事务处理
若事务过大导致mysqlbinlog内存溢出,可分段解析
-start/stop-position --start/stop-datetime 区别详解
1. --start/stop-position(物理位置)
原理
直接指向binlog事件的物理存储位置(如 # at 54321),通过解析binlog文件的固定偏移量定位。
特点
✅ 100%精确到具体事务
✅ 不受时间同步问题影响
❌ 需先通过其他方式获取位置号
2. --start/stop-datetime(时间范围)
原理
根据binlog事件头的时间戳字段过滤(如 #250618 10:00:00),依赖系统时钟同步。
特点
✅ 无需提前知道位置号
❌ 最大可能有1秒误差(可能漏掉边界事务)
❌ 受服务器时间漂移影响
相关文章:
MySQL误删数据急救指南:基于Binlog日志的实战恢复详解
背景 数据误删是一个比较严重的场景 1.典型误操作场景 场景1:DELETE FROM orders WHERE status0 → 漏写AND create_time>‘2025-06-20’ 场景2:DROP TABLE customer → 误执行于生产环境 认识 binlog 1.binlog 的核心作用 记录所有 DDL/DML 操…...
API网关Apisix管理接口速查
🧭 管理接口总体分类(基于 REST API) 资源类别接口路径前缀功能说明路由(Routes)/apisix/admin/routes/{id}定义 HTTP 请求的匹配规则及转发目标服务(Services)/apisix/admin/services/{id}封装…...
React 组件通信
父传子 函数式组件 function Footer(props){const [count,setCount] useState(0)const {name,age} propsconst onClick ()>{setCount(count1)}return (<div><button onClick{()>{onClick()}}>点此1</button><div>{count}</div><di…...
Zephyr 电源管理机制深度解析:从 Tickless Idle 到平台 Suspend 实践
本文系统解析 Zephyr 的电源管理机制,包括 Tickless Idle 模式、系统 suspend/resume 生命周期管理、平台级功耗优化 Hook、自定义设备电源域,以及如何结合低功耗 SoC 实现最小化功耗设计。全文超过 5000 字,适合构建对功耗敏感的 IoT、BLE、…...
clickhouse-server连不上clickhouse-keeper的问题记录
背景 想简单部署一个1 shard 2 replica,1keeper的集群。 有两个虚拟机:192.168.1.3,192.168.1.6。 192.168.1.3:部署1个ck,1个keeper 192.168.1.6:部署1个ck 192.168.1.3和192.168.1.6的ck组成1个shar…...
Python 数据分析与可视化 Day 3 - Pandas 数据筛选与排序操作
🎯 今日目标 掌握 DataFrame 的条件筛选(布尔索引)学会多条件筛选、逻辑运算熟练使用排序(sort_values)提升数据组织力结合列选择进行数据提取分析 🧪 一、列选择与基本筛选 ✅ 选择单列 / 多列 df[&quo…...
Android NDK下载链接及配置版本
Android NDK下载链接及配置版本 https://github.com/android/ndk/releases 在build.gralde里面这样配置ndk具体版本号: android {ndkVersion "27.0.12077973" } Android Studio报错:Could not move temporary workspace () to immutable locat…...
Mac Parallels Desktop Kali 2025 代理设置
Mac Parallels Desktop Kali 2025 代理设置 核心步骤: kali设置桥接wifi 查看kali和主机ip 运行命令ifconfig查看kali ip: mac主机ip: kali设置proxy ip填写主机ip,port为主机proxy端口 enjoy...
Python 的内置函数 hash
Python 内建函数列表 > Python 的内置函数 hash Python 的内置函数 hash() 是一个非常有用的工具函数,主要用于获取对象的哈希值。哈希值是一个固定长度的整数,代表该对象的唯一标识。在 Python 中,hash() 函数常用于字典键值、集合元素等…...
文生视频(Text-to-Video)
🕒 生成时间:每张图大概 10–60 秒(取决于设备) ✅ 二、文生视频(Text-to-Video) 以下项目中,很多都基于 SD 模型扩展,但视频生成复杂度高,生成时间一般 超过 30 秒&am…...
(LeetCode 面试经典 150 题) 80. 删除有序数组中的重复项 II (双指针、栈)
题目:80. 删除有序数组中的重复项 II 思路:左指针 left 类似于指向栈顶的下一个待填的元素,每次遍历只需看当前元素nums[i]和栈顶的下一个元素nums[left-2]是否相等,不等就可以插入栈当中。时间复杂度0(n)。 C版本: …...
【舞蹈】编排:如何对齐拍子并让小节倍数随BPM递减
音的强弱关系 当前划分编排最小单位的代码的分析 📊 代码逻辑分析 ✅ 完整性方面 代码逻辑相对完整,包含了: 结构段落分析(intro, verse, chorus等)强拍时间点提取歌词时间轴处理AI增强的编舞建议生成⚠️ 主要问题 1. 强拍对齐逻辑不够精确 # 当前代码只是简单提取…...
LangGraph--基础学习(工具调用)
本节将详细学习大模型是怎么调用工具的,为什么可以调用工具等等,手写一个工具调用,后续可以通过mcp自己调用即可,没必要自己写,但是学习过程中需要手写,通常怎么使用第三方工具调用呢? import o…...
华为云 Flexus+DeepSeek 实战:华为云单机部署 Dify-LLM 开发平台全流程指南【服务部署、模型配置、知识库构建全流程】
华为云 FlexusDeepSeek 实战:华为云单机部署 Dify-LLM 开发平台全流程指南【服务部署、模型配置、知识库构建全流程】 文章目录 华为云 FlexusDeepSeek 实战:华为云单机部署 Dify-LLM 开发平台全流程指南【服务部署、模型配置、知识库构建全流程】前言1、…...
【appium】2.初始连接脚本配置
连接配置 from appium import webdriver desired_caps {platformName: Android,automationName: UIAutomator2,deviceName: ZTEB880,appPackage: com.taobao.taobao,appActivity: com.taobao.tao.welcome.Welcome,noReset: True }driver webdriver.Remote(http://localhost:…...
磁性传感器在电机控制闭环系统中的反馈作用
磁性传感器的基本原理和类型 基本原理 :磁性传感器是基于磁学原理来检测磁场强度、方向或其他与磁场相关的物理量。常见的磁性传感器有霍尔传感器、磁阻传感器等。霍尔传感器是利用霍尔效应工作的,当电流通过置于磁场中的半导体材料时,在垂直…...
Python:.py文件如何变成双击可执行的windows程序?(版本1)
1、如下.py文件,右键重命名文件后缀名:py改为:pyw 2、修改时,提示如下:不用管点击:是即可 3、之后双击,即可执行python代码文件。 好的,我们来详细介绍一下 Python 的 .pyw 文件。 简…...
Spring Boot + MyBatis + Vue:全栈开发的深度剖析与实践指南
一、技术栈深度剖析 (一)Spring Boot:后端开发的加速器 Spring Boot 是基于 Spring 框架的一个开源 Java 项目,旨在简化基于 Spring 的应用开发。它通过自动配置机制,能够根据项目中添加的依赖自动配置 Spring 和相关…...
学习C++、QT---03(C++的输入输出、C++的基本数据类型介绍)
每日一言 你比想象中更强大,那些咬牙坚持的瞬间,都在雕刻更好的你。 案例:C的输入输出 但是我也会用c语言的方式来回顾c语言的写法,因为两种语言都是密不可分的,所以不能忘记,所以两个一起写 注意点&#…...
八、Redis的主从原理、哨兵
简介: 想要了解Redis的主从原理,首先得认识一个基本的分布式理论-CAP理论。要理解这个理论,其实也非常简单。 CAP理论 C:Consistency、A:Available、P:Partition tolerance 。这是CAP三个字母的全称。C&…...
springboot通过独立事务管理器实现资源隔离与精准控制
安心流转站核心业务模块,为什么!我们考虑这样设计,下面讲讲专用事务管理器的设计与必要性! 一、为什么需要专属事务管理器? 在安心流转站模块中,存在 「多资源混合操作」 和 「业务高敏…...
59-Oracle 10046事件-知识准备
上一篇说到了autotrace,SQL调试时候的获取性能和参数数据,直接用上trace,还有个更全能的工具10046。是不是很多小伙伴会对这么个数字,觉得起名很奇怪,数字起名任性。“10046”本质是Oracle内核事件的随机性技术编号&am…...
2025年渗透测试面试题总结-2025年HW(护网面试) 03(题目+回答)
安全领域各种资源,学习文档,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具,欢迎关注。 目录 2025年HW(护网面试) 03 1. 同源策略(Same-Origin Policy) 2. XSS攻击用途 3. XSS类…...
嵌入式开发之嵌入式系统硬件架构设计时,如何选择合适的微处理器/微控制器?
在嵌入式系统硬件架构设计中,选择合适的微处理器 / 微控制器(MCU/MPU)是关键环节,需从多维度综合评估。以下是系统化的选择策略及核心考量因素: 一、明确应用需求与核心指标 1. 性能需求 处理能力:根据任…...
C++(面向对象编程——继承)
继承基础概念 1.什么是继承? 继承是C三大特性之一;继承是一个已经存在的类的基础上新建一个类,新建的类拥有已经存在的类的特性。主要提现的是代码复用的思想。新的类继承了基类的所有成员变量和成员函数,包括不显示的函数&…...
Unity Shader开发-着色器变体(2)-定义着色器变体
一.定义着色器变体 定义一个着色器变体(Shader Variant)从概念和实现上讲,主要包括以下几个核心部分 1.使用预编译指令来声明变体关键字 关键字是驱动变体生成的“开关”。它们是简单的字符串标识符,用于在 Shader 代码中标记不…...
Cookie和Session的作用和区别
Cookie 客户端持久化保存服务器数据的一种机制(持久化存储就是存硬盘里)。Cookie文件数据为键值对形式,客户端根据服务器域名的不同分别存储Cookie,不同域名的Cookie不同,不会产生冲突。 典型应用场景: 保…...
Redis集群部署终极指南:架构选型、生产部署与深度优化
第一部分:Redis集群技术全景解析 1.1 Redis集群演进史 单机时代(2009-2012):Redis 2.8之前,纯单机模式复制时代(2012-2015):Redis 2.8引入PSYNC改进复制哨兵时代(2015-…...
腾讯云IM即时通讯:开启实时通信新时代
一、引言 在当今数字化浪潮席卷全球的时代,即时通讯已然成为互联网世界中不可或缺的关键元素。无论是个人日常生活中的社交互动,还是企业运营里的高效协作,即时通讯都发挥着举足轻重的作用,已然渗透到人们生活与工作的每一个角落…...
基于Qt的UDP主从服务器设计与实现
概述 一个基于Qt框架实现的UDP主从服务器系统,该系统具备自动主机选举、故障转移和状态同步等关键功能,适用于分布式能源管理系统中的设备通信与协调。 系统核心功能 1. 自动主机选举与故障转移 系统通过优先级机制实现自动主机选举,当主机…...
JVM(8)——详解分代收集算法
JVM 的分代收集算法不是一种具体的垃圾收集算法实现,而是一种指导思想和设计原则,是现代 JVM 垃圾收集器的基石。其核心思想源于对程序运行过程中对象生命周期分布的观察(即弱分代假说)。 核心思想与理论基础:分代假说…...
深入Java面试:从Spring Boot到微服务
深入Java面试:从Spring Boot到微服务 在准备互联网大厂的Java岗位面试时,掌握核心技术栈是关键。本文将从技术栈中选取几个重要的技术点进行探讨,帮助你在面试中脱颖而出。 问题一:Spring Boot的核心特性是什么? 面…...
【软考高级系统架构论文】论无服务器架构及其应用
论文真题 近年来,随着信息技术的迅猛发展和应用需求的快速更迭,传统的多层企业应用系统架构面临越来越多的挑战,已经难以适应这种变化。在这一背景下,无服务器架构(Serverless Architecture) 逐渐流行,它强调业务逻辑由事件触发,具有短暂的生命周期,运行于无状态的轻量…...
Snapchat矩阵运营新策略:亚矩阵云手机打造高效社交网络
1. Snapchat平台特性与风控挑战 Snapchat作为全球领先的即时社交平台,其独特的阅后即焚功能和强社交属性使其风控系统极为严格: 核心风控机制 设备指纹检测:记录设备ID、系统版本、IP地址等硬件信息行为模式分析…...
BGP路由反射器(RR)实验详解,结尾有详细脚本
目录 路由反射器基础概念 实验拓扑与设计 实验配置步骤 配置验证与排错 实验总结 完整配置命令集 路由反射器基础概念 在传统的IBGP网络中,为了防止路由环路,BGP规定通过IBGP学到的路由不能再传递给其他IBGP对等体,这导致所有IBGP路由…...
【JAVA】数组的使用
文章目录 前言一、数组的基本概念1.1 数组的创建和初始化1.2 数组的基本使用 二、数组是引用类型2.1 初始JVM的内存分布JVM内存划分(按功能分区) 2.2 基本类型变量与引用类型变量的区别2.3 再谈引用变量2.4 认识null 三、数组作为函数的参数和返回值四、…...
Python的6万张图像数据集CIFAR-10和CIFAR-100说明
CIFAR-10和CIFAR-100数据集是8000万张微小图像数据集的标记子集。CIFAR-10和CIFAR-100都是由AlexKrizhevsky、VinodNair和GeoffreyHinton创建。数据集说明的网页:https://www.cs.toronto.edu/~kriz/cifar.html 一、CIFAR-10数据集 (一)CIFA…...
CTF--PhP Web解题(走入CTF)
前情提要 分享有趣CTF题目,记录学习过程 题目(带注释,方便理解) <?php // 开启PHP源代码高亮显示,输出当前文件内容(用于调试/展示) highlight_file(__FILE__);// 关闭所有错误报告,防止敏感…...
【Linux仓库】进程概念与基本操作【进程·贰】
🌟 各位看官好,我是! 🌍 Linux Linux is not Unix ! 🚀 今天来学习Linux中进程概念与基本操作。 👍 如果觉得这篇文章有帮助,欢迎您一键三连,分享给更多人哦!…...
Z-Ant开源程序是简化了微处理器上神经网络的部署和优化
一、软件介绍 文末提供程序和源码下载 Z-Ant (Zig-Ant) 是一个全面的开源神经网络框架,专门用于在微控制器和边缘设备上部署优化的 AI 模型。Z-Ant 使用 Zig 构建,为资源受限的硬件上的模型优化、代码生成和实时推理提供端到端…...
面试题-在ts中类型转换的方法
在 TypeScript 中,类型转换主要分为 类型断言(Type Assertion)、类型守卫(Type Guard) 和 类型兼容转换 三种方式。以下是详细分类和示例: 一、类型断言(Type Assertion) 强制编译…...
【论文笔记】【强化微调】T-GRPO:对视频数据进行强化微调
tulerfeng/Video-R1: Video-R1: Reinforcing Video Reasoning in MLLMs [🔥the first paper to explore R1 for video] 1. 引述 在强化微调中,像 GRPO、DAPO 这样的方法都是对文本或者图片进行微调思考,所以这类微调方法不对时序信息做处理&…...
`shallowReactive` 与 `shallowRef`:浅层响应式 API
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 🍚 蓝桥云课签约作者、…...
使用Node.js开发服务端接口
Node.js是一个基于JavaScript的运行时环境,非常适合开发高性能的服务端接口。以下是开发服务端接口的主要方法和步骤。 选择合适的框架 Express、Koa或Fastify是Node.js中常用的框架。Express是最流行的选择,适合快速开发。Koa更轻量,适合需…...
`teleport` 传送 API 的使用:在 Vue 3 中的最佳实践
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 🍚 蓝桥云课签约作者、…...
Linux 多种方式实现行转列
目录 一. 前提二. xargs 实现行转列三. paste 实现行转列四. sed 实现行转列 一. 前提 ⏹之前在这下面篇文章中使用sed命令实现了行专列,本篇文章再介绍几种更加简单的方式。 Linux sed案例 👉 20231126-2.log 110120 SPLREQUEST 内容1 AAA memberID1…...
AI与SEO关键词协同进化
内容概要 人工智能(AI)与搜索引擎优化(SEO)的结合,正深刻变革着关键词策略的制定与执行方式。本文旨在探讨AI技术如何驱动SEO关键词领域的智能化进化,核心在于利用AI强大的数据处理与模式识别能力…...
C# 网络编程-关于HTTP/HTTPS的基础(一)
一、HTTP基础概念 1. 请求-响应模型 HTTP是基于客户端-服务器的无状态协议,流程如下: 客户端(如浏览器)发起请求。服务器接收请求并处理。服务器返回响应,包含状态码、Header和响应体。连接关闭,后续请求…...
题解:P11501 [ROIR 2019] 探险队(Day 2)
前言:这道题 dp 做法找环的部分还没有用拓扑做的,补充一下。 这道题其实很像“上司的舞会”,就是求树上最大独立集。 这里我们把每个人向他讨厌的那个人连边(发现所有点出度均为 1 1 1,所以这是一个基环树࿰…...
读者写者问题与读写锁自旋锁
一、读者写者问题 读者写者问题具有以下特点: 一个交易场所---写者写入数据,读者读数据两种角色---读者,写者三种关系 读者和读者---并发写者和写者---互斥读者和写者---互斥 && 同步 二、读者写者VS生产消费 生产者消费者模型中…...