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

TDengine 可靠性保障:数据持久化与容灾备份(二)

四、容灾备份策略揭秘

(一)主从复制与故障转移

在 TDengine 的高可用性架构中,主从复制是一种极为关键的设计模式,它就像是数据的 “安全复制机”,将数据从主节点精准无误地复制到多个从节点 。在这个过程中,主节点承担着数据变更的实时传递任务,就如同信息的核心枢纽,将最新的数据变化及时同步给从节点 。而从节点则像是忠实的 “追随者”,不仅可以承担读操作,减轻主节点的负载压力,还在主节点出现故障时发挥着至关重要的作用 。

当主节点遭遇故障时,整个系统会迅速启动故障转移机制,这一机制就像是一个智能的 “应急切换开关” 。系统会快速检测到主节点的异常情况,然后自动将读写操作切换到从节点上 。在这个过程中,从节点会迅速接替主节点的工作,确保系统的稳定性和数据的可用性 。以一个大型电商平台的订单数据存储为例,主节点负责实时写入新的订单数据,从节点则同步这些数据并提供查询服务 。当主节点因硬件故障或网络问题无法正常工作时,从节点能够立即顶上,保证订单数据的查询和处理不受影响,避免了因主节点故障而导致的业务中断 。

(二)数据备份与恢复工具

在数据备份与恢复方面,TDengine 提供了强大的 taosdump 工具,它就像是数据的 “安全卫士”,能够帮助用户轻松实现数据的备份和恢复操作 。

使用 taosdump 进行数据导出时,首先需要确保已经安装了该工具,并且具备相应的权限 。例如,如果要备份名为 “iot_data” 的数据库,可以使用以下命令:taosdump -o /backup_path -D iot_data,其中-o参数指定了备份文件的输出路径,/backup_path是用户自定义的路径;-D参数则指定了要备份的数据库名称 。执行该命令后,taosdump 会将 “iot_data” 数据库中的数据导出到指定路径下,生成一系列的备份文件 。

在进行数据恢复时,操作也非常简单 。假设之前的数据备份路径为 “/backup_path”,当数据库出现故障需要恢复数据时,只需执行命令:taosdump -i /backup_path,-i参数表示输入路径,即备份文件所在的路径 。taosdump 会读取备份文件中的数据,并将其导入到 TDengine 数据库中,实现数据的快速恢复 。

数据备份对于数据安全性来说至关重要,它就像是为数据购买了一份 “保险” 。定期进行数据备份可以防止因硬件故障、人为误操作、病毒攻击等意外情况导致的数据丢失 。在面对数据库故障时,能够迅速恢复到最近一次备份的状态,最大程度地减少数据损失和业务影响 。以一家金融机构为例,其交易数据至关重要,通过定期使用 taosdump 进行数据备份,即使在遭遇服务器硬件损坏的情况下,也能通过备份数据快速恢复交易记录,保障金融业务的正常开展 。

(三)双副本与双活方案

为了满足不同用户对于数据可靠性和可用性的多样化需求,TDengine 在 3.3.0.0 版本中推出了双副本(+ 仲裁者)方案和双活方案 。

双副本(+ 仲裁者)方案是一种经济高效且具备一定可靠性的解决方案 。在这种方案中,每个 Vgroup 仅有两个 Vnode,就像是两个数据的 “守护者”,相互协作保障数据的安全 。当其中一个 Vnode 发生故障时,Mnode 就像是一个公正的 “裁判”,会根据数据同步状态,裁定另一 Vnode 是否可以独自对外提供服务 。仲裁者在其中发挥着关键作用,它提供仲裁服务但不存储数据,就像是一个中立的协调者 。当 Vgroup 因某一 Vnode 故障而无法提供服务时,仲裁者可以根据同步情况指定同组另一 Vnode 成为 Assigned Leader,无论其他副本 Vnode 是否存活,均可一直响应用户请求 。这一机制确保了在某个副本节点故障时,数据不会丢失,并且系统能够持续进行写入和查询操作 。例如,对于一些对成本较为敏感但又需要一定高可用性的小型企业,双副本(+ 仲裁者)方案可以在降低硬件成本的同时,保证业务的正常运行 。

