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

分布式队列对消息语义的处理

在分布式系统中,消息的处理语义(Message Processing Semantics)是确保系统可靠性和一致性的关键。有三种语义:
在分布式系统中,消息的处理语义(Message Processing Semantics)是确保系统可靠性和一致性的关键。以下是三种核心消息处理语义的详细说明:

1. 最多一次(At-Most-Once)

  • 定义:消息可能丢失,但不会重复。
  • 实现方式:消费者收到消息后立即标记为“已处理”(如更新偏移量),无需确认是否成功处理。若处理失败,消息不会重试。
  • 优点:低延迟(无需重试或持久化状态)。
  • 缺点:可能丢失消息,可靠性最低。
  • 适用场景:实时性要求高但允许少量数据丢失的场景(如传感器数据、日志聚合)。

2. 最少一次(At-Least-Once)

  • 定义:消息绝不会丢失,但可能重复处理。
  • 实现方式:
    • 消费者必须显式确认(ACK)消息处理成功。若未收到ACK,消息会被重新投递。
    • 需业务逻辑处理幂等性(如数据库去重或业务去重)。
  • 优点: 高可靠性(确保消息不丢失)。
  • 缺点: 可能重复处理,需额外幂等设计。
  • 适用场景:金融交易、订单支付等不允许丢失但可容忍重复的场景。

3. 精准一次(Exactly-Once)

  • 定义:消息确保被处理且仅处理一次。
  • 实现方式:
    • 幂等性 + 事务:通过唯一ID去重(如Kafka的幂等生产者)或分布式事务(如两阶段提交)。
    • 日志/状态快照:如Flink的检查点机制(Checkpoint)或事件溯源(Event Sourcing)。
  • 优点:最高一致性(无丢失无重复)。
  • 缺点: 实现复杂,性能开销大。
  • 适用场景:严格要求的场景(如银行对账、计费系统)。
唯一id的设计
系统常见的设计是提交数据后,才分配唯一ID
这么做的后果是客户端每次提交都会得到一个新的ID,即使客户端提交了重复的数据。
这样也就无法保障精准一次。
提前分配ID
如果改为提前分配好ID, 客户端将ID与数据一同发送给服务端,服务端进行ID验证,检查这个ID是否已经处理过了。
这个过程等同于在服务端实现了幂等性。
场景
防止订单重复提交,用户手快或非法api调用是很容易重复提交订单的,这样会占用库存。
通过预分配ID就容易避免,客户端每次提交订单都需要携带一个提前获取的订单id,当服务端检查有重复的订单id时,就可以拒绝。
Kafka的生产者幂等性也是这么设计的。

Exactly-Once 语义的实现设计

1. 幂等性设计 (Idempotency)

  • 原理:使操作执行多次与执行一次效果相同
  • 实现方式:
    • 为每个操作分配唯一ID,处理前检查是否已执行
    • 使用条件更新(如"update where version=X")
    • 数据库唯一约束防止重复插入

2. 事务性处理 (Transactional Processing)

  • 两阶段提交 (2PC):
    • 准备阶段:协调者询问所有参与者是否可以提交
    • 提交阶段:所有参与者确认后执行提交
  • Saga模式:
    • 将长事务分解为多个本地事务
    • 每个本地事务有对应的补偿事务
    • 失败时按相反顺序执行补偿事务

3. 日志与检查点 (Logging & Checkpointing)

  • Write-Ahead Logging (WAL):
    • 操作前先记录日志
    • 崩溃恢复时重放日志
  • 检查点机制:
    • 定期保存系统状态快照
    • 故障时从最近检查点恢复

4. 分布式流处理框架策略

  • Apache Kafka:
    • 生产者:启用幂等生产者和事务
    • 消费者:使用事务性消费和read_committed隔离级别
    • 存储偏移量与处理结果在同一事务中
  • Apache Flink:
    • Checkpoint机制保证状态一致性
    • 两阶段提交Sink连接器
    • 端到端精确一次保证

5. 去重表 (Deduplication Table)

  • 存储已处理消息的唯一标识
  • 处理前查询去重表检查是否已处理
  • 可与TTL结合自动清理旧记录

6. 混合策略

实际系统中常组合使用多种策略,例如:
  • 幂等操作+事务性写入
  • WAL+检查点+幂等消费者
  • 去重表+Saga模式

