架构思维:构建高并发扣减服务_分布式无主架构
文章目录
- Pre
- 无主架构的任务
- 简单实现
- 分布式无主架构
- 设计和实现扣减中的返还
- 什么是扣减的返还
- 返还实现原则
- 原则一:扣减完成才能返还
- 原则二:一次扣减可以多次返还
- 原则三:返还的总数量要小于等于原始扣减的数量
- 原则四:返还要保证幂等
- 总结
Pre
架构思维:构建随时可写的高可用写服务_利用缓存+数据库构建高可靠的扣减方案
架构思维:构建随时可写的高可用写服务_从分库分表到无状态存储架构
上面两篇博文中均使用了异步任务(Worker)来做无状态存储到正式业务库的数据同步。只涉及扣减的正向流程。但关于具体如何设计异步任务来保证高可用,以及如何设计任务的执行来保障执行的速度,避免产生任务积压,其实并没有过多介绍
无主架构的任务
简单实现
对于无状态存储集群的数据同步任务,最简单的做法是为每个分库启动一个自循环 Worker ,通过不断轮询 SQL 拉取未执行任务并标记完成。
select task_id,task_body,... from t_task where id>lastId and status='未执行' limit 一批数量 order by task_id
上述的流程虽然在功能上能够满足需求,但在高可用及性能上还是有一些不足:
-
扩展性差——任务量越大,单 Worker 无法水平扩容 . 如果任务库中任务特别多,上述单 Worker 单库的方式不具备扩展性,随着任务不断变多,会出现任务积压的瓶颈且无法通过扩容解决;
-
单点风险——Worker 宕机导致任务持续积压。单库单 Worker 的方式存在单点问题,在执行过程中,当 Worker 发生故障导致宕机,如果没有监控等机制发现故障,Worker 得不到执行,任务就会一直积压。
分布式无主架构
为了解决上述瓶颈,可采用“分布式无主架构”, 对单库多 Worker 并发执行并自动协调分区:
-
多实例并发:对每个分库启动 M 个 Worker 进程/容器,提升吞吐;
-
自助协调分区:每个 Worker 计算唯一哈希值并上报 etcd/ZooKeeper;
-
Watch 机制感知拓扑变化:Worker 订阅同库其他实例的哈希列表;
-
一致性 Hash 环分区:各实例根据哈希环负责自己的 ID 区间(见图3);
-
动态扩缩容:节点上下线迅速触发 Watch,重分区后新旧 Worker 自动调整执行范围。
对于上述两个问题,这里介绍一种可以提升任务执行速度,既具备扩展性、又能保障高可用的任务架构模式,如下图所示:
在上述的整体架构里,每个分库对应的 Worker 的执行流程都类似,因此在讲解时,只对一个分库的 Worker 进行分析,其余的可以以此类推。
首先为了提升性能和高可用,单个分库的执行 Worker 配置的是多个并发进行执行。
单个分库配置的多个任务在执行时使用自助协调,协调流程如下。
-
(1)每个 Worker 在启动时,会根据机器的 IP、随机数、当前时间戳等进行组合拼接计算一个唯一串,再在此基础上使用各种哈希工具计算一个无符号整形哈希值。
-
(2)所有的 Worker 会将自己的无符号整形哈希值上报到强一致的 etcd 或 ZooKeeper 存储集群里。
-
(3)etcd 等集群具备通知功能(Watch)。借助通知功能,所有的 Worker 都去订阅某一个分库下的其他 Worker 的哈希值,比如一个新的 Worker 启动了或者扩容新增了一个新的 Worker。
-
(4)每一个 Worker 都会获取到当前分库的所有其他 Worker 的哈希值。假设一个分库配置了四个 Worker,其中一个 Worker 会获取到自己及其他三个 Worker 的哈希值,假设为{200,300,500,800}。这四个 Worker 的 Hash 值便组成了一个环形区间,如下图
任务一致性 Hash 环
这个环形区间其实就类似一致性 Hash,每一个结点都代表一个 Worker,这个 Worker 负责任务编号在它区间范围内的任务的执行。
- (5)有了上述的哈希值列表后,就可以做任务分配了。如果当前 Worker 的哈希值为 300,那么当前 Worker 就处理任务 ID 在区间[200,300)里的值。比如哈希值为 200 的 Worker 则执行区间为[800,无穷大)和[0,200)的任务(即任务编号大于等于 800 和处在[0,200)区间内的任务),其他以此类推。区间处在[200,300)的 Worker 获取任务的 SQL 大致如下:
select * from task where id>=200 and id<300 and status='待执行' order by id limit 100;
通过上述方式,无论是某一台 Worker 发生故障还是新扩容一台 Worker,通过 etcd 和 ZK 的通知机制,所有的其他 Worker 都可以立马感知,并更新自己所负责的任务区间。
比如上述介绍的案例里,四个 Worker 代表 300 的那一个发生故障,整个哈希值列表就从{200,300,500,800}变成了{200,500,800},此时负责 500 的 Worker 就会执行[200,500)这个区间里的所有任务了,扩容 Worker 的流程和上述类似。
最后,在 Worker 扩缩容的间隙里,可能存在临界的并发情况,即两个 Worker 可能获取到同一条任务。对于此问题,可以从两点着手解决:
-
首先,任务执行需要保持幂等,即任务可重复执行,这个可以从业务上着手实现;
-
其次,可以给任务增加状态,如上述 SQL 里的 status 字段。当某一个 Worker 处理到该任务时,可以去修改该任务为处理中。其他 Worker 在获取任务时,显式指定状态,只处理为待执行的任务即可。
设计和实现扣减中的返还
什么是扣减的返还
扣减的返还指的是在扣减完成之后,业务上发生了一些逆向行为,导致原先已扣减的数据需要恢复以便供后续的扣减请求使用的场景。以在购买商品时的扣减库存举例,其中常见的逆向行为有:
当客户下单之后,发现某个商品买错了(商品品类买错或是数量填错),客户便会取消订单,此时该订单对应的所有商品的库存数量都需要返还;
其次,假设客户在收到订单后,发现其中某一个商品质量有问题或者商品的功能和预期有差异,便会发起订单售后流程,比如退、换货。此时该订单下被退货的商品,也需要单独进行库存返还。
返还实现原则
从上述的业务场景里可以看出,相比扣减而言, 返还的并发量比较低,因为下单完成后发生整单取消或者个别商品售后的情况概率较低。比如,对于热点商品或者爆品的抢购带来的扣减并发量是非常大的,但抢到爆品后再取消订单的概率是非常低的。此种场景里,扣减和返还的并发量的差距可能会达到上万倍。
因此,返还在实现上,可以参考商家对已有商品补货的实现,直接基于数据库进行落地。但返还自身也具备一些需要注意的实现原则,可以总结为以下几点。
原则一:扣减完成才能返还
返还接口在设计时,必须要有扣减号这个字段。因为所有的返还都是依托于扣减的,如果某一个商品的返还没有带上当时的扣减号,后续你很难对当时的情况做出准确判断。
-
当前商品是否能够返还。 因为没有扣减号,无法找到当时的扣减明细,无法判断此商品当时是否做了扣减,没有做扣减的商品是无法进行返还的。
-
当前返还的商品数量是否超过扣减值。假设外部系统因为异常,传入了一个超过当时扣减值的数量,如果不通过扣减号获取当时的扣减明细,你无法判断此类异常。
原则二:一次扣减可以多次返还
假设你购买的一个订单里包含了 A、B 两件商品,且这两个商品你各买了 5 件,在产生购买订单时即对应一次扣减。后续使用过程中可能会对某件不满的商品发起售后退货申请。极端情况下,可能会发生四次退货的行为,如:第一次,先退 2 个 A;第二次,再退 3 个 B;最后一次退货,一起将剩余的 3 个 A 和 2 个 B 退回。
由上述案例可以看出,一次扣减(即一个订单)在业务上可以对应多次返还。因此,在实现时需要考虑多次返还的场景。返还主要基于数据库实现,下面介绍下支持多次返还的数据库表的设计。
create table t_return{id bigint not null comment '自增主健',occupy_uuid bigint not null comment '扣减的ID',return_uuid bigint not null comment '返还的唯一ID',unique idx_return_uuid (occupy_uuid,return_uuid) comment '返还标识唯一索引'
}comment '返还记录表';
create table t_return_detail{id bigint not null comment '自增主健',return_uuid bigint not null comment '返还标识',sku_id bigint not null comment '返还的商品ID',num bigint not null comment '返还的商品数量',unique idx_return_sku (return_uuid,sku_id) comment '返还商品唯一标识'
}comment '返还商品记录表';
上述返还记录表实现了一次扣减多次返还的数据记录,返还商品记录表实现了一次返还里有多个商品的场景,也就是上述案例里的最后一次一起退了 A 和 B 两个商品的场景。
原则三:返还的总数量要小于等于原始扣减的数量
从业务上来看,这是一个必要条件。但在真正实现时,很容易出现处理遗漏。依然以“原则二”里的案例来讲解,在并发返还时,即同一时刻有两个返还请求,一个请求返还 2 个 A,另一个请求返还 4 个 A。如果技术上没有并发的时序控制,在处理两个请求时,有可能都判断为可返还并实际进行返还,最终就会出现返还 6 个 A(实际当时只扣减了 5 个)的超返还的场景。具体如下图 所示:
超返还的场景
对于上述潜在的风险,可以在返还前,对返还所属的扣减 ID 进行加锁来保证串行化操作,规避超卖的风险,架构如下图 所示:
加锁串行的架构
在扣减 ID 上加锁,会导致该扣减 ID 下的所有返还都串行执行,有一定的性能损耗。但从业务上看,同一个扣减 ID 并发产生返还的场景极低且返还的调用次数也相对较少,从“架构是技术与业务场景的取舍”这个角度来看,暂不需要花费太大的人力去构建一个更加复杂的加锁架构。
原则四:返还要保证幂等
最后,设计的返还接口需要支持幂等性。比如外部系统调用返还接口超时后,因为外部系统不知道是否调用成功,就会再一次重试。如果返还接口不满足幂等性要求,且上次超时实际是执行成功的,则会导致同一个返还号产生两次数据的返还。处理这个问题最简单的做法是:在返还接口增加返还编号(上述表结构中的 return_uuid)字段并由外部系统传入,通过数据库唯一索引来防重,进而实现幂等性,大致的架构如下图所示
幂等的返还架构图
总结
- 分布式无主架构 —— 如何通过一致性 Hash 与 Watch 机制实现高可用、可水平扩缩容的异步任务执行;
- 扣减返还设计 —— 四大原则保障数据正确性与幂等性
相关文章:
架构思维:构建高并发扣减服务_分布式无主架构
文章目录 Pre无主架构的任务简单实现分布式无主架构 设计和实现扣减中的返还什么是扣减的返还返还实现原则原则一:扣减完成才能返还原则二:一次扣减可以多次返还原则三:返还的总数量要小于等于原始扣减的数量原则四:返还要保证幂等…...
C++函数基础:定义与调用函数,参数传递(值传递、引用传递)详解
1. 引言 函数是C编程中的核心概念之一,它允许我们将代码模块化,提高代码的可读性、复用性和可维护性。本文将深入探讨: 函数的定义与调用参数传递方式(值传递 vs 引用传递)应用场景与最佳实践 2. 函数的定义与调用 …...
深入解析Python中的Vector2d类:从基础实现到特殊方法的应用
引言 在Python面向对象编程中,特殊方法(或称魔术方法)是实现对象丰富行为的关键。本文将以Vector2d类为例,详细讲解如何通过特殊方法为自定义类添加多种表示形式和操作能力。 Vector2d类的基本行为 Vector2d类是一个二维向量类…...
【25软考网工】第六章(7)网络安全防护系统
博客主页:christine-rr-CSDN博客 专栏主页:软考中级网络工程师笔记 大家好,我是christine-rr !目前《软考中级网络工程师》专栏已经更新三十多篇文章了,每篇笔记都包含详细的知识点,希望能帮助到你&#x…...
Mac下载bilibili视频
安装 安装 yt-dlp brew install yt-dlp安装FFmpeg 用于合并音视频流、转码等操作 brew install ffmpeg使用 下载单个视频 查看可用格式 yt-dlp -F --cookies-from-browser chrome "https://www.bilibili.com/video/BV15B4y1G7F3?spm_id_from333.788.recommend_more_vid…...
6个月Python学习计划:从入门到AI实战(前端开发者进阶指南)
作者:一名前端开发者的进阶日志 计划时长:6个月 每日学习时间:2小时 覆盖方向:Python基础、爬虫开发、数据分析、后端开发、人工智能、深度学习 📌 目录 学习目标总览每日时间分配建议第1月:Python基础与编…...
批量处理 Office 文档 高画质提取图片、视频、音频素材助手
各位办公小能手们!你们有没有遇到过想从 Office 文档里提取图片、音频和视频,却又搞得焦头烂额的情况?今天就给大家介绍一款超厉害的工具——OfficeImagesExtractor! 这货的核心功能那可真是杠杠的!首先是高画质提取&a…...
【甲方安全建设】Python 项目静态扫描工具 Bandit 安装使用详细教程
文章目录 一、工具简介二、工具特点1.聚焦安全漏洞检测2.灵活的扫描配置3.多场景适配4.轻量且社区活跃三、安装步骤四、使用方法场景1:扫描单个Python文件场景2:递归扫描整个项目目录五、结果解读六、总结一、工具简介 Bandit 是由Python官方推荐的静态代码分析工具(SAST)…...
【推荐】新准则下对照会计报表172个会计科目解释
序号 科目名称 对应的会计报表项目 序号 科目名称 对应的会计报表项目 一、资产类 二、负债类 1 1001 库存现金 货币资金 103 2001 短期借款 短期借款 2 1002 银行存款 货币资金 104 2101 交易性金融负债 易性金融负债 3 1012 其他货币资…...
IntelliJ IDEA设置编码集
在IntelliJ IDEA中设置Properties文件的编码格式,主要涉及以下步骤和注意事项: 1. 全局和项目编码设置 打开设置界面:File -> Settings -> Editor -> File Encodings。在Global Encoding和Project Encoding下拉菜单中均选择UT…...
类魔方 :多变组合,灵活复用
文章目录 一、类的基础1. 类的基本结构与语法1. 类的定义与实例化2. 成员变量(属性)3. 构造函数(Constructor)4. 成员方法 2. 访问修饰符1. 基本访问规则2. 子类对父类方法的重写3. 构造函数的访问修饰符4. 参数属性与继承总结 3.…...
支持多方式拼接图片的软件
软件介绍 本文介绍一款名为 PicMerger 的图片拼接软件。 拼接亮点 PicMerger 这款软件最大的亮点在于,它能够将不同分辨率的图片完美地拼接在一起。拼接时会自动以分辨率最小的图片为标准,操作十分方便。 拼接方式与设置 该软件支持横向和纵向的拼接…...
Qt音视频开发过程中一个疑难杂症的解决方法/ffmpeg中采集本地音频设备无法触发超时回调
一、前言 最近在做实时音视频通话的项目中,遇到一个神奇的问题,那就是用ffmpeg采集本地音频设备,当音频设备拔掉后,采集过程会卡死在av_read_frame函数中,尽管设置了超时时间,也设置了超时回调interrupt_c…...
Android studio Could not move temporary workspace
Android studio Could not move temporary workspace 在Window上运行AS出现Could not move temporary workspace报错方法一(有效)方法二方法三方法四总结 在Window上运行AS出现Could not move temporary workspace报错 Could not move temporary workspa…...
深度估计中为什么需要已知相机基线(known camera baseline)?
在计算机视觉和立体视觉的上下文中,“已知相机基线”(known camera baseline)的解释 1. 相机基线的定义 相机基线是指两个相机中心之间的距离。在立体视觉系统中,通常有两个相机(或一个相机在不同位置拍摄两张图像&a…...
Spring Cloud 技术实战
Spring Cloud 简介 Spring Cloud 是基于 Spring Boot 构建的微服务框架,提供了一套完整的微服务解决方案。它利用 Spring Boot 的开发便利性,并通过各种组件简化分布式系统的开发。 核心组件 Spring Cloud Netflix Eureka: 服务注册与发现Spring Clou…...
《云端共生体:Flutter与AR Cloud如何改写社交交互规则》
当Flutter遇上AR Cloud,一场关于社交应用跨设备增强现实内容共享与协作的变革正在悄然发生。 Flutter是谷歌推出的一款开源UI软件开发工具包,其最大的优势在于能够实现一套代码,多平台部署,涵盖iOS、Android、Web、Windows、macO…...
【数据结构】1-3 算法的时间复杂度
数据结构知识点合集:数据结构与算法 • 知识点 • 时间复杂度的定义 1、算法时间复杂度 事前预估算法时间开销T(n)与问题规模 n 的关系(T 表示 “time”) 2、语句频度 算法中语句的执行次数 对于以上算法,语句频度:…...
Science Robotics 封面论文:基于形态学开放式参数化的仿人灵巧手设计用于具身操作
人形机械手具有无与伦比的多功能性和精细运动技能,使其能够精确、有力和稳健地执行各种任务。在古生物学记录和动物王国中,我们看到了各种各样的替代手和驱动设计。了解形态学设计空间和由此产生的涌现行为不仅可以帮助我们理解灵巧的作用及其演变&#…...
Vue百日学习计划Day24-28天详细计划-Gemini版
总目标: 在 Day 24-27 熟练掌握 Vue.js 的各种模板语法,包括文本插值、属性绑定、条件渲染、列表渲染、事件处理和表单绑定,并能结合使用修饰符。 所需资源: Vue 3 官方文档 (模板语法): https://cn.vuejs.org/guide/essentials/template-syntax.htmlVu…...
C++_数据结构_哈希表(hash)实现
✨✨ 欢迎大家来到小伞的大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:C学习 小伞的主页:xiaosan_blog 制作不易!点个赞吧!!谢谢喵!&…...
elasticsearch kibana ik 各版本下载
https://release.infinilabs.com/analysis-ik/stable/或者 https://github.com/infinilabs/analysis-ik/releases...
Uniapp 与 Uniapp X 对比:新手上手指南及迁移到 Uniapp X 的注意事项
文章目录 前言一、Uniapp 与 Uniapp X 核心区别二、Uniapp X 的核心优势三、新手学习 Uniapp X 必备技能栈3.1 基础技能要求3.2 平台相关知识3.3 工具链掌握 四、从 Uniapp 迁移到 Uniapp X 的注意事项4.1 语法转换:4.2 组件替换:4.3 状态管理࿱…...
SQL性能分析
查看数据库操作频次 使用SHOW GLOBAL STATUS LIKE Com_______; 指令,能查看当前数据库的INSERT、UPDATE、DELETE、SELECT访问频次 。若以查询为主,需重点优化查询相关性能,如索引;若以增删改为主,可考虑事务处理、批量…...
CANoe测试应用案例之A2L
写在前面 本系列文章主要讲解CANoe测试应用案例之A2L的相关知识,希望能帮助更多的同学认识和了解CANoe测试。 若有相关问题,欢迎评论沟通,共同进步。(*^▽^*) CANoe Option AMD/XCP支持加载A2L到CANoe中,方便ECU内部变量在功能验…...
H2数据库源码学习+debug, 数据库 sql、数据库引擎、数据库存储从此不再神秘
一、源码结构概览 H2源码采用标准Maven结构,核心模块在src/main/org/h2目录下: ├── command/ # SQL解析与执行 ├── engine/ # 数据库引擎核心(会话、事务) ├── table/ # 表结构定义与操作 ├── index/ # 索引实现&am…...
PopSQL:一个支持团队协作的SQL开发工具
PopSQL 是一款专为团队协作设计的现代化 SQL 编辑器,通过通团队过协作编写 SQL 查询、交互式可视化以及共享结果提升数据分析和管理效率。 PopSQL 提供了基于 Web 的在线平台以及跨系统(Windows、macOS、Linux)的桌面应用,包括免费…...
tomcat查看状态页及调优信息
准备工作 先准备一台已经安装好tomcat的虚拟机,tomcat默认是状态页是默认被禁用的 1.添加授权用户 vim /usr/local/tomcat/conf/tomcat-users.xml22 <role rolename"manager-gui"/>23 <user username"admin" password"tomcat&q…...
贝塞尔曲线原理
文章目录 一、 低阶贝塞尔曲线1.一阶贝塞尔曲线2. 二阶贝塞尔曲线3. 三阶贝塞尔曲线 一、 低阶贝塞尔曲线 1.一阶贝塞尔曲线 如下图所示, P 0 P_0 P0, P 1 P_1 P1 是平面中的两点,则 B ( t ) B ( t ) B(t) 代表平面中的一段线段。…...
【MYSQL】笔记
📚 博主的专栏 🐧 Linux | 🖥️ C | 📊 数据结构 | 💡C 算法 | 🅒 C 语言 | 🌐 计算机网络 在ubuntu中,改配置文件: sudo nano /etc/mysql/mysql.conf.d/mysq…...
构建 TypoView:一个富文本样式预览工具的全流程记录
我正在参加CodeBuddy「首席试玩官」内容创作大赛,本文所使用的 CodeBuddy 免费下载链接:腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴 在一次和 CodeBuddy 的日常交流中,我提出了一个构想:能不能帮我从零构建一个富文本样式…...
使用conda创建python虚拟环境,并自定义路径
创建虚拟环境 conda create --prefixE:/ai-tools/Luoxuejiao/envs/Luo24 python3.8 此时虚拟环境没有名字,只有路径,下面将名字添加到配置中: conda config --append envs_dirs E:/ai-tools/Luoxuejiao/envs/...
【自然语言处理与大模型】向量数据库技术
向量数据库,是专门为向量检索设计的中间件! 高效存储、快速检索和管理高纬度向量数据的系统称为向量数据库 一、向量数据库是什么有什么用? 向量数据库是一种专门用于高效存储和检索高维向量数据的系统。它通过嵌入模型将各类非结构化数据&am…...
Java中的伪共享(False Sharing):隐藏的性能杀手与高并发优化实战
引言 在高性能Java应用中,开发者通常会关注锁竞争、GC频率等显性问题,但一个更隐蔽的陷阱——伪共享(False Sharing)——却可能让精心设计的并发代码性能骤降50%以上。伪共享是由CPU缓存架构引发的底层问题,常见于多…...
【数据结构】2-3-3单链表的查找
数据结构知识点合集 知识点 单链表的按位查找 GetElem(L,i):按位查找操作。获取表L中第i个位置的元素的值。 /*查找L中的第i个节点并返回*/ LNode *GetElm(LinkList L,int i) { /*位置不合法返回NULL*/ if(i<0) return NULL; /*p指向当前节…...
从0开始学linux韦东山教程第四章问题小结(1)
本人从0开始学习linux,使用的是韦东山的教程,在跟着课程学习的情况下的所遇到的问题的总结,理论虽枯燥但是是基础。说实在的越看视频越感觉他讲的有点乱后续将以他的新版PDF手册为中心,视频作为辅助理解的工具。参考手册为嵌入式Linux应用开发…...
TYUT-企业级开发教程-第三章
JAVAWEB的三大组件 在 Spring Boot 项目中,会自动将 Spring 容器中的 Servlet 、 Filter 、 Listener 实例注册为 Web 服务器中对应的组件。因此,可以将自定义的 Java Web 三大组件作为 Bean 添加到 Spring 容器中,以实现组件的注册。使用 S…...
【数据结构】2-3-2 单链表的插入删除
数据结构知识点合集 知识点 按位序插入带头节点链表 ListInsert(&L,i,e):插入操作。在表L中的第i个位置上插入指定元素e;找到第 i-1 个结点,将新结点插入其后 。 /*在带头节点的单链表L的第i个位置插入元素e*/ bool ListInsert(LinkList …...
spark-配置yarn模式
1.上传并解压spark-3.1.1-bin-hadoop3.2.tgz (/opt/software) 解压的命令是:tar -zxvf spark-3.3.1-bin-hadoop3.tgz -C /opt/module (cd /opt/software 进入software) 2.重命名 解压之后的目录为spark-yarn(原为spark-3.1.1-…...
鸿蒙系统电脑:开启智能办公新时代
鸿蒙系统电脑:开启智能办公新时代 引言 2025 年 5 月 8 日,华为正式推出了鸿蒙系统电脑,这款具有里程碑意义的产品,不仅彰显了华为在智能设备领域的创新实力,也为用户带来了全新的智能办公体验。在数字化转型加速的背…...
Ubuntu---omg又出bug了
自用遇到问题的合集 250518——桌面文件突然消失 ANS:参考博文...
COCO数据集神经网络性能现状2025.5.18
根据当前搜索结果,截至2025年5月,COCO数据集上性能最佳的神经网络模型及其关键参数如下: 1. D-FINE(中科大团队) 性能参数: 在COCO数据集上以78 FPS的速度实现了59.3%的平均精度(AP࿰…...
elementplus menu 设置 activeindex
<el-menu:default-active"defaultActive"> 更改当前激活的 index 可以 绑定:default-active"defaultActive" 改变 defaultActive 值 即会改变 index 但不会改变路径 watch(() > route.fullPath,(newPath: string) > {defaultActive.value…...
张 心理问题的分类以及解决流程
心理问题的分类以及解决流程 目录 心理问题的分类以及解决流程心理问题的分类**一、心理问题的分类与层次****1. 一般心理问题****2. 严重心理问题****3. 神经症性心理问题(神经症)****4. 精神障碍**轻度问题以心理咨询==判断:时间(3个月,1年,大于1年=神经质),社会功能(…...
网页 H5 微应用接入钉钉自动登录
ℹ️关于云审批 云审批(cloud approve) ,一款专为小微企业打造,支持多租户的在线审批神器。它简化了申请和审批流程,让您随时随地通过手机或电脑完成请款操作。员工一键提交申请,审批者即时响应,…...
接口——类比摄像
最近迷上了买相机,大疆Pocket、Insta Go3、大疆Mini3、佳能50D、vivo徕卡人像大师(狗头),在买配件的时候,发现1/4螺口简直是神中之神,这个万能接口让我想到计算机设计中的接口,遂有此篇—— 接…...
java每日精进 5.18【文件存储】
1.文件存储思路 支持将文件上传到三类存储器: 兼容 S3 协议的对象存储:支持 MinIO、腾讯云 COS、七牛云 Kodo、华为云 OBS、亚马逊 S3 等等。磁盘存储:本地、FTP 服务器、SFTP 服务器。数据库存储:MySQL、Oracle、PostgreSQL、S…...
LeetCode 394. 字符串解码详解:Java栈实现与逐行解析
文章目录 1. 问题描述2. 解决思路核心问题栈的应用遍历逻辑 3. 完整代码实现4. 关键代码解析处理右括号 ]处理嵌套的示例 5. 复杂度分析6. 总结 1. 问题描述 给定一个经过编码的字符串,要求将其解码为原始字符串。编码规则为 k[encoded_string],表示方括…...
基于STC89C52的红外遥控的电子密码锁设计与实现
一、引言 电子密码锁作为一种安全便捷的门禁系统,广泛应用于家庭、办公室等场景。结合红外遥控功能,可实现远程控制开锁,提升使用灵活性。本文基于 STC89C52 单片机,设计一种兼具密码输入和红外遥控的电子密码锁系统,详细阐述硬件选型、电路连接及软件实现方案。 二、硬…...
Android 性能优化入门(一)—— 数据结构优化
1、概述 一款 app 除了要有令人惊叹的功能和令人发指交互之外,在性能上也应该追求丝滑的要求,这样才能更好地提高用户体验: 优化目的性能指标优化的方向更快流畅性启动速度页面显示速度(显示和切换)响应速度更稳定稳定性避免出现 应用崩溃&…...