双活方案则适用于那些对系统可靠性和数据准确性有着极高要求的场景 。在业务系统中,双活架构通常包括两台服务器,各自部署一套服务,它们就像是两个并肩作战的 “战士”,共同为业务提供支持 。在业务层看来,这两台机器和两套服务组成了一个完整的系统 。双活中的两个节点通常被称为 Master-Slave,即 “主从” 或 “主备” 。系统通过 Client Driver 实现双系统的 Failover,就像是一个智能的 “故障切换器”,在主节点发生故障时,能够自动切换到从节点,确保服务不中断 。同时,taosX 实现了主节点到从节点的数据复制,通过数据订阅的写接口在写入复制过来的数据时,在 WAL 中加入特殊标记,而数据订阅的读接口在读取数据时,会自动过滤掉带有特殊标记的数据,从而避免数据重复复制和无限循环 。当前,双活方案仅支持 JDBC 连接器和 WebSocket 连接方式,不支持 Native 连接,并且双活两端集群必须同构,即数据库的命名和所有配置参数必须完全相同,以确保系统的正确运行 。比如在工业控制领域,对系统的实时性和可靠性要求极高,双活方案能够很好地满足这些需求,保障工业生产的稳定运行 。

对比两种方案,双活方案在集群内部节点数目上具有更大的灵活性,可以根据实际需求进行灵活配置,但同时也增加了部署和管理的复杂性,需要更多的技术资源和运维成本 。双活系统内的最小节点数为两个,每个集群至少有一个节点;而双副本方案只需部署一个集群,但集群内的节点数目必须大于等于三,以确保数据的可靠性和高可用性 。在同步原理上,双活方案通过 taosX 实现数据同步,依赖于 taosX 的同步速度,通常在秒级别,而双副本方案则通过 Arbitrator 仲裁选主,由 Raft 协议保证数据的一致性,在同步延迟上表现更好,几乎没有延迟 。在数据安全性方面,双活方案依赖于 WAL 的保存时长,而双副本方案则能确保无数据丢失 。在高可用性上,双活方案只要有一个节点存活即可提供服务,而双副本方案在连续宕机后,只有一个节点存活时,可能无法提供服务 。因此,用户在选择方案时,需要根据自身的实际需求、预算以及技术能力等因素进行综合考虑,选择最适合自己的方案 。

五、实际应用案例分析

案例一:物联网智能工厂设备监测

某全球知名的智能工厂,在其生产线上部署了大量的传感器,用于实时监测设备的运行状态,包括温度、压力、振动等参数 。这些传感器每秒钟会产生数以万计的时序数据,对数据的可靠性和处理速度要求极高 。

在采用 TDengine 之前,该工厂使用传统关系型数据库存储这些数据,随着数据量的快速增长,数据库的性能逐渐下降,查询响应时间变长,并且经常出现数据丢失的情况,严重影响了生产效率和设备的稳定性 。

引入 TDengine 后,通过其独特的数据持久化机制,数据能够快速且可靠地写入存储,即使在高并发的情况下也能保持稳定的性能 。TDengine 按时间段对数据进行分区存储,使得数据的管理和查询更加高效 。同时,利用 TDengine 的主从复制和多副本机制,实现了数据的容灾备份和高可用性 。当主节点出现故障时,从节点能够迅速接管工作,确保生产监测系统的不间断运行 。

应用 TDengine 后,该智能工厂的数据存储成本降低了约 70%,主要得益于 TDengine 高效的压缩算法,大大减少了存储空间的占用 。系统的可用性得到了显著提高,从原来的 95% 提升到了 99.9% 以上,几乎杜绝了因数据丢失或系统故障导致的生产中断情况,生产效率提高了 20%,有效提升了企业的竞争力 。

案例二:工业互联网能源管理系统

一家大型能源企业,在其能源生产和输送过程中,需要对分布在各地的发电设备、输电线路等进行实时监测和管理 。每天产生的数据量高达数十亿条,数据的可靠性对于能源供应的稳定性和安全性至关重要 。

以往,该企业使用开源的时序数据库存储数据,但在数据备份和恢复方面存在很大的问题,一旦发生数据丢失,恢复过程漫长且复杂,给企业带来了巨大的风险 。

