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

【实战ES】实战 Elasticsearch:快速上手与深度实践-2.2.1 Bulk API的正确使用与错误处理

👉 点击关注不迷路
👉 点击关注不迷路
👉 点击关注不迷路


文章大纲

  • Elasticsearch Bulk API 深度实践:性能调优与容错设计
    • 1. `Bulk API` 核心机制解析
      • 1.1 批量写入原理剖析
        • 1.1.1 各阶段性能瓶颈
    • 2. 高性能批量写入实践
      • 2.1 客户端最佳配置
        • 2.1.1 主流客户端对比
        • 2.1.2 Python 优化示例
      • 2.2 服务端关键参数
    • 3. 错误处理与容错设计
      • 3.1 错误分类与处理策略
      • 3.2 重试机制实现方案
        • 3.2.1 重试参数计算公式
    • 4. 性能优化案例
      • 4.1 日志采集系统调优
        • 4.1.1 原始性能
        • 4.1.2 优化措施
        • 4.1.3 优化结果
      • 4.2 电商订单数据同步
        • 4.2.1 挑战
        • 4.2.2 解决方案
        • 4.2.3 效果验证
    • 5. 监控与问题诊断
      • 5.1 关键监控指标
      • 5.2 性能问题排查流程
    • 6. 进阶优化策略
      • 6.1 硬件级优化
      • 6.2 数据建模优化

Elasticsearch Bulk API 深度实践:性能调优与容错设计


  • Elasticsearch Bulk API 是 Elasticsearch 提供的一种批量操作 API允许在单个请求中执行多个索引、更新或删除操作
  • 使用 Bulk API 可以显著提高数据导入和处理的效率,因为它减少了与 Elasticsearch 集群之间的网络往返次数,从而减少了网络开销,提高了整体性能。

1. Bulk API 核心机制解析

1.1 批量写入原理剖析

Elasticsearch 批量写入吞吐量主要受以下因素影响:
在这里插入图片描述

1.1.1 各阶段性能瓶颈
阶段典型耗时占比关键影响因素优化杠杆点
客户端构建10%-15%序列化效率/数据格式NDJSON 流式构建
网络传输20%-30%压缩算法/批量大小Gzip压缩/5-15MB 包体
节点处理40%-50%线程池配置/索引刷新间隔调整 bulk 线程池队列
分片写入15%-25%分片数/副本策略动态分片策略
  • 基准测试数据:单节点 16C32G SSD 磁盘,10KB/doc,不同批量大小的吞吐量对比:

    批量大小QPS网络耗时占比CPU利用率
    1008,20038%65%
    50014,50024%82%
    100018,30018%91%
    500021,00012%95%

2. 高性能批量写入实践

2.1 客户端最佳配置