问题

  • 性能开销:Exactly-Once通常比At-Least-Once有更高延迟
  • 实现复杂度:需要精心设计系统各组件
  • 存储成本:去重表、日志等需要额外存储
选择策略时应根据业务需求、性能要求和系统复杂度进行权衡。

Kafka 的 Exactly-Once 语义实现

Kafka 提供的 Exactly-Once 保障

Kafka 在三个层面上实现了 Exactly-Once 语义:
  1. 生产者幂等性 (Idempotent Producer)
  • 防止生产者重试导致的消息重复
  • 通过 PID(Producer ID)和序列号(Sequence Number)实现
  • 启用方式:设置 enable.idempotence=true
  1. 事务性生产 (Transactional Producer)
  • 跨分区原子写入
  • 使用事务协调器管理
  • 启用方式:设置 transactional.id 并调用 initTransactions()
  1. 事务性消费 (Transactional Consumer)
  • 确保"读取-处理-写入"的原子性
  • 使用 isolation.level=read_committed
  • 消费者只读取已提交的事务消息

实现原理

生产者端

* PID:每个新的Producer在初始化的过程中就会被分配一个唯一的PID。这个PID对用户是不可见的。
* Sequence Numer: 对于每个PID,这个Producer针对Partition会维护一个sequenceNumber。这是一个从0开始单调递增的数字。当Producer要往同一个Partition发送消息时,这个Sequence Number就会加1。然后会随着消息一起发往Broker。
* Broker端则会针对每个\维护一个序列号(SN),只有当对应的SequenceNumber = SN+1时,Broker才会接收消息,同时将SN更新为SN+1。否则,SequenceNumber过小就认为消息已经写入了,不需要再重复写入。而如果SequenceNumber过大,就会认为中间可能有数据丢失了。对生产者就会抛出一个OutOfOrderSequenceException。

消费者端

  • 将消费位移(offset)和处理结果写入同一事务
  • 要么全部成功,要么全部回滚
  • 故障恢复后从正确位置重新消费

使用限制

  1. 范围限制:
  • 仅保证 Kafka 内部的 Exactly-Once
  • 如果处理逻辑涉及外部系统,需要额外措施(如幂等写入)
  1. 性能影响:
  • 事务会降低吞吐量(约20-30%)
  • 增加端到端延迟
  1. 配置要求:
  • 需要集群版本 ≥ 0.11.0
  • 要求 acks=all 和 min.insync.replicas≥1

代码实现