采用 TDengine 后,企业利用其强大的 taosdump 工具进行定期的数据备份,操作简单且高效 。在一次因服务器硬件故障导致数据丢失的事故中,通过 taosdump 工具,企业迅速从备份中恢复了数据,整个恢复过程仅用了几个小时,相比之前使用的数据库,恢复时间缩短了数倍 。

同时,TDengine 的分布式架构和容灾备份机制确保了系统在面对各种故障时的高可用性 。在数据处理性能方面,TDengine 也表现出色,查询响应时间从原来的数秒缩短到了毫秒级,大大提高了能源管理的效率和决策的及时性 。通过使用 TDengine,该能源企业不仅降低了运维成本,还提升了能源供应的稳定性和可靠性,为企业创造了显著的经济效益 。

六、总结与展望

TDengine 作为一款领先的时序数据库,在数据持久化与容灾备份方面展现出了卓越的能力 。通过独特的存储模型和数据分区策略,结合时间驱动的缓存管理与数据驱动的持久化存储机制,确保了数据的高效存储和快速访问 。在容灾备份上,主从复制、故障转移、数据备份与恢复工具以及双副本、双活方案等多种策略,为数据的安全性和系统的高可用性提供了全方位的保障 。

展望未来,随着物联网、工业互联网等领域的快速发展,数据量将持续呈指数级增长,对数据可靠性的要求也会越来越高 。TDengine 有望在以下几个方向取得进一步突破:一是进一步优化数据持久化算法,提高存储效率和读写性能,以应对更大规模数据的挑战;二是不断完善容灾备份方案,提升系统在复杂环境下的容错能力和恢复速度,降低数据丢失的风险;三是加强与云计算、边缘计算等新兴技术的融合,为分布式、多节点的应用场景提供更可靠的数据保障 。

对于广大开发者和企业来说,在构建数据密集型应用系统时,不妨将 TDengine 纳入技术选型的考虑范围 。通过实际应用 TDengine,充分利用其在数据持久化与容灾备份方面的优势,提升数据可靠性,为业务的稳定发展筑牢根基 。相信在 TDengine 的助力下,我们能够更加从容地应对数据时代的挑战,挖掘数据背后的巨大价值 。

相关文章:

TDengine 可靠性保障:数据持久化与容灾备份(二)

四、容灾备份策略揭秘 (一)主从复制与故障转移 在 TDengine 的高可用性架构中,主从复制是一种极为关键的设计模式,它就像是数据的 “安全复制机”,将数据从主节点精准无误地复制到多个从节点 。在这个过程中&#xf…...

一文讲透大模型强化学习基础:PPO、DPO、GRPO

DeepSeek-R1 的强化学习方案中,其亮点之一在于通过 GRPO 算法取代RLHF 常用的 PPO,通过尽可能减少人类标注数据,设计纯 RL 的环境,用精心设计的奖励机制来训练模型自己学会推理。 那么什么是PPO、GRPO,其产生的背景、…...

第十六届蓝桥杯大赛软件赛省赛 Python 大学 B 组 部分题解

题面链接Htlang/2025lqb_python_b 个人觉得今年这套题整体比往年要简单许多,但是G题想简单了出大问题,预估50101015120860,道阻且长,再接再厉 A: 攻击次数 答案:103?181?题目没说明白每回合是…...

5分钟搭建一个在线客服网站!免费!

快速搭建在线客服网站完整教程 本文将手把手教你如何从零开始搭建一个功能完善的在线客服系统,整个过程简单快速,适合新手操作。 一、服务器选购指南 注册雨云账号 如果您尚未注册雨云账号,可以通过以下方式获取优惠: 注册链…...

【测试】-- 测试用例

文章目录 1. 测试用例1.1 概念 2. 设计测试用例的万能公式2.1 常规思考逆向思维发散性思维2.2 万能公式 3. 设计测试用例的方法3.1 具体的设计⽅法3.1.1 等价类3.1.2 边界值3.1.3 正交法3.1.3.1 如何设计正交表 3.1.4 判定表法3.1.4.1 根据判定表法设计测用例的步骤 3.1.5 场景…...

深度剖析循环码解码:从原理到纠错实践

一、引言 循环码作为线性分组码中的重要一员,凭借其出色的纠错和检测能力,在通信领域得到了广泛应用。本文将深入探讨循环码的解码过程,详细阐述其纠错和检测的机理。 二、循环码基础回顾 2.1 循环码的定义与性质 循环码是一类具有循环特性的线性分组码,即任一码组循环…...