2.1.1 主流客户端对比
客户端并发模型内存管理推荐场景
RestHighLevel同步阻塞全量缓冲小规模数据
Jest异步回调部分缓冲中等吞吐
Elastic-py协程异步流式处理高吞吐低延迟
Go-elasticGoroutine零拷贝极致性能需求
2.1.2 Python 优化示例
# 从 elasticsearch 库中导入 helpers 模块
# helpers 模块提供了一些实用的工具函数,用于简化与 Elasticsearch 的交互,例如批量操作
from elasticsearch import helpers
import datetimedef gen_data():"""这是一个生成器函数,用于流式生成要插入到 Elasticsearch 中的数据。流式生成数据的好处是可以避免一次性将大量数据加载到内存中,从而防止内存溢出。"""# 循环 100000 次,模拟生成 100000 条数据for _ in range(100000):# 使用 yield 关键字将数据逐个生成# 每次生成的数据是一个字典,包含两个主要部分:_index 和 _sourceyield {# _index 指定数据要插入到的 Elasticsearch 索引名称# 这里将数据插入到名为 "logs" 的索引中"_index": "logs",# _source 包含了实际要存储的数据"_source": {# timestamp 字段记录当前的时间戳# 使用 datetime.now() 获取当前的日期和时间"timestamp": datetime.now(),# message 字段是一个示例消息,这里用 "..." 表示"message": "..." }}# 关键参数调优
# 使用 helpers.bulk 函数将生成的数据批量插入到 Elasticsearch 中
# 该函数返回两个值:success 表示成功插入的文档数量,failed 表示插入失败的文档数量
success, failed = helpers.bulk(# es_client 是 Elasticsearch 客户端实例,用于与 Elasticsearch 服务器进行通信# 这里假设 es_client 已经在代码的其他部分正确初始化es_client,# gen_data() 是前面定义的生成器函数,用于提供要插入的数据gen_data(),# chunk_size 指定每一批次插入的文档数量# 这里设置为 2000,意味着每次批量插入 2000 条文档chunk_size=2000,# max_retries 指定插入失败时的最大重试次数# 如果某一批次的插入操作失败,会尝试重新插入,最多重试 3 次max_retries=3,# initial_backoff 指定重试等待的基数(单位:秒)# 第一次重试前会等待 2 秒,之后每次重试的等待时间会根据一定规则递增initial_backoff=2,# request_timeout 指定单批插入操作的超时时间(单位:秒)# 如果某一批次的插入操作在 120 秒内没有完成,会被视为超时request_timeout=120
)

2.2 服务端关键参数

# elasticsearch.yml 调优项
# 批量操作线程池队列大小(控制并发写入能力)
thread_pool.bulk.queue_size: 2000     # 默认200易满
# ▶ 作用:设置批量操作(如 bulk API)的请求队列容量
# ▶ 调优:从默认200提升至2000,适应高并发批量写入场景(如日志采集、数据迁移)
# ▶ 场景:当写入量超过线程池处理能力时,队列可暂存请求(避免立即报错)
# ▶ 风险:过大可能导致内存溢出,需结合 heap size 调整(建议 ≤ 1/4 堆内存)# 索引内存缓冲区大小(影响文档刷新频率)
indices.memory.index_buffer_size: 20% # 堆内存占比
# ▶ 作用:控制每个索引的内存缓冲区占 JVM 堆的比例
# ▶ 调优:从默认10%提升至20%,增加单次刷新的文档数量(减少 I/O 次数)
# ▶ 机制:缓冲区满时触发 refresh(生成新的 segment)
# ▶ 场景:写入密集型业务(如实时日志、监控数据)# 索引刷新间隔(影响搜索可见性)
index.refresh_interval: 120s          # 刷新间隔
# ▶ 作用:控制 Lucene 索引的刷新频率(数据写入后对搜索可见的时间)
# ▶ 调优:从默认1s延长至120s,降低 refresh 频率(提升写入性能)
# ▶ 权衡:牺牲实时性(120s 后数据可搜索)换取更高吞吐量
# ▶ 场景:离线分析、批量导入等对实时性要求不高的场景# 事务日志持久化策略(平衡写入性能与数据安全)
index.translog.durability: async      # 异步写translog
# ▶ 作用:控制 translog(事务日志)的写入方式
# ▶ 模式:
#   - async(异步):写入内存后立即返回(最快,可能丢数据)
#   - request(同步):写入磁盘后返回(安全,性能低)
# ▶ 调优:异步模式提升写入速度(适合非关键数据或异步复制场景)
# ▶ 风险:节点宕机可能丢失最后一次 fsync 后的所有操作

3. 错误处理与容错设计

3.1 错误分类与处理策略

错误类型HTTP状态码典型原因重试策略
版本冲突409文档ID重复/版本号不匹配丢弃或合并文档
限流拒绝429线程池满/队列超限指数退避重试
分片未分配503节点故障/分片迁移中等待集群恢复后重试
语法错误400字段类型不匹配/JSON格式必须修复后重新提交

3.2 重试机制实现方案

在这里插入图片描述