// 生产者配置
props.put("enable.idempotence", "true");
props.put("transactional.id", "my-transactional-id");
KafkaProducer producer = new KafkaProducer(props);// 消费者配置
props.put("isolation.level", "read_committed");
KafkaConsumer consumer = new KafkaConsumer(props);// 事务处理流程
producer.initTransactions();
while(true) {ConsumerRecords records = consumer.poll(Duration.ofMillis(100));producer.beginTransaction();try {// 处理消息并生成新消息producer.send(new ProducerRecord(...));// 提交消费位移producer.sendOffsetsToTransaction(offsets, "consumer-group");producer.commitTransaction();} catch(Exception e) {producer.abortTransaction();}
}

RocketMQ 的 Exactly-Once 语义实现

RocketMQ 部分支持 Exactly-Once 语义,但实现方式与 Kafka 不同,且有一些限制条件。

RocketMQ 的 Exactly-Once 支持情况

1. 生产者幂等性 (4.4.0+ 版本支持)

  • 实现原理
    • 每个消息携带唯一 UNIQ_KEY(业务标识符)
    • Broker 端基于 UNIQ_KEY 进行重复检测
    • 时间窗口默认为5分钟(可配置)
  • 启用方式
// 发送消息时设置UNIQ_KEY
Message msg = new Message("topic", "tag", "body".getBytes());
msg.setKeys("your_business_key");  // 设置幂等键

2. 事务消息 (半事务机制)

  • 实现原理
    • 两阶段提交:预备消息 → 本地事务执行 → 提交/回滚
    • 如果生产者崩溃,Broker 会回查事务状态
  • 代码示例
TransactionListener listener = new TransactionListenerImpl();
TransactionMQProducer producer = new TransactionMQProducer("group");
producer.setTransactionListener(listener);
// 发送事务消息
TransactionSendResult result = producer.sendMessageInTransaction(msg, null);

3. 消费者端 Exactly-Once

RocketMQ 不原生支持消费者端的 Exactly-Once,需要业务方自行实现:
  • 常见方案:
    • 幂等消费:通过业务唯一键+去重表实现
    • 事务性消费:将消息处理与存储更新放在同一事务中
    • 手动位点管理:确保处理成功后再提交offset

与 Kafka Exactly-Once 的关键区别

特性
RocketMQ
Kafka
生产者幂等
基于业务键(UNIQ_KEY)
基于PID+序列号
事务支持
半事务(需回查)
完整两阶段提交
消费者Exactly-Once
不原生支持
支持(事务性消费)
性能影响
较小
较大(约20-30%吞吐下降)

实现完整 Exactly-Once 的建议方案

如果需要 RocketMQ 实现完整的 Exactly-Once 语义,可以采用以下组合方案:
  1. 生产者端:
  • 启用事务消息
  • 为每条消息设置唯一 UNIQ_KEY
  1. 消费者端:
// 伪代码示例:消费者幂等处理
consumer.registerMessageListener((msgs, context) -> {for (MessageExt msg : msgs) {String bizId = msg.getKeys(); // 获取业务唯一IDif (deduplicate(bizId)) {    // 检查是否已处理continue;}// 处理消息(与数据库操作在同一个事务中)processInTransaction(msg);// 记录已处理(可异步)markAsProcessed(bizId); }
});

  1. 存储设计:
  • 创建去重表:CREATE TABLE msg_dedup (biz_id VARCHAR PRIMARY KEY, processed_at TIMESTAMP)
  • 使用TTL自动清理过期记录

总结

  1. RocketMQ 的事务消息不是严格的ACID事务,而是"最终一致"的
  2. 消息去重窗口期默认5分钟(fileReservedTime参数控制)
  3. 高并发场景下,去重检查可能成为性能瓶颈
  4. 跨系统场景仍需额外的一致性保障措施
RocketMQ 官方推荐对于严格要求 Exactly-Once 的场景,应该在业务层实现幂等性作为主要保障手段,消息队列的机制作为辅助。

相关文章:

分布式队列对消息语义的处理

在分布式系统中,消息的处理语义(Message Processing Semantics)是确保系统可靠性和一致性的关键。有三种语义: 在分布式系统中,消息的处理语义(Message Processing Semantics)是确保系统可靠性和…...

《免费开放”双刃剑:字节跳动Coze如何撬动AI生态霸权与暗涌危机?》

战略动机分析 降低技术门槛为数据采集接口 Coze平台宣称**“30秒无代码生成AI Bot”,大幅降低了企业开发AI应用的技术门槛。任何不懂编程的业务人员都可以通过可视化流程和提示词,在半分钟内搭建聊天机器人或智能代理。这种极低门槛意味着更多企业和个人…...

AI 开发工具提示词集体开源!解锁 Cursor、Cline、Windsurf 等工具的核心逻辑

✨ 前言:提示词,AI 编程工具的灵魂 随着大模型编程能力的迅速提升,AI 编程工具如雨后春笋般涌现,涵盖了从代码编辑器(如 Cursor、Windsurf、Cline)到应用生成服务(如 Lovable、Bolt.new、V0&am…...

MYSQL 常用字符串函数 和 时间函数详解

一、字符串函数 1、​CONCAT(str1, str2, …) 拼接多个字符串。 SELECT CONCAT(Hello, , World); -- 输出 Hello World2、SUBSTRING(str, start, length)​​ 或 ​SUBSTR() 截取字符串。 SELECT SUBSTRING(MySQL, 3, 2); -- 输出 SQ3、LENGTH(str)​​ 与 ​CHAR_LENGTH…...

Ubuntu 下 Nginx 1.28.0 源码编译安装与 systemd 管理全流程指南

一、环境与依赖准备 为确保编译顺利,我们首先更新系统并安装必要的编译工具和库: sudo apt update sudo apt install -y build-essential \libpcre3 libpcre3-dev \zlib1g zlib1g-dev \libssl-dev \wgetbuild-essential:提供 gcc、make 等基…...

线程怎么创建?Java 四种方式一网打尽

🚀 Java 中线程的 4 种创建方式详解 创建方式实现方式是否推荐场景说明1. 继承 Thread 类class MyThread extends Thread❌ 不推荐简单学习、单线程场景2. 实现 Runnable 接口class MyRunnable implements Runnable✅ 推荐更适合多线程共享资源3. 实现 Callable 接…...

高效使用DeepSeek对“情境+ 对象 +问题“型课题进行开题!

目录 思路"情境 对象 问题"型 课题选题的类型有哪些呢?这要从课题题目的构成说起。通过对历年来国家社会科学基金立项项目进行分析,小编发现,课题选题类型非常丰富,但一般是围绕限定词、研究对象和研究问题进行不同的组…...

【GCC bug】libstdc++.so.6: version `GLIBCXX_3.4.29‘ not found

在 conda 环境安装 gcc/gxx 之后&#xff0c;运行开始遇到了以下的报错 File "/mnt/data/home/xxxx/miniforge3/envs/GAGAvatar/lib/python3.12/site-packages/google/protobuf/internal/wire_format.py", line 13, in <module>from google.protobuf import de…...

python卸载报错:No Python 3.12 installation was detected已解决

问题背景 在卸载Python 3.12.5时&#xff0c;遇到了一个棘手的问题&#xff1a;运行安装包python.exe点击Uninstall后&#xff0c;系统提示No Python 3.12 installation was detected. 尝试了网上各种方法&#xff08;包括注册表清理、修复repair&#xff0c;卸载unins…...

【Hive入门】Hive分区与分区表完全指南:从原理到企业级实践

引言 在大数据时代&#xff0c;高效管理海量数据成为企业面临的核心挑战。Hive作为Hadoop生态系统中最受欢迎的数据仓库解决方案&#xff0c;其分区技术是优化数据查询和管理的关键手段。本文将全面解析Hive分区技术的原理、实现方式及企业级最佳实践&#xff0c;帮助您构建高性…...

AI之FastAPI+ollama调用嵌入模型OllamaBgeEmbeddings

以下是对该 FastAPI 代码的逐行解析和详细说明: 代码结构概览 from fastapi import Depends # 导入依赖注入模块def get_embedder():return OllamaBgeEmbeddings(base_url="http://ollama-cluster:11434",timeout=30,max_retries=5)@app.post("/embed")…...

RK3588芯片NPU的使用:yolov8-pose例子图片检测在安卓系统部署与源码深度解析(rknn api)

一、本文的目标 将yolo8-pose例子适配安卓端,提供选择图片后进行姿态识别功能。通过项目学习源码和rknn api。二、开发环境说明 主机系统:Windows 11目标设备:搭载RK3588芯片的安卓开发板核心工具:Android Studio Koala | 2024.1.1 Patch 2,NDK 27.0三、适配(迁移)安卓 …...

【HTTP/3:互联网通信的量子飞跃】

HTTP/3&#xff1a;互联网通信的量子飞跃 如果说HTTP/1.1是乡村公路&#xff0c;HTTP/2是现代高速公路系统&#xff0c;那么HTTP/3就像是一种革命性的"传送门"技术&#xff0c;它彻底重写了数据传输的底层规则&#xff0c;让信息几乎可以瞬间抵达目的地&#xff0c;…...

2024 年:Kubernetes 包管理的新前沿

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;历代文学&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编程&#xff0c;高并发设计&#xf…...

SIEMENS PLC 程序 GRAPH 程序解读 车型入库

1、程序载图1 2、程序截图2 3、程序解释 这是一个基于西门子 GRAPH 编程的车型 1 入库顺序控制流程图&#xff0c;通过状态机结构&#xff08;状态框 S 与转移条件 T&#xff09;描述完整工作流程&#xff0c;具体如下&#xff1a; 整体流程概述 初始化&#xff1a;从 S1&am…...

c++11新特性随笔

1.统一初始化特性 c98中不支持花括号进行初始化&#xff0c;编译时会报错&#xff0c;在11当中初始化可以通过{}括号进行统一初始化。 c98编译报错 c11: #include <iostream> #include <set> #include <string> #include <vector>int main() {std:…...

微信小程序文章管理系统开发实现

概述 在内容为王的互联网时代&#xff0c;高效的文章管理系统成为各类平台的刚需。幽络源平台今日分享一款基于SSM框架开发的微信小程序文章管理系统完整解决方案&#xff0c;该系统实现了多角色内容管理、智能分类、互动交流等功能。 主要内容 一、用户端功能模块 ​​多角…...

3种FSC标签你用对了吗?

如果你留意过产品上的FSC小树标识&#xff0c;也许会发现它们很相似但又各不相同。 根据产品使用的FSC认证材料的不同比例&#xff0c;共有三种不同类型的FSC标签&#xff1a; 1、FSC 100% 所有使用的材料均来自负责任管理的FSC认证森林。 标签文本为&#xff1a;“ From well-…...

NLP高频面试题(五十四)——深度学习归一化详解

引言:大模型训练中的归一化需求 随着人工智能技术的快速发展,**大模型(Large Language Models, LLMs)**的规模与能力都呈爆发式增长。诸如GPT-4、BERT、PaLM等模型参数量从最初的百万级到如今的千亿、万亿级别,训练难度和效率问题日益显著。在超大模型的训练过程中,梯度…...

第5.5章:ModelScope-Agent:支持多种API无缝集成的开源框架

5.5.1 ModelScope-Agent概述 ModelScope-Agent&#xff0c;由阿里巴巴旗下ModelScope社区开发&#xff0c;是一个开源的、模块化的框架&#xff0c;旨在帮助开发者基于大型语言模型快速构建功能强大、灵活性高的智能代理。它的核心优势在于支持与多种API和外部系统的无缝集成&…...

筑牢数字防线:商城系统安全的多维守护策略

一、构建网络安全防护屏障​ 网络安全是商城系统安全的第一道防线。企业应采用先进的防火墙技术&#xff0c;实时监控和过滤进出网络的流量&#xff0c;阻止非法访问和恶意攻击。入侵检测与防御系统&#xff08;IDS/IPS&#xff09;也是不可或缺的安全组件&#xff0c;它能够及…...

PTC加热片详解(STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.引脚描述 三、程序设计 main文件 jdq.h文件 jdq.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 PTC是正温度系数热敏电阻的英文简称&#xff0c;其电阻值随着PTC热敏电阻本体温度的升高呈现阶跃性的增加。温度越高&…...

OpenCV 图形API(64)图像结构分析和形状描述符------在图像中查找轮廓函数findContours()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在二值图像中查找轮廓。 该函数使用[253]中的算法从二值图像检索轮廓。轮廓是形状分析以及对象检测和识别的有用工具。请参阅 OpenCV 示例目录中…...

GIS开发笔记(15)基于osg和osgearth实现三维地图上添加路网数据(矢量shp)

一、实现效果 二、实现原理 准备路网图层数据(.shp、.prj、.dbf、.cpg),设置样式、贴地,添加图层到地球节点。 三、参考代码 {// 获取当前可执行程序所在的目录QString exeDir = QCoreApplication::applicationDirPath();// 构造 Shapefile 文件的完整路径...

Golang日志模块之xlog

基于douyu的xlog 依赖 github.com/douyu/jupiter/pkg/xlog go.uber.org/zap gopkg.in/natefinch/lumberjack.v2log相关结构体 types/log.go type Log struct {Env string toml:"env"InfoLogFileName string toml:"infoLogFileName"Error…...

guvcview-源码记录

guvcview源码记录 一、概述二、项目结构1. guvcview2. gview_audio3. gview_encoder4. gview_render1. render.c2. render_sdl2.c3. render_osd_crosshair.c4. render_osd_vu_meter.c5. render_fx.c 3. gview_v4l2core 三、四、五、六、 一、概述 项目地址&#xff1a;guvcvie…...

对比2款国产远控软件,贝锐向日葵更优

贝锐向日葵和ToDesk是两款国产的远程控制软件&#xff0c;其中贝锐向日葵比较老牌&#xff0c;2009年就推出了最早的版本&#xff0c;而ToDesk则是在前几年疫情期间出现的。如果要在这两款远控软件中进行一个对比和选择&#xff0c;我们可以从功能配置、性能表现、系统支持、使…...

SOC估算:开路电压修正的安时积分法

SOC估算&#xff1a;开路电压修正的安时积分法 基本概念 开路电压修正的安时积分法是一种结合了两种SOC估算方法的混合技术&#xff1a; 安时积分法&#xff08;库仑计数法&#xff09; - 通过电流积分计算SOC变化 开路电压法 - 通过电池电压与SOC的关系曲线进行校准 方法原…...

maxscript根据音频创建动画表情

方案1&#xff1a; Python pydub / Audacity phoneme recognition 来提取语音中的音素&#xff08;phonemes&#xff09;并输出为 JSON 供 3ds Max 使用 方案2: Papagayo输出.pgo 文件&#xff0c;通过 Python 脚本解析&#xff0c;然后转换成 JSON。 下面介绍下方案2&#…...

使用ast解ob混淆时关于types的总结

在AST解OB混淆过程中&#xff0c;babel/types模块&#xff08;简称types&#xff09;是核心操作工具&#xff0c;以下是典型应用场景及具体代码示例&#xff1a; 一、字符串解密场景 场景&#xff1a;OB混淆常将字符串存储为十六进制或Unicode编码&#xff0c;需还原为明文 ty…...

每天学一个 Linux 命令(32):sort

​​可访问网站查看,视觉品味拉满: http://www.616vip.cn/32/index.html sort 是 Linux 中用于对文本文件的行进行排序的命令,支持按字典序、数字、月份等多种方式排序。以下是详细说明和示例: 命令语法 sort [选项]... [文件]...常用选项 -n 或 --numeric-sort 按数值大小…...

解释两个 Django 命令 makemigrations和migrate

python manage.py makemigrations 想象一下&#xff0c;你正在设计一个房子。在开始建造之前&#xff0c;你需要一个详细的蓝图来指导建筑过程。在 Django 中&#xff0c;当你定义或修改模型&#xff08;比如 Employee&#xff09;&#xff0c;你实际上是在设计数据库的“房子…...

tkinter的窗口构建、原生组件放置和监测事件

诸神缄默不语-个人技术博文与视频目录 本文关注用Python3的tkinter包构建GUI窗口&#xff0c;并用tkinter原生组件来进行排版&#xff08;通过pack() / grid() / place()&#xff0c;并监测基础的事件&#xff08;如按钮被点击后获取文本框输入信息、单/多选框选择结果等&…...

Hot100方法及易错点总结2

本文旨在记录做hot100时遇到的问题及易错点 五、234.回文链表141.环形链表 六、142. 环形链表II21.合并两个有序链表2.两数相加19.删除链表的倒数第n个节点 七、24.两两交换链表中的节点25.K个一组翻转链表(坑点很多&#xff0c;必须多做几遍)138.随机链表的复制148.排序链表 N…...

WebUI可视化:第6章:项目实战:智能问答系统开发

第6章:项目实战:智能问答系统开发 学习目标 ✅ 完整实现前后端分离的问答系统 ✅ 掌握本地AI模型的集成方法 ✅ 实现对话历史管理功能 ✅ 完成系统部署与性能优化 6.1 项目整体设计 6.1.1 系统架构 graph TDA[用户界面] -->|输入问题| B(Web服务器)B -->|调用模型| …...

项目质量管理

项目质量管理核心要点与高频考点解析 一、项目质量管理核心框架 三大核心过程&#xff1a; 规划质量管理&#xff1a;制定质量标准和计划&#xff08;预防为主&#xff09;。实施质量保证&#xff1a;审计过程&#xff0c;确保符合标准&#xff08;过程改进&#xff09;。控…...

利用TTP协议 ETag + 路由守卫 实现前端发版后通知用户更新得一个方案

利用 ETag 做提示更新的实现方案 ETag&#xff08;Entity Tag&#xff09;是万维网协议HTTP的一部分&#xff0c;是HTTP协议提供的若干机制中的一种Web缓存验证机制&#xff0c;是一个可以与Web资源关联的记号&#xff08;token&#xff09;&#xff0c;并且允许客户端进行缓存…...

uniapp-商城-36-shop 购物车 选好了 进行订单确认2 支付方式颜色变化和颜色滤镜filter

颜色滤镜&#xff0c;在好多网页都这样使用&#xff0c;滤掉彩色&#xff0c;显示黑白&#xff0c;这在一些关键的日子中都这样使用。 1、依然回到订单确认页面 看到支付的颜色了嘛&#xff1f; <view class"payType"><view class"box" :class&q…...

CSRF请求伪造

该漏洞主要是关乎于用户&#xff0c;告诫用户不可乱点击链接&#xff0c;提升自我防范&#xff0c;才能不落入Hacker布置的陷阱&#xff01; 1. cookie与session 简单理解一下两者作用 1.1. &#x1f36a; Cookie&#xff1a;就像超市的会员卡 存储位置&#xff1a;你钱包里…...

爬虫瑞数6案例:深圳大学总医院,webEnv补环境

爬虫瑞数6案例:深圳大学总医院,webEnv补环境 一、准备工作二、webEnv补环境三、验证cookie四、验证请求结果五、总结声明: 该文章为学习使用,严禁用于商业用途和非法用途,违者后果自负,由此产生的一切后果均与作者无关 前言: 之前出了一篇深圳大学总医院爬虫教程,那时候…...

运维 vm windows虚拟机nat网络配置

参考 VMWare虚拟机网络配置 - 秋夜雨巷 - 博客园 vm设置虚拟网络段 设置网络段 网关地址 设置DHCP 自动化分配网络段 主机&#xff1a;设置ip 控制面板\所有控制面板项\网络连接 出现设置的虚拟机网卡 设置ip 虚拟机&#xff1a;设置ip...

PPO 强化学习机械臂 IK 训练过程可视化利器 Tensorboard

视频讲解&#xff1a; PPO 强化学习机械臂 IK 训练过程可视化利器 Tensorboard PPO 强化学习过程中&#xff0c;设置了verbose会显示数据&#xff0c;但还是不够直观&#xff0c;这里上一个可视化利器&#xff0c;Tensorboard&#xff0c;实际上stable baselines3中已经有了这部…...

巧记英语四级单词 Unit5-中【晓艳老师版】

ignore v.无视&#xff0c;不理睬 发音“一个闹”&#xff0c;对付一个无理取闹的孩子&#xff0c;最好的方式就是无视 不理睬ignorant a.无知的&#xff0c;不礼貌的 对于什么事都无视&#xff0c;中国第一个不平等条约问也不知道就是无知的neglect n.忽视 negative消极的&a…...

Linux操作系统从入门到实战(三)Linux基础指令(上)

Linux操作系统从入门到实战&#xff08;三&#xff09;Linux基础指令&#xff08;上&#xff09; 前言一、ls 指令二、pwd三、cd四、touch 指令五、mkdir六、rmdir 指令和 rm 指令七、man 指令八、cp九、mv 指令十、cat 指令十一、 more 指令十二、less 指令十四、head 指令十五…...

MDF标准

MDF(Measurement Data Format),测量数据格式,是ASAM(自动化及测量系统标准协会)定义的, 是一种二进制文件,需要使用二进制文件编辑器查看. 作为一种紧凑的二进制格式,ASAM MDF提供了对海量测量数据的高效及高性能存储方案。MDF由松散耦合的二进制块组成,以实现灵活且高…...

如何本地无损放大图片保持高清画质

软件介绍 这款工具能让你轻松放大图片而不失真&#xff0c;最高支持4倍放大&#xff0c;并提供四种AI模型&#xff0c;适配不同风格的图像处理需求&#xff0c;包括普通照片、插画和漫画。它支持JPG、PNG、WEBP三种格式的输出&#xff0c;小巧便携&#xff0c;仅占用54.1MB空…...

【视频时刻检索】Text-Video Retrieval via Multi-Modal Hypergraph Networks 论文阅读

Text-Video Retrieval via Multi-Modal Hypergraph Networks 论文阅读 ABSTRACT1 INTRODUCTION2 PRELIMINARIES3 OUR FRAMEWORK3.1 Multi-Modal Hypergraph Networks3.2 Variational Inference 4 EXPERIMENT6 CONCLUSION 文章信息&#xff1a; 发表于&#xff1a;WSDM 24 原文…...

PowerShell脚本实现|从文件夹动画序列中均匀选取关键帧(保留首尾帧)

文章目录 1. 问题概述2. 两种实现方案方案一&#xff1a;自动计算法&#xff08;推荐&#xff09;方案二&#xff1a;手动列表法 3. 操作流程对比4. 注意事项5. 常见问题解决6. 总结建议 1. 问题概述 我们经常需要从动画序列中选取关键帧&#xff0c;例如&#xff1a; 文件名…...

红黑树——如何靠控制色彩实现平衡的?

目录 引言 一、认识红黑树&#xff08;RBTree&#xff09; 二、为什么有了AVL树&#xff0c;还要红黑树&#xff1f; 1、AVL树 vs 红黑树&#xff0c;两棵树区别 2、如何选择&#xff1f; 三、红黑树的核心操作 3.1、红黑树结构定义 3.2、插入操作 四、红黑树的验证 …...

金仓数据库KingbaseES技术实践类深度剖析与实战指南

一、语法兼容及迁移实战 &#xff08;一&#xff09;语法兼容的多元魅力 在当今多元化的数据库应用环境中&#xff0c;金仓数据库管理系统KingbaseES凭借其卓越的语法兼容能力脱颖而出。它采用的融合数据库架构&#xff0c;通过多语法体系一体化架构&#xff0c;实现了对Orac…...