MySQL面试题及答案,2025最新整理

文章目录 前言1.InnoDB 与 MyISAM 在事务和索引方面有哪些主要区别?2.简述 MySQL 的事务隔离级别及其对并发问题的解决情况?3.在使用 MySQL 索引时,如何避免索引失效,提高查询效率? 前言 本文围绕 MySQL面试题及答案&…...

ubuntu 安装pyllama教程

最近在研究motion gpt,有一个环节是需要下载gpt 13b,然后老是安装不上去pyllama,ubuntu的版本为: $ lsb_release -a LSB Version: core-11.1.0ubuntu4-noarch:security-11.1.0ubuntu4-noarch Distributor ID: Ubuntu Description…...

Python operator 模块介绍

operator 模块是 Python 标准库中的一个模块,它提供了一系列与 Python 内置运算符对应的函数。这些函数可以用于替代一些常见的运算符操作,在某些场景下能让代码更加简洁、高效,还能方便地用于函数式编程。以下是对 operator 模块的详细介绍: 1. 导入模块 使用 operator …...

[python] reduce

reduce 是 Python 中的一个高阶函数,用于对可迭代对象(如列表、元组等)中的元素进行累积计算,最终返回一个单一的结果。它位于 functools 模块中,使用时需要先导入: from functools import reduce 核心功能…...

ESP32与STM32哪种更适合初学者?

目录 1、ESP32:物联网时代的“网红” 2、STM32:工业界的“常青树” 3、到底谁更容易? 无论是刚入坑的小白,还是想扩展技术栈的老鸟,在选择主力 MCU 时,学习曲线绝对是重要的考量因素。ESP32 以其强大的 …...

AI编程案例拆解|基于机器学习XX评分系统-前端篇

文章目录 1. 定价使用DeepSeek估价小红书调研 2. 确定工作事项利用DeepSeek生成具体工作事项 3. 和客户沟通约会议沟通确定内容样式 4. 前端部分设计使用DeepSeek生成UI设计在Cursor中生成并提问前置条件开始编程 关注不迷路,励志拆解100个AI编程、AI智能体的落地应…...

十六届蓝桥杯嵌入式省赛直播基本外设驱动

前言 本文是准备2025年4月123日嵌入式蓝桥杯直播内容准备的一篇文章 1.创建工程 选择芯片 开启烧录引脚 开启高速时钟 主频设置成80回车 工程名称(不能有中文,包括路径) 考试的时候最下面哪一行取消勾选USE 然后选择这个文件夹打开 勾选几个…...

c_c++八股(一)