3.2.1 重试参数计算公式

在这里插入图片描述

  • initial_backoff:初始退避时间(如 2 秒),建议设为 1-5 秒(平衡响应速度与服务器压力)。

  • retry_count:当前重试次数(从 0 开始),建议设为 30-120 秒(避免过长的等待时间)。

  • max_backoff:最大退避时间(如 60 秒),通过 max_backoff 防止间隔无限增长(如网络长期不可达时)。

  • 推荐参数组合:

    场景initial_backoffmax_backoff最大重试次
    网络抖动1s10s3
    节点故障5s60s5
    集群维护30s300s
  • 对比其他退避策略
    在这里插入图片描述


4. 性能优化案例

4.1 日志采集系统调优

4.1.1 原始性能
  • 吞吐量:12,000 docs/sec
  • CPU利用率:75%
  • 主要瓶颈:小批量频繁提交
4.1.2 优化措施
    1. 批量大小从500调整至2000
    1. 启用gzip压缩(节省40%带宽)
    1. 客户端从同步改为异步模式
4.1.3 优化结果
指标优化前优化后提升幅度
吞吐量12k/s34k/s183%
CPU利用率75%88%-
网络包量520/s150/s-71%

4.2 电商订单数据同步

4.2.1 挑战
  • 数据突增:大促期间写入量增长20倍
  • 时效要求:95%数据需在5分钟内入ES
4.2.2 解决方案

在这里插入图片描述

4.2.3 效果验证
压力等级平均延迟写入成功率系统负载
日常2.1s99.98%45%
大促8.7s99.83%91%

5. 监控与问题诊断

5.1 关键监控指标

指标名称计算公式健康阈值告警策略
Bulk队列等待时间thread_pool.bulk.queue<1000持续>500告警
写入拒绝率bulk.rejected / bulk.total<0.1%>1%立即告警
JVM Old GC频率jvm.gc.old.count<5次/分钟>10次/分钟告警

5.2 性能问题排查流程

在这里插入图片描述


6. 进阶优化策略

6.1 硬件级优化

硬件组件优化方向预期收益成本评估
CPU高频核心(3.6GHz+)提升15%-20%$$$
内存保持50%空闲内存减少GC暂停$$
磁盘NVMe SSD RAID0降低50% IO延迟$$$$
网络25Gbps RDMA减少30%延迟$$$$$

6.2 数据建模优化

  • 分片策略按时间范围分片(hot-warm架构)
  • 字段设计禁用 _all 字段,限制 nested 对象
  • 索引模板:预定义字段类型,避免动态映射

  • 关键结论
    • 通过合理配置批量大小(建议5-15MB)、实施指数退避重试策略、配合服务端线程池调优,可提升Bulk API吞吐量3-5倍
    • 在极端场景下,采用Kafka等中间件作为缓冲层 !!!,可确保系统弹性。持续的监控与硬件优化可将性能推向理论极限。

相关文章:

【实战ES】实战 Elasticsearch:快速上手与深度实践-2.2.1 Bulk API的正确使用与错误处理

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 Elasticsearch Bulk API 深度实践&#xff1a;性能调优与容错设计1. Bulk API 核心机制解析1.1 批量写入原理剖析1.1.1 各阶段性能瓶颈 2. 高性能批量写入实践2.1 客户端最佳…...

Oracle 23ai Vector Search 系列之2 ONNX(Open Neural Network Exchange)

文章目录 Oracle 23ai Vector Search 系列之2 ONNX(Open Neural Network Exchange)ONNX基本概念ONNX(Open Neural Network Exchange)ONNX Runtime ONNX Runtime 在Oracle数据库中的集成参考 Windows 环境图形化安装 Oracle 23ai Oracle 23ai Vector Search 系列之1 架构基础 Or…...

前端 - ts - - declare声明类型

