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

03-高并发写架构详解

高并发写架构详解一、知识概述高并发写场景常见于日志采集、订单创建、消息发送、数据上报等业务,核心挑战是如何高效处理海量写入请求,同时保证数据不丢失、系统不崩溃。核心指标:写入TPS:1万 - 100万+数据可靠性:99.999%写入延迟:P99 100ms典型特征:写多读少(或读写分离)数据持续涌入可容忍短延迟(异步处理)需要持久化保证二、知识点详细讲解2.1 异步写入架构2.1.1 消息队列缓冲┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │ Producer │ ───→ │ MQ │ ───→ │ Consumer │ │ (应用) │ │ (缓冲池) │ │ (写入DB) │ └──────────────┘ └──────────────┘ └──────────────┘ 同步写入 削峰填谷 异步落库 10ms 百万级 可控速率2.1.2 批量写入策略/** * 批量写入缓冲区 */@ComponentpublicclassBatchWriteBufferT{privatefinalBlockingQueueTbuffer;privatefinalintbatchSize;privatefinalintflushInterval;// msprivatefinalConsumerListTwriter;publicBatchWriteBuffer(intbufferSize,intbatchSize,intflushInterval,ConsumerListTwriter){this.buffer=newLinkedBlockingQueue(bufferSize);this.batchSize=batchSize;this.flushInterval=flushInterval;this.writer=writer;// 启动后台刷新线程startFlushThread();}/** * 添加数据(非阻塞) */publicbooleanadd(Titem){returnbuffer.offer(item);// 队列满则快速失败}/** * 后台定时刷新 */privatevoidstartFlushThread(){ScheduledExecutorServiceexecutor=Executors.newSingleThreadScheduledExecutor();executor.scheduleWithFixedDelay(()-{ListTbatch=newArrayList(batchSize);// 取出批量数据buffer.drainTo(batch,batchSize);if(!batch.isEmpty()){try{// 批量写入writer.accept(batch);}catch(Exceptione){log.error("批量写入失败",e);// 失败重试或持久化到本地handleFailure(batch);}}},flushInterval,flushInterval,TimeUnit.MILLISECONDS);}}// 使用示例@BeanpublicBatchWriteBufferOrderorderWriteBuffer(OrderServiceorderService){returnnewBatchWriteBuffer(100000,// 缓冲区大小1000,// 批次大小1000,// 刷新间隔 1秒orderService::batchInsert);}2.2 分库分表写入2.2.1 写入路由策略/** * 分库分表写入服务 */@ServicepublicclassShardingWriteService{@AutowiredprivateListDataSourcedataSources;// 多数据源/** * 路由算法 */privateintrouteToDb(LongshardingKey,intdbCount){returnMath.abs(shardingKey.hashCode())%dbCount;}/** * 插入订单 */publicvoidinsertOrder(Orderorder){intdbIndex=routeToDb(order.getUserId(),dataSources.size());DataSourceds=dataSources.get(dbIndex);try(Connectionconn=ds.getConnection()){Stringsql="INSERT INTO t_order VALUES(?,?,?,?,?)";try(PreparedStatementps=conn.prepareStatement(sql)){ps.setLong(1,order.getId());ps.setLong(2,order.getUserId());ps.setBigDecimal(3,order.getAmount());ps.setInt(4,order.getStatus());ps.setTimestamp(5,newTimestamp(order.getCreateTime().getTime()));ps.executeUpdate();}}catch(SQLExceptione){log.error("插入订单失败",e);thrownewRuntimeException("数据库写入失败",e);}}/** * 批量插入 */publicvoidbatchInsert(ListOrderorders){// 按库分组MapInteger,ListOrdergroupedOrders=orders.stream().collect(Collectors.groupingBy(o-routeToDb(o.getUserId(),dataSources.size())));// 并行写入各库groupedOrders.parallelStream().forEach(entry-{intdbIndex=entry.getKey();List

相关文章:

03-高并发写架构详解

高并发写架构详解 一、知识概述 高并发写场景常见于日志采集、订单创建、消息发送、数据上报等业务,核心挑战是如何高效处理海量写入请求,同时保证数据不丢失、系统不崩溃。 核心指标: 写入TPS:1万 - 100万+ 数据可靠性:99.999% 写入延迟:P99 < 100ms 典型特征: 写…...

基于领航者人工势场法的队形变化避障控制及Matlab代码仿真:路径规划、拓扑结构与集群编队控制算法

基于领航者人工势场法的队形变化避障控制matlab代码仿真&#xff0c;路径规划&#xff0c;改进人工势场法&#xff0c;拓扑结构&#xff0c;集群&#xff0c;变换队形&#xff0c;基于领航者与人工势场法相结合的编队控制算法&#xff0c;可随意变换队形 增加机器人个数一、代码…...

智能驾驶中的环境感知与决策控制

智能驾驶中的环境感知与决策控制 随着人工智能和传感器技术的飞速发展&#xff0c;智能驾驶正逐步从实验室走向现实道路。环境感知与决策控制是智能驾驶系统的核心&#xff0c;它们决定了车辆能否安全、高效地行驶。环境感知负责识别周围车辆、行人、交通标志等信息&#xff0…...

ROSCO-OpenFAST联合仿真避坑实录:从.dll编译到Paraview动画,手把手解决路径与版本报错

ROSCO-OpenFAST联合仿真全流程排障指南&#xff1a;从.dll编译到可视化实战 第一次接触ROSCO-OpenFAST联合仿真时&#xff0c;那些看似简单的路径配置和版本匹配问题&#xff0c;往往能让最有经验的工程师也抓狂。记得去年帮团队调试一个5MW风机模型时&#xff0c;光是解决32位…...

FAST-LIO 实战:从 LI-Init 标定到 YAML 配置全解析

1. FAST-LIO 与 LI-Init 标定基础 FAST-LIO 是近年来激光雷达 SLAM 领域的热门算法&#xff0c;它以计算效率高、鲁棒性强著称。但要让 FAST-LIO 在实际项目中发挥最佳性能&#xff0c;LI-Init 标定是绕不开的第一步。所谓 LI-Init&#xff0c;就是激光雷达&#xff08;Lidar&a…...

PCIe带宽计算实战:从Gen1到Gen4,手把手教你算清吞吐量(含编码方案解析)

PCIe带宽计算实战&#xff1a;从Gen1到Gen4的吞吐量精算指南 刚接手服务器主板设计时&#xff0c;我曾被PCIe带宽计算坑得不轻——明明理论速率写着32GT/s&#xff0c;实测却只有25GB/s。后来才发现是编码方案和双工模式的"隐藏扣费"在作祟。本文将用电路板级的实战经…...

S32DS中集成RTD 扩展包

S32系列MCU在进行软件开发时&#xff0c;我们可以选择使用S32DS的IDE开发环境&#xff0c;在使用的时候我们通常还需要RTD的包&#xff0c;那么如何把RTD的扩展包集成到S32DS中呢&#xff0c;今天我们就来详细的说明一下这个步骤&#xff0c;方便大家参考。 首先在下载安装包的…...

MySQL升级后如何处理加密字段迁移_确保密钥与解密算法一致

MySQL升级后AES_DECRYPT返回NULL的直接原因是密钥长度、填充方式或字符集不匹配导致解密校验失败&#xff1b;需检查旧库字段字符集、显式定义VARBINARY/BLOB类型、统一AES-128密钥长度、指定加密模式并管理IV、客户端连接设binary字符集。MySQL升级后AES_DECRYPT返回NULL怎么办…...

433MHz模块信号波形全解析:用示波器实测教你区分24位与32位编码

433MHz无线信号解码实战&#xff1a;从波形捕获到协议逆向全指南 当你面对一堆未知协议的433MHz遥控设备时&#xff0c;是否曾感到无从下手&#xff1f;那些在空中传播的无线电波究竟携带了怎样的信息&#xff1f;本文将带你走进硬件调试的侦探世界&#xff0c;用示波器作为放大…...

大模型新手必看:收藏这份学习清单,轻松入门AI风口!

本文为AI大模型初学者提供了一份完整的学习清单&#xff0c;涵盖大模型基础认知、核心技术模块&#xff08;RAG、Prompt工程、Agent开发&#xff09;、开发基础能力、应用场景开发、项目落地流程及面试求职冲刺等六大模块。文章强调实践的重要性&#xff0c;建议新手先利用业余…...

MaterialFilePicker:解决Android文件选择痛点的3大实战模块

MaterialFilePicker&#xff1a;解决Android文件选择痛点的3大实战模块 【免费下载链接】MaterialFilePicker Picking files since 2015 项目地址: https://gitcode.com/gh_mirrors/ma/MaterialFilePicker 在Android应用开发中&#xff0c;文件选择功能是许多应用不可或…...

如何在画中画(PiP)模式下动态切换视频源

本文详解如何在不退出画中画模式的前提下&#xff0c;实时切换 PiP 窗口中播放的视频流——核心方法是直接更新 <video> 元素的 srcObject&#xff0c;并针对 Chrome/Safari 与 Firefox 的兼容性差异提供可落地的工程化方案。 本文详解如何在不退出画中画模式的前提…...

告别样板代码:用CommunityToolkit.MVVM简化你的WPF开发(最新版指南)

告别样板代码&#xff1a;用CommunityToolkit.MVVM重构WPF开发范式 当你在WPF项目中第20次手动实现INotifyPropertyChanged接口时&#xff0c;是否想过这种重复劳动正在吞噬宝贵的开发时间&#xff1f;MVVM模式虽优雅&#xff0c;但传统实现方式往往伴随着大量样板代码。这正是…...

GD32F105RBT6 IAP实战:手把手教你合并BootLoader与APP的bin文件(告别两次烧录)

GD32F105RBT6 IAP实战&#xff1a;从双文件烧录到单文件固件整合的终极方案 在嵌入式产品量产过程中&#xff0c;每次烧录都需要处理BootLoader和APP两个独立的bin文件&#xff0c;不仅效率低下&#xff0c;还增加了生产环节出错的风险。想象一下&#xff0c;当生产线需要烧录上…...

【2026年最新600套毕设项目分享】微信小程序的校园外卖平台(30049)

有需要的同学&#xff0c;源代码和配套文档领取&#xff0c;加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码&#xff08;前后端源代码SQL脚本&#xff09;配套文档&#xff08;LWPPT开题报告/任务书&#xff09;远程调试控屏包运行一键启动项目&…...

《温暖的客栈》林允做春味宴:这一锅腌笃鲜,鲜到心里去|珠海也能复刻

前几天刷到《温暖的客栈元气篇》第四期,林允带着蒋梦婕去南京高淳挖笋做春味宴。 说实话,作为一个在珠海待了多年的“老广”,我对江南的春天一直有种说不清的情愫。 明明从小吃的是白切鸡、煲仔饭这种实在货,却总在短视频里刷到那些“鲜”字当头的时令美味时,忍不住多看…...

芯片尺寸封装

芯片尺寸封装例题 以下那种封装形式是指芯片尺寸封装(A) A、CSP(Chip Scale Package) B、BGA(Ball Grid Array) C、SIP(System In Package) D、QFP(Plastic Quad Flat Package) CSP(芯片尺寸封装) Chip Scale Package, 即封装出来的芯片体积, 几乎和内部真实的硅晶圆裸片(Die)一…...

浏览器端HTML转DOCX解决方案:告别服务器依赖的文档生成革命

浏览器端HTML转DOCX解决方案&#xff1a;告别服务器依赖的文档生成革命 【免费下载链接】html-docx-js Converts HTML documents to DOCX in the browser 项目地址: https://gitcode.com/gh_mirrors/ht/html-docx-js 在当今数字化办公环境中&#xff0c;前端开发者经常面…...

PHP错误和异常如何处理_PHP错误与异常处理机制详解【详解】

PHP错误与异常本质不同&#xff1a;错误&#xff08;如E_WARNING&#xff09;默认不走异常流程&#xff0c;而异常必须try/catch捕获&#xff1b;set_error_handler仅捕获可恢复错误&#xff0c;无法处理Parse Error等致命错误&#xff1b;PHP 7可通过set_error_handler抛出Err…...

智能体市场生态:Agent Store 的未来形态

智能体市场生态&#xff1a;Agent Store 的未来形态摘要/引言 开门见山 2023年底&#xff0c;英伟达开发者大会上黄仁勋掏出一张写满了「AI Agent 是下一代操作系统核心」的便签纸演讲时&#xff0c;台下不少AI从业者只是把它当作“发布会PPT上的下一个万亿风口愿景”——就像当…...

YDFID-1色织物图像数据集终极指南:免费获取高质量纺织缺陷检测数据

YDFID-1色织物图像数据集终极指南&#xff1a;免费获取高质量纺织缺陷检测数据 【免费下载链接】YDFID-1 Yarn-dyed Fabric Image Dataset Version1. From Zhang Hongwei, Artificial Intelligence Research Group, Xi an Polytechnic University. 项目地址: https://gitcode…...

告别死记硬背!一张图+叠加定理,搞定所有集成运放信号运算电路分析

集成运放电路分析的黄金法则&#xff1a;叠加定理与拓扑思维 记得第一次接触集成运放电路时&#xff0c;我被各种比例、求和、积分电路搞得晕头转向。每个电路都有自己独特的公式&#xff0c;稍不留神就会混淆反相和同相的接法区别。直到某天实验室里&#xff0c;导师在黑板上画…...

脑机接口开发的终极解决方案:MetaBCI完整指南

脑机接口开发的终极解决方案&#xff1a;MetaBCI完整指南 【免费下载链接】MetaBCI MetaBCI: China’s first open-source platform for non-invasive brain computer interface. The project of MetaBCI is led by Prof. Minpeng Xu from Tianjin University, China. 项目地…...

如何查找SQL字符集中某位置_使用POSITION函数查询

POSITION函数返回子串首次出现位置&#xff08;从1开始&#xff09;&#xff0c;未找到返回0&#xff1b;标准写法为POSITION(sub IN str)&#xff0c;PostgreSQL/MySQL 8.0支持&#xff0c;旧版MySQL需用LOCATE&#xff1b;大小写敏感&#xff0c;跨库兼容性优于INSTR/CHARIND…...

职场高效神器:透明智能股票盯盘工具开发实战

1. 为什么职场人需要智能股票盯盘工具 早上9:30开盘时你正在开会&#xff0c;下午1:00休市前领导突然找你谈话——作为职场股民&#xff0c;这种时间冲突太常见了。传统炒股软件要么全屏遮挡工作内容&#xff0c;要么频繁切换窗口容易被发现。我去年就因为上班看盘被主管约谈&a…...

2026奇点智能技术大会AIAgent代码生成全链路复盘(含GitHub私有Repo脱敏数据+VS Code插件配置清单)

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AIAgent代码生成全景概览 2026奇点智能技术大会(https://ml-summit.org) 本届大会首次设立“AIAgent原生开发”主题展区&#xff0c;聚焦多模态提示理解、增量式代码合成、跨IDE运行时验证三大技术支柱。来自Google DeepM…...

学术PPT别再照搬论文了!哈佛教授建议的幻灯片制作心法(附时间分配表)

学术PPT别再照搬论文了&#xff01;哈佛教授建议的幻灯片制作心法&#xff08;附时间分配表&#xff09; 站在学术会议的演讲台上&#xff0c;面对满场期待的目光&#xff0c;你是否经历过这样的尴尬时刻——台下观众低头刷手机&#xff0c;偶尔抬头瞥一眼你的幻灯片&#xff0…...

AIAgent黑盒变透明:5步实现高可信度可解释架构设计(附NASA/医疗级验证标准)

第一章&#xff1a;AIAgent黑盒变透明&#xff1a;可解释性设计的范式革命 2026奇点智能技术大会(https://ml-summit.org) 传统AI代理&#xff08;AIAgent&#xff09;长期受限于“决策不可见、推理不可溯、错误不可修”的三重黑盒困境。当Agent在金融风控中否决一笔贷款、在医…...

2026奇点智能技术大会前瞻:为什么92%的搜索产品将在18个月内被淘汰?(AIAgent替代路径白皮书)

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AIAgent智能搜索 2026奇点智能技术大会(https://ml-summit.org) 核心能力演进 AIAgent智能搜索在2026大会上首次公开全栈式语义理解架构&#xff0c;支持跨模态上下文延续、多跳推理与自主工具调用。相比传统关键词匹配引…...

Ostrakon-VL扫描终端效果展示:货架巡检+价签解密真实案例

Ostrakon-VL扫描终端效果展示&#xff1a;货架巡检价签解密真实案例 1. 像素特工&#xff1a;零售场景的AI扫描利器 想象一下&#xff0c;你是一位超市经理&#xff0c;每天需要检查数百个货架的商品摆放和价签准确性。传统的人工巡检不仅耗时费力&#xff0c;还容易遗漏细节…...