C/C static 静态局部变量(函数内) 使局部变量的生命周期延长至整个程序运行期间,但作用域仍限于函数内 变量只初始化一次,下次调用函数时保留上次的值 void counter() {static int count 0; // 只初始化一次count;printf(&quo…...

通过websocket给服务端发送订单催单提醒消息

controller层 GetMapping("/reminder/{id}")public Result Remainder(PathVariable("id") Long id){orderService.remainder(id);return Result.success();} 实现类 Overridepublic void remainder(Long id) {Orders ordersDB orderMapper.getById(id);…...

【NumPy科学计算引擎:从基础操作到高性能实践】

目录 前言:技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析关键技术模块说明技术选型对比 二、实战演示环境配置核心代码实现运行结果验证 三、性能对比测试方法论量化数据对比结果分析 四、最佳实践推荐方案 ✅常见错误 ❌调试技巧 五、应用…...

day24 学习笔记

文章目录 前言一、OpenCV简介二、计算机中的图像表达1.图像表示2.图像存储 三、基本图像操作1.创建窗口2.读取图像3.显示图像4.保存图像5.创建黑白图像6.图像切片7.图像大小调整 四、读取视频 前言 目前,我开始学习OpenCV的相关概念和操作。通过今天的学习&#xf…...

OFDM CP 对解码影响

OFDM符号间会存在ISI,为了解决该问题在符号间插入了循环前缀,可以说这个发明是OFDM能够实用的关键,在多径信道中CP可以有效的解决符号间干扰。3GPP中对于不同SCS 定义了不同的CP长度: 5G Cyclic Prefix (CP) Design -5G Physical …...

Compose笔记(十六)--ExoPlayer

这一节了解一下Compose中的ExoPlayer的使用,我们在开发Android应用时,经常会使用到播放器这个ExoPlayer框架就相对成熟,易上手,现简单总结如下: 1. ExoPlayer 核心类 ExoPlayer 是 ExoPlayer库的核心类,负责管…...

拖拽实现3

import React, { useState, useRef, useEffect } from ‘react’; import ‘./ImageList.css’; const ImageList () > { const images [ ‘https://picsum.photos/300/200?random1’, ‘https://picsum.photos/300/200?random2’, ‘https://picsum.photos/300/200?r…...

OracleLinuxR5U5系统重启后启动数据库oracle23ai

1、切换到oracle用户 [rootOracleLinux-R9-U5 ~]# su oracle2、查看oracle是否配置了ORACLE_SID [oracleOracleLinux-R9-U5 root]$ cd ~ [oracleOracleLinux-R9-U5 ~]$ cat .bash_profile3、输出内容如下: [oracleOracleLinux-R9-U5 ~]$ cat .bash_profile # .ba…...

`offset_mapping` 是什么

offset_mapping 是什么 offset_mapping是 transformers 库中分词器(tokenizer)在进行分词操作时返回的一个重要信息,它用于建立原始文本中的字符位置和分词后标记(tokens)之间的映射关系。借助 offset_mapping&#x…...

数据结构(1)

算法代码如下&#xff1a; #include <iostream> typedef int DataType; void Reverse(DataType a[], int n, DataType b[] ){for(int i 0; i < n; i) {b[i] a[n - 1 - i];} } int main() {const int n 5; DataType a[n] {1, 2, 3, 4, 5}; DataType b[n]; Reverse…...

Linux 第三讲 --- 基础指令(三)

前言&#xff1a; 在前面我们已经讲了有十几个Linux的基础指令&#xff0c;今天我们再补充几个常用的基础指令&#xff0c;为后面的学习做准备 。 目录 前言&#xff1a; 一、两个与时间相关的指令 1.date指令 演示 &#xff1a; 时间戳 设置时间 2、cal指令 演示&#x…...

HotSpot虚拟机中对象的访问定位机制是怎样的?

HotSpot虚拟机中对象的访问定位机制 在HotSpot虚拟机中&#xff0c;对象的访问定位主要通过 直接指针&#xff08;Direct Pointer&#xff09; 实现。这种方式以性能优化为核心&#xff0c;结合内存布局和运行时机制&#xff0c;确保高效的对象数据访问。以下是详细分析&#…...

pjsip 呼叫自定义头协议(pjsua)

我们想和远端设备进行信令交互的时候可以进行自定头部协议带上数据,进行解析处理一些特殊功能,这样可以减少我们再用其他信令交互才能处理一些特殊功能。 1.1 SIP消息结构SIP消息由以下几部分组成: 起始行(Start-Line) 头部字段(Header Fields) 空行(CRLF) 消息体(Me…...

黑马点评redis改 part 2

02.商户查询缓存 比如说那么这是因为这种数据读写的能力远远的低于预算能力&#xff0c;所以说计算机性能受到了一个限制。所以为了解决这个问题&#xff0c;人们就在CPU的内部添加了一个缓存&#xff0c;什么意思&#xff1f;就是CPU会把经常需要读写的一些数据放到CPU的缓存…...

C语言复习笔记--指针(5)

在之前的复习中我们已经简单的了解了qsort函数的使用方式,下面我们接着上回的继续复习,来看看qsort函数的模拟实现. qsort函数的模拟实现 这里因为我们刚刚学习了冒泡排序,所以就先用冒泡排序来改装一下qsort函数,让冒泡排序也可以排各种各样类型的元素. #define _CRT_SECURE_…...

设计模式——工厂模式学习总结

假设现在一个场景&#xff1a; 某物流公司&#xff0c;当前有以下业务&#xff1a;汽车运输和轮船运输。客户可以选择任一运输方式进行运输。 此时&#xff0c;应该如何使用代码将这个现实业务进行抽象实现&#xff1f; 在没有学习工厂模式前&#xff0c;我是这样想的&#x…...

《Python星球日记》第27天:Seaborn 可视化

名人说&#xff1a;路漫漫其修远兮&#xff0c;吾将上下而求索。—— 屈原《离骚》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 专栏&#xff1a;《Python星球日记》&#xff0c;限时特价订阅中ing 目录 一、Seabor…...

获取1688商品评论接口的实践指南

在电商领域&#xff0c;商品评论是消费者了解产品真实情况的重要依据&#xff0c;对于商家来说&#xff0c;分析商品评论可以帮助他们改进产品、优化服务。1688作为国内知名的B2B电商平台&#xff0c;提供了丰富的商品评论接口&#xff0c;方便开发者获取商品的评论数据。本文将…...

c++中继承方面的知识点

继承的概念及定义 继承的概念 继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段&#xff0c;它允许程序员在保 持原有类特性的基础上进行扩展&#xff0c;增加功能&#xff0c;这样产生新的类&#xff0c;称派生类。继承呈现了面向对象 程序设计的层次结…...

青少年编程考试 CCF GESP图形化编程 一级认证真题 2025年3月

图形化编程 一级 2025 年 03 月 一、单选题&#xff08;共 10 题&#xff0c;每题 3 分&#xff0c;共 30 分&#xff09; 1、2025 年春节有两件轰动全球的事件&#xff0c;一个是 DeepSeek 横空出世&#xff0c;另一个是贺岁片《哪吒 2》票房惊人&#xff0c;入了全球票房榜。…...

Openlayers:flat样式介绍

在前段时间我在使用WebGL矢量图层时接触到了flat样式&#xff0c;我对其十分的感兴趣&#xff0c;于是我花了几天的时间对其进行了了解&#xff0c;在这篇文章中我将简单的介绍一下flat样式的使用方式以及我对其的一些理解。 一、了解flat样式 1.什么是flat样式&#xff1f; …...

[特殊字符] 第十三讲 | 地统计模拟与空间不确定性评估

&#x1f4d8; 专栏&#xff1a;科研统计方法实战分享 | 地学/农学人的数据分析工具箱 ✍️ 作者&#xff1a;平常心0715 &#x1f3af; 关键词&#xff1a;地统计模拟、随机函数、空间不确定性、条件模拟、SGS、R语言 &#x1f9e0; 核心导语 在现实数据有限、空间异质性强的…...

Vue接口平台学习六——接口列表及部分调试页面

一、实现效果图及界面布局简单梳理 整体布局分左右&#xff0c;左边调试&#xff0c;右边显示接口列表 左侧&#xff1a; 一个输入框按钮&#xff1b;下面展示信息&#xff0c;大部分使用代码编辑器就好了&#xff0c;除了请求体传文件类型需要额外处理。然后再下方显示响应信…...

Spring 中的 @Cacheable 缓存注解

1 什么是缓存 第一个问题&#xff0c;首先要搞明白什么是缓存&#xff0c;缓存的意义是什么。 对于普通业务&#xff0c;如果要查询一个数据&#xff0c;一般直接select数据库进行查找。但是在高流量的情况下&#xff0c;直接查找数据库就会成为性能的瓶颈。因为数据库查找的…...

Context的全面解析:在不同技术应用中的通用作用与差异

Context的全面解析&#xff1a;在不同技术应用中的通用作用与差异 引言&#xff1a; 在软件开发中&#xff0c;“Context”这个概念被广泛使用。它不仅限于某个特定的技术或编程语言&#xff0c;实际上&#xff0c;Context 作为一种抽象的设计模式&#xff0c;贯穿在许多开发领…...

机器学习(2)——逻辑回归

文章目录 1. 什么是逻辑回归?2. 核心思想3. 逻辑回归模型的训练&#xff1a;4. 参数估计&#xff08;损失函数与优化&#xff09;4.1. **损失函数&#xff1a;**4.2. 极大似然估计&#xff08;MLE&#xff09;4.3. 优化方法 5. 决策边界6. 模型评估指标7 . 假设与适用条件8. 逻…...

Sentinel核心算法解析の滑动窗口算法

文章目录 前言一、回顾&#xff1a;快速失败二、固定窗口算法三、滑动窗口算法三、源码体现3.1、ArrayMetric的初始化3.2、addPass3.2.1、currentWindow3.2.2、wrap.value().addPass 总结 前言 在Sentinel中&#xff0c;流控效果有快速失败、预热和排队等待。其中快速失败的统计…...

ida 使用记录

文章目录 伪代码-汇编hexstring快捷键 伪代码-汇编 流程图界面——F5——伪代码界面——再点Tab——流程图界面——再按空格——汇编界面流程图界面——空格——汇编界面 hex view - open subviews - hex dump string view - open subviews - string快捷键&#xff1a; sh…...

数字统计:

1.题意&#xff1a; 在1~N之间寻找d出现的个数&#xff0c;然后输出即可&#xff1b;例如&#xff1a;d2,N23&#xff0c;那么满足条件的有2,12,21,23&#xff0c;所以是4个 2.思路&#xff1a; 1.暴力枚举&#xff08;不可能&#xff09;&#xff1a;可以先写出来去找规律 …...

【架构师从入门到进阶】第五章:DNSCDN网关优化思路——第八节:网关-注入攻击与预防

【架构师从入门到进阶】第五章&#xff1a;DNS&CDN&网关优化思路——第八节&#xff1a;网关-注入攻击与预防 SQL注入攻击的原理攻击者获取数据库表结构预防SQL注入的方法 这篇文章我们来看SQL注入。 SQL注入攻击的原理 SQL注入攻击的原理呢&#xff1f;我们来简单说…...

波束形成(BF)从算法仿真到工程源码实现-第五节-线性约束最小方差波束形成算法(LCMV)

一、概述 本节我们讨论线性约束最小方差波束形成算法(Linearly constrained minimum variance,LCMV)波束形成算法&#xff0c;包括原理分析及代码实现。 更多资料和代码可以进入https://t.zsxq.com/qgmoN &#xff0c;同时欢迎大家提出宝贵的建议&#xff0c;以共同探讨学习。 …...

Java类加载机制原理与应用

前言 Java 中的类加载机制&#xff08;Class Loading Mechanism&#xff09;是 JVM 架构中的核心组成部分&#xff0c;它控制着类从编译后的 .class 文件被加载到内存、并最终变成可以被程序使用的对象的全过程。涉及类加载器、双亲委派模型及加载过程。下面我们从原理到实际应…...

android display 笔记(十三)surfcaeflinger的DEQUEUED、QUEUED

BufferQueue 的核心作用 BufferQueue 是 生产者-消费者模型 的核心组件&#xff0c;协调应用&#xff08;生产者&#xff09;和 SurfaceFlinger&#xff08;消费者&#xff09;之间的图形缓冲区&#xff08;GraphicBuffer&#xff09;传递。 生产者&#xff1a;应用&#xff0…...

数据库预热

介绍 Database Warm-up &#x1f9e0; 一句话理解 数据库是在应用启动阶段&#xff0c;提前建立数据库连接 或 执行轻量 SQL 操作&#xff0c;从而 加快首个请求的响应速度 的一种优化手段 &#x1f3af; 为什么需要数据库预热&#xff1f; 当 FastAPI 或其他 Web 服务刚启…...

C语言—程序的编译和链接

1. 翻译环境和运行环境 在ANSI S的任何一种实现中&#xff0c;存在两个不同的环境 第一种是翻译环境&#xff0c;在这个环境中源代码被转换为可执行的机器指令&#xff08;二进制指令&#xff09; 第二种是执行环境&#xff0c;它用于实际执行代码 2. 翻译环境 翻译环境是由…...

Neo4j GDS-10-neo4j GDS 库中相似度算法介绍

neo4j apoc 系列 Neo4j APOC-01-图数据库 apoc 插件介绍 Neo4j GDS-01-graph-data-science 图数据科学插件库概览 Neo4j GDS-02-graph-data-science 插件库安装实战笔记 Neo4j GDS-03-graph-data-science 简单聊一聊图数据科学插件库 Neo4j GDS-04-图的中心性分析介绍 Ne…...

Unity 动画

Apply Root Motion 勾选的话就会使用动画片段自带的位移 Update Mode &#xff08;动画重新计算骨骼位置转向缩放的数值&#xff09;&#xff1a; Normal &#xff1a; 随Update走&#xff0c;每次Update都计算Animate Physics &#xff1a;与 fixed Update() 同步&#xff0…...