在使用typeScript的项目中 需要声明属性类型 单独的局部属性 可以直接在当前文件中声明 全局属性需要在项目根目录下新建.d.ts文件 vite会自动识别.d.ts类型文件 在该文件中使用declare声明类型有三种写法 1、在某种类型的文件中声明 2、声明window上的属性类型 3、全局声明…...

Processor System Reset IP 核 v5.0(vivado)

这个IP的作用&#xff0c;我的理解是&#xff0c;比普通按键复位更加高效灵活&#xff0c;可以配置多个复位输出&#xff0c;可以配置复位周期。 1、输入信号&#xff1a; 重要的信号有时钟clk信号&#xff0c;一般连接到系统时钟&#xff1b;输入复位信号&#xff0c;一般是外…...

基于dify平台批量分析excel格式信息

如何以表格形式批量输入一些信息&#xff0c;然后让大模型以对话应用形式逐条进行推理分析&#xff1f; 这里提供一个分步解决方案&#xff0c;结合 Dify平台功能 和 API调用优化 的思路&#xff0c;既保证效率又降低复杂度&#xff1a; 1. 优先检查 Dify 的「数据集」功能 Di…...

GMII 接口

文章目录 概述硬件拓扑GMII 接口站管理接口发送数据时序接收数据时序参考 本文为笔者学习以太网对网上资料归纳整理所做的笔记&#xff0c;文末均附有参考链接&#xff0c;如侵权&#xff0c;请联系删除。 概述 GMII 是千兆网的MII接口&#xff0c;这个也有相应的 RGMII 接口&…...

学习不同电脑cpu分类及选购指南

关于电脑cpu 一、CPU型号的核心组成与命名规则Intel命名规则:AMD命名规则:5. 后缀:Intel常见后缀及其含义:AMD后缀一些常见的后缀及其含义:二、主流品牌CPU的分类与性能差异三、区分CPU型号的实用方法四、主流品牌CPU对比与选择建议五、选购CPU的注意事项关于不同主流CPU的…...

Android 动态设置默认Launcher(默认应用 电话-短信-浏览器-主屏幕应用))

Android 动态设置默认Launcher(默认应用 电话-短信-浏览器-主屏幕应用&#xff09;) 文章目录 场景需求参考资料思路期待效果 实现方案源码流程分析和思路实现DefaultAppActivityHandheldDefaultAppFragmentHandheldDefaultAppPreferenceFragmentDefaultAppChildFragmentDefaul…...

23种设计模式-策略(Strategy)设计模式

策略设计模式 &#x1f6a9;什么是策略设计模式&#xff1f;&#x1f6a9;策略设计模式的特点&#x1f6a9;策略设计模式的结构&#x1f6a9;策略设计模式的优缺点&#x1f6a9;策略设计模式的Java实现&#x1f6a9;代码总结&#x1f6a9;总结 &#x1f6a9;什么是策略设计模式…...

游戏引擎学习第188天

回顾并计划今天的内容 原本这周的目标是进行可视化操作的尝试&#xff0c;但每一天都被一些棘手的bug和问题所阻碍&#xff0c;导致我们一直没能实现这个目标。直到今天&#xff0c;星期四&#xff0c;我们终于解决了这些问题&#xff0c;所有功能都能正常运行了&#xff0c;所…...

TF-IDF——自然语言处理——红楼梦案例

目录 一、红楼梦数据分析 &#xff08;1&#xff09;红楼梦源文件 &#xff08;2&#xff09;数据预处理——分卷实现思路 &#xff08;3&#xff09;分卷代码 二、分卷处理&#xff0c;删除停用词&#xff0c;将文章转换为标准格式 1.实现的思路及细节 2.代码实现&#…...

Oracle数据库数据编程SQL<2.3 DML增、删、改及merge into>

目录 一、DML数据操纵语言&#xff08;Aate Manipulation Language) 二、【insert】插入数据 1、单行插入 2、批量插入 3、将数据同时插入到多张表insert all/insert first 三、【update】 更新数据 1、语法 2、举例 3、update使用注意事项&#xff1a; 四、【delete…...

面试计算机操作系统解析(一中)

判断 1. 一般来说&#xff0c;先进先出页面置换算法比最近最少使用页面置换算法有较少的缺页率。&#xff08;✘&#xff09; 正确答案&#xff1a;错误解释&#xff1a;FIFO&#xff08;先进先出&#xff09;页面置换算法可能导致“Belady异常”&#xff0c;即页面数增加反而…...

启山智软实现b2c单商户商城对比传统单商户的优势在哪里?

启山智软实现 B2C 单商户商城具有以下对比优势&#xff1a; 技术架构方面 先进的框架选型&#xff1a;基于 SpringCloud 等主流框架开发&#xff0c;是百万真实用户沉淀并检验的商城系统&#xff0c;技术成熟稳定&#xff0c;能应对高并发场景&#xff0c;保证系统在大流量访…...

蓝桥杯备考:贪心问题之均分纸牌

咱的贪心策略就是每次分好一个堆儿&#xff0c;如果某个堆已经是满足题意了&#xff0c;就不用管这个堆了&#xff0c;否则要向下一个堆借几个元素 #include <iostream> using namespace std; const int N 110; typedef long long ll; int a[N]; int n; ll x; int cnt…...

免去繁琐的手动埋点,Gin 框架可观测性最佳实践

作者&#xff1a;牧思 背景 在云原生时代的今天&#xff0c;Golang 编程语言越来越成为开发者们的首选&#xff0c;而对于 Golang 开发者来说&#xff0c;最著名的 Golang Web 框架莫过于 Gin [ 1] 框架了&#xff0c;Gin 框架作为 Golang 编程语言官方的推荐框架 [ 2] &…...

centos7 linux VMware虚拟机新添加的网卡,能看到网卡名称,但是看不到网卡的配置文件

问题现象&#xff1a;VMware虚拟机新添加的网卡&#xff0c;能看到网卡&#xff0c;但是看不到网卡的配置文件 解决方案&#xff1a; nmcli connection show nmcli connection add con-name ens36 ifname ens36 type ethernet #创建一个网卡连接配置文件&#xff0c;这里con…...

python的内置方法getitem和len

完整小测试&#xff1a; #python的内置函数&#xff0c;getitemclass Animal():def __init__(self,name):self.name namedef __str__(self):return f"This is {self.name}"class Zoo():def __init__(self,animal_list):self.animal_list animal_listdef __getite…...

深入理解 Git Stash:功能、用法与实战示例

文章目录 深入理解 Git Stash&#xff1a;功能、用法与实战示例一、Git Stash 的核心概念二、Git Stash 的基本用法1. 存储当前修改2. 查看 Stash 列表3. 恢复 Stash4. 恢复并删除 Stash5. 删除 Stash&#xff08;1&#xff09;删除指定 Stash&#xff08;2&#xff09;清空所有…...

SQL 复杂查询和性能优化

一、掌握复杂查询的核心技能 1. ​理解 SQL 执行顺序 SQL 语句的逻辑执行顺序&#xff08;非书写顺序&#xff09;&#xff1a; FROM → JOIN → WHERE → GROUP BY → HAVING → SELECT → DISTINCT → ORDER BY → LIMIT ​关键点&#xff1a;每一步的结果会传递给下一步&a…...

【web应用安全】关于web应用安全的几个主要问题的思考

文章目录 防重放攻击1. **Token机制&#xff08;一次性令牌&#xff09;**2. **时间戳 超时验证**3. **Nonce&#xff08;一次性随机数&#xff09;**4. **请求签名&#xff08;如HMAC&#xff09;**5. **HTTPS 安全Cookie**6. **幂等性设计****综合防御策略建议****注意事项…...

看懂roslunch输出

自编了一个demo 第一步&#xff1a;创建功能包 cd ~/catkin_ws/src catkin_create_pkg param_demo roscpp第二步&#xff1a;写 main.cpp 创建文件&#xff1a;param_demo/src/param_node.cpp #include <ros/ros.h> #include <string>int main(int argc, char*…...

如何查看Unity打包生成的ab文件

文章目录 前言AssetStudioab文件介绍1. 动态加载资源2. 资源分离与模块化3. 平台兼容性4. 资源压缩与加密5. 资源管理与更新6. 减少安装包大小7. 资源加载灵活性8. 资源打包与分发9. 实际应用场景10. 注意事项 总结 前言 问题来源于工作又回归到工作&#xff0c;当发现发布包里…...

从泛读到精读:合合信息文档解析如何让大模型更懂复杂文档

从泛读到精读&#xff1a;合合信息文档解析如何让大模型更懂复杂文档 一、引言&#xff1a;破解文档“理解力”瓶颈二、核心功能&#xff1a;合合信息的“破局”亮点功能亮点1&#xff1a;复杂图表的高精度解析图表解析&#xff1a;为大模型装上精准“标尺”表格数据精准还原 功…...

Python SciPy面试题及参考答案

目录 什么是 SciPy?它与 NumPy 有什么区别? 如何在 Python 中安装 SciPy? 如何导入 SciPy 库? SciPy 中有哪些子模块?简要介绍它们的功能。 如何使用 SciPy 进行数值积分?请举例说明。 SciPy 中提供了哪些求解微分方程的函数? 什么是插值?SciPy 中如何进行插值?…...

21.Excel自动化:如何使用 xlwings 进行编程

一 将Excel用作数据查看器 使用 xlwings 中的 view 函数。 1.导包 import datetime as dt import xlwings as xw import pandas as pd import numpy as np 2.view 函数 创建一个基于伪随机数的DataFrame&#xff0c;它有足够多的行&#xff0c;使得只有首尾几行会被显示。 df …...

【redis】数据类型之Stream

Redis Stream是Redis 5.0版本引入的一种新的数据类型&#xff0c;它提供了一种持久化的、可查询的、可扩展的消息队列服务。 它结合了Redis高性能的特性与持久化能力&#xff0c;支持&#xff1a; 多消费者组模式&#xff08;Consumer Groups&#xff09;消息回溯&#xff08…...

day17 周末两天偷懒没更新,今天炼丹加学习,完结STL常用容器部分

还剩下两个常用容器&#xff0c;一个是set(集合容器) &#xff0c; 一个是map容器 set/multiset 容器 set容器是关联式容器&#xff0c;该容器的特点是&#xff1a;所有元素都会在插入时被自动排序 set/multiset 都是关联式容器 &#xff0c;其底层结构是使用二叉树实现的。…...

嵌入式开发场景中Shell脚本执行方式的对比

‌Shell脚本执行方式对比表‌ ‌执行方式‌‌命令示例‌‌是否需要执行权限‌‌是否启动子Shell‌‌环境变量影响范围‌‌适用场景‌‌嵌入式开发中的典型应用‌‌直接执行脚本‌./script.sh是是子Shell内有效独立运行的脚本&#xff0c;需固定环境自动化构建脚本&#xff08;…...

数据结构之多项式相加的链表实现

在计算机科学中&#xff0c;多项式的表示和运算经常会用到。使用链表来表示多项式是一种常见且有效的方法&#xff0c;它可以方便地处理多项式的各项&#xff0c;并且在进行多项式相加等运算时具有较好的灵活性。 多项式通常由一系列的项组成&#xff0c;每一项包含一个系数和…...

Java 实现将Word 转换成markdown

日常的开发中&#xff0c;需要将word 等各类文章信息转换成格式化语言&#xff0c;因此需要使用各类语言将word 转换成Markdown 1、引入 jar包 <dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version&g…...

IEEE PDF Xpress校验出现 :字体无法嵌入问题以及pdf版本问题

文章目录 问题描述一、字体嵌入问题首先查看一下&#xff0c;哪些字体没有被嵌入查看window的font文件夹里的字体下载字体的网站修复字体嵌入问题 二、pdf版本不对 问题描述 在处理IEEE的camera ready的时候&#xff0c;提交到IEEE express的文件没有办法通过validate&#xf…...

Sa-Token

简介 Sa-Token 是一个轻量级 Java 权限认证框架&#xff0c;主要解决&#xff1a;登录认证、权限认证、单点登录、OAuth2.0、分布式Session会话、微服务网关鉴权 等一系列权限相关问题。 官方文档 常见功能 登录认证 本框架 用户提交 name password 参数&#xff0c;调用登…...

StarRocks 中 CURRENT_TIMESTAMP 和 CURRENT_TIME 分区过滤问题

背景 本文基于Starrocks 3.3.5 最近在进行Starrocks 跑数据的时候&#xff0c;发现了一个SQL 扫描了所有分区的数据&#xff0c;简化后的SQL如下&#xff1a; select date_created from tableA where date_createddate_format(current_time(), %Y-%m-%d %H:%i:%S) limit 20其…...

GithubPages+自定义域名+Cloudfare加速+浏览器收录(2025最新排坑)

前言 最近刷到一个小视频&#xff0c;讲述了选择域名选择的三宗罪&#xff0c;分别是 不要使用 .net&#xff0c;因为它价格贵&#xff0c;但是在顶级域名中的 SEO 效果却不是很好&#xff0c;也就是性价比很低不要使用 .cn&#xff0c;因为国外访问该网站可能会很慢&#xf…...

Canvas粒子系统终极指南:从基础运动到复杂交互的全流程实现

文章目录 一、粒子系统基础架构1.1 粒子数据结构设计1.2 粒子系统管理器 二、基础粒子效果实现2.1 重力场模拟2.2 弹性碰撞效果 三、高级交互实现3.1 鼠标吸引效果3.2 颜色渐变粒子 四、性能优化策略4.1 粒子池复用4.2 分层渲染 五、复杂效果实现5.1 烟花爆炸效果5.2 流体模拟 …...

【QT】新建QT工程(详细步骤)

新建QT工程 1.方法(1)点击new project按钮&#xff0c;弹出对话框&#xff0c;新建即可&#xff0c;步骤如下&#xff1a;(2) 点击文件菜单&#xff0c;选择新建文件或者工程&#xff0c;后续步骤如上 2.QT工程文件介绍(1).pro文件 --》QT工程配置文件(2)main.cpp --》QT工程主…...

详解Http:在QT中使用Http协议

目录 一、HTTP 概述 1、主要特点 2、HTTP 方法 3、HTTP 状态码 4、HTTP 头部 5、HTTP的工作原理 二、在Qt中使用HTTP 1、发送简单的HTTP请求 2、发送POST请求 3、处理异步请求 4、使用QSslConfiguration进行HTTPS 5、 处理JSON响应 6、处理错误 三、总结 一、HTTP…...

Next.js 中间件鉴权绕过漏洞 (CVE-2025-29927) 复现利用与原理分析

免责声明 本文所述漏洞复现方法仅供安全研究及授权测试使用&#xff1b; 任何个人/组织须在合法合规前提下实施&#xff0c;严禁用于非法目的&#xff1b; 作者不对任何滥用行为及后果负责&#xff0c;如发现新漏洞请及时联系厂商并遵循漏洞披露规则。 漏洞原理 Next.js 是一个…...

AI时代的数据底座:火山引擎多模态数据湖的设计与实践

资料来源&#xff1a;火山引擎-开发者社区 随着大模型的发展和应用&#xff0c;文本的边界被拓宽&#xff0c;图像、视频、语音各种模态涌现&#xff0c;并给数据管理、检索、计算带来巨大挑战。 火山引擎多模态数据湖 解决方案则可实现海量结构化、半结构化及非结构化数据的统…...

Numpy用法(二)

一.数组变维 1.1 reshape reshape() 可以改变数组维度&#xff0c;但是返回的是一个新的数组&#xff0c;原数组的形状不会被修改.reshape后产生的新数组是原数组的一个视图&#xff0c;即它与原数组共享相同的数据&#xff0c;但可以有不同的形状或维度&#xff0c;且对视图…...

STM32 IIC通信

目录 IIC简介硬件电路连接I2C时序基本单元IIC完整数据帧MPU6050封装硬件IIC内部电路 IIC简介 IIC&#xff08;Inter-Integrated Circuit&#xff09;是 IIC Bus 简称&#xff0c;中文叫集成电路总线。它是一种串行通信总线&#xff0c;使用多主从架构&#xff0c;由飞利浦公司…...

快速入门 JSON 数据格式

引言 JSON&#xff0c;全称 JavaScript Object Notion&#xff0c;类似于XML&#xff0c;YAML&#xff0c;Properties等&#xff0c;是一种数据交换格式&#xff0c;相比于XML&#xff0c;更简单&#xff0c;更轻量&#xff0c;更容易理解。 JSON vs XML 使用 JSON 目前被广…...

FFmpeg —— 中标麒麟系统下使用FFmpeg内核+Qt界面,制作完整功能音视频播放器(附:源码)

🔔 FFmpeg 相关音视频技术、疑难杂症文章合集(掌握后可自封大侠 ⓿_⓿)(记得收藏,持续更新中…) 程序运行效果...

硬件测试工装设计不合理的补救措施

硬件测试工装设计不合理的补救措施主要包括重新评估设计需求、优化工装结构、强化工装校准与验证。其中&#xff0c;优化工装结构尤其重要&#xff0c;通过结构优化能够有效解决因设计不合理导致的测试准确性下降和可靠性不足的问题。根据工程实践数据&#xff0c;经过优化结构…...

任意文件读取漏洞

fofa语句&#xff1a;body"/vite/client" /fs/etc/passwd?import&raw?? https://35.175.173.157/fs/etc/passwd?import&raw?? http://geometer.dev.mvergely.com/fs/etc/passwd?import&raw??...

如何使用RK平台的spi驱动 spidev

RK平台spidev驱动读取RC522版本号示例 1. 硬件与驱动确认 确认SPI接口连接&#xff1a;RC522的SPI引脚与RK开发板的对应SPI控制器正确连接&#xff08;CS、CLK、MOSI、MISO&#xff09;检查内核配置&#xff1a; Bash # 内核需启用以下配置 CONFIG_SPIy CONFIG_SPI_MASTERy…...

网路传输层UDP/TCP

一、端口号 1.端口号 1.1 五元组 端口号(port)标识了一个主机上进行通信的不同的应用程序. 如图所示, 在一个机器上运行着许多进程, 每个进程使用的应用层协议都不一样, 比如FTP, SSH, SMTP, HTTP等. 当主机接收到一个报文中, 网络层一定封装了一个目的ip标识我这台主机, …...

1.2-WAF\CDN\OSS\反向代理\负载均衡

WAF&#xff1a;就是网站应用防火墙&#xff0c;有硬件类、软件类、云WAF&#xff1b; 还有网站内置的WAF&#xff0c;内置的WAF就是直接嵌在代码中的安全防护代码 硬件类&#xff1a;Imperva、天清WAG 软件&#xff1a;安全狗、D盾、云锁 云&#xff1a;阿里云盾、腾讯云WA…...

Dify 服务器部署指南

1. 系统要求 在开始部署之前&#xff0c;请确保你的服务器满足以下要求&#xff1a; 操作系统&#xff1a;Linux&#xff08;推荐使用 Ubuntu 20.04 或更高版本&#xff09;内存&#xff1a;至少 4GB RAM存储&#xff1a;至少 20GB 可用空间网络&#xff1a;稳定的互联网连接…...