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

Zookeeper断开连接时分布式锁释放问题的解决方案

Zookeeper断开连接时分布式锁释放问题的解决方案

当Zookeeper客户端与服务器断开连接时,可能会导致分布式锁无法正常释放,这是分布式锁实现中需要重点解决的问题。以下是几种解决方案:

1. 利用Zookeeper临时节点的特性

核心原理:Zookeeper的临时节点(EPHEMERAL)会在客户端会话结束时自动删除

// 创建临时顺序节点
currentLock = zk.create(LOCK_ROOT + "/lock_", new byte[0], ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);

优点

  • 天然支持会话结束自动释放锁
  • 不需要额外的清理机制

缺点

  • 网络闪断可能导致锁被意外释放
  • 客户端可能不知道自己已经失去锁

2. 会话超时与重连机制

2.1 合理设置会话超时时间

// 创建Zookeeper客户端时设置合理的会话超时
private static final int SESSION_TIMEOUT = 30000;
zk = new ZooKeeper(zkServers, SESSION_TIMEOUT, this);

2.2 实现会话过期监听

@Override
public void process(WatchedEvent event) {if (event.getState() == Event.KeeperState.Expired) {// 会话过期,需要重新连接try {reconnect();} catch (Exception e) {e.printStackTrace();}}// 其他事件处理...
}private void reconnect() throws Exception {if (zk != null) {zk.close();}zk = new ZooKeeper(zkServers, SESSION_TIMEOUT, this);connectedLatch = new CountDownLatch(1);connectedLatch.await();
}

3. 锁的租约机制

实现一个心跳机制来维持锁的持有状态:

public class LeaseManager {private ScheduledExecutorService executor;private String lockPath;private ZooKeeper zk;public LeaseManager(ZooKeeper zk, String lockPath) {this.zk = zk;this.lockPath = lockPath;this.executor = Executors.newSingleThreadScheduledExecutor();}public void startLease() {executor.scheduleAtFixedRate(() -> {try {// 更新节点数据维持租约zk.setData(lockPath, new byte[0], -1);} catch (Exception e) {// 租约维持失败,可能是连接问题executor.shutdown();}}, 0, 10, TimeUnit.SECONDS); // 每10秒续租一次}public void stopLease() {executor.shutdown();}
}

4. 双重检测机制

在业务代码中增加锁状态检测:

public boolean doBusinessWithLock() {ZkDistributedLock lock = null;try {lock = new ZkDistributedLock(zkServers);if (lock.tryLock(5, TimeUnit.SECONDS)) {// 获取锁后再次检查锁节点是否存在Stat stat = zk.exists(lock.getCurrentLockPath(), false);if (stat == null) {// 锁节点已不存在,可能是会话过期导致return false;}// 执行业务逻辑return processBusiness();}return false;} catch (Exception e) {e.printStackTrace();return false;} finally {if (lock != null) {try {lock.unlock();} catch (Exception e) {e.printStackTrace();}}}
}

5. 使用Curator框架的解决方案

Apache Curator提供了更健壮的分布式锁实现:

public class CuratorLockExample {private CuratorFramework client;private InterProcessMutex lock;public CuratorLockExample(String zkServers) {RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3);client = CuratorFrameworkFactory.newClient(zkServers, retryPolicy);client.start();lock = new InterProcessMutex(client, "/lock_path");}public void doWork() {try {if (lock.acquire(10, TimeUnit.SECONDS)) {try {// 业务逻辑System.out.println("Doing work with lock");Thread.sleep(5000);} finally {lock.release();}}} catch (Exception e) {e.printStackTrace();}}// Curator会自动处理连接问题,内置了重试机制
}

6. 锁的监控与告警机制

实现锁状态的监控系统:

public class LockMonitor {private ZooKeeper zk;private String monitorPath;public LockMonitor(String zkServers, String lockPath) throws Exception {this.zk = new ZooKeeper(zkServers, 30000, this);this.monitorPath = lockPath;monitorLocks();}private void monitorLocks() {// 定期检查锁状态ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();executor.scheduleAtFixedRate(() -> {try {List<String> locks = zk.getChildren(monitorPath, false);for (String lock : locks) {Stat stat = zk.exists(monitorPath + "/" + lock, false);long duration = System.currentTimeMillis() - stat.getMtime();if (duration > 60000) { // 锁持有超过1分钟alertLongHoldingLock(lock, duration);}}} catch (Exception e) {e.printStackTrace();}}, 0, 30, TimeUnit.SECONDS);}private void alertLongHoldingLock(String lock, long duration) {// 发送告警通知System.err.println("警告: 锁 " + lock + " 已持有 " + duration + " 毫秒");}
}

7. 最佳实践总结

  1. 合理设置会话超时时间:根据网络环境和业务需求设置合适的超时时间
  2. 实现可靠的重连机制:确保连接断开后能自动恢复
  3. 使用临时节点:利用Zookeeper的临时节点特性自动清理失效锁
  4. 添加锁超时机制:在业务层面设置锁的最大持有时间
  5. 实现锁的监控:及时发现和处理异常锁
  6. 考虑使用Curator:成熟的框架通常比自行实现更可靠
  7. 设计幂等操作:确保锁失效后业务能安全重试

通过以上方法的组合使用,可以有效地解决Zookeeper断开连接时分布式锁的释放问题,提高分布式系统的可靠性。

相关文章:

Zookeeper断开连接时分布式锁释放问题的解决方案

Zookeeper断开连接时分布式锁释放问题的解决方案 当Zookeeper客户端与服务器断开连接时&#xff0c;可能会导致分布式锁无法正常释放&#xff0c;这是分布式锁实现中需要重点解决的问题。以下是几种解决方案&#xff1a; 1. 利用Zookeeper临时节点的特性 核心原理&#xff1…...

Nginx配置文件介绍

Nginx 的配置文件是模块化的&#xff0c;不同的配置文件承担着不同的功能&#xff0c;下面为你详细介绍常见的配置文件及其作用&#xff1a; 这些文件在/etc/nginx/目录下&#xff1a; 1、主配置文件 /etc/nginx/nginx.conf 是 Nginx 的核心配置文件&#xff0c;对全局参数进…...

新闻数据接口开发指南:从多源聚合到NLP摘要生成

随着人工智能&#xff08;AI&#xff09;技术的飞速发展&#xff0c;新闻行业也迎来了新的变革。AI不仅能够自动化生成新闻内容&#xff0c;还能通过智能推荐系统为用户提供个性化的新闻体验。万维易源提供的“新闻查询”API接口&#xff0c;结合了最新的AI技术&#xff0c;为开…...

【八股消消乐】发送请求有遇到服务不可用吗?如何解决?

&#x1f60a;你好&#xff0c;我是小航&#xff0c;一个正在变秃、变强的文艺倾年。 &#x1f514;本专栏《八股消消乐》旨在记录个人所背的八股文&#xff0c;包括Java/Go开发、Vue开发、系统架构、大模型开发、机器学习、深度学习、力扣算法等相关知识点&#xff0c;期待与你…...

【博通芯片方案】调试指令详解版一(无线)

前言 无线路由器的主流芯片方案包括,博通(BCM)、联发科(MTK)和高通等等。掌握常用的调试指令,有助于产品的测试以及故障排查。本系列文章将介绍博通芯片方案调试指令,欢迎有需要的朋友关注和分享。 无线 wl指令 查无线国家码 指令:wl -i wl1 country 说明:本系列文章…...

【Google Colab】利用unsloth针对医疗数据集进行大语言模型的快速微调(含跑通原代码)

【本文概述】 为了快速跑通&#xff0c;首先忽略算力等问题&#xff0c;使用google colab云端服务器&#xff0c;选择unsloth/DeepSeek-R1-Distill-Llama-8B大语言模型进行微调&#xff0c;微调参数只进行了简单的设置。 在微调的时候&#xff0c;实际说明colab对8B的模型微调…...

基于STM32、HAL库的ADS1255IDBR模数转换器ADC驱动程序设计

一、简介: ADS1255IDBR是德州仪器(TI)生产的一款高精度、低噪声、24位ΔΣ模数转换器(ADC),主要特性包括: 24位无丢失码分辨率 高达23位有效分辨率(ENOB) 数据速率可达30kSPS 低噪声: 2.5μV RMS (20SPS时) 可编程增益放大器(PGA): 1-64V/V 单/差分输入配置 内置自校准和系…...

T检验、F检验及样本容量计算学习总结

目录 〇、碎语一、假设检验1.1 两种错误1.2 z检验和t检验1.3 t检验1.3.1 单样本t检验1.3.2 配对样本t检验1.3.3 独立样本t检验1.4 方差齐性检验1.4 卡方检验二、样本容量的计算2.1 AB测试主要的两种应用场景2.2 绝对量的计算公式2.3 率的计算公式参考资料〇、碎语 听到最多的检…...

PDFMathTranslate:让数学公式在PDF翻译中不再痛苦

在日常的论文阅读、教材翻译中&#xff0c;我们经常会遇到一个极其恼人的问题&#xff1a;PDF里的数学公式翻译错乱。即使用上了各种强大的PDF翻译工具&#xff0c;公式依然可能被拆碎、误解&#xff0c;甚至丢失。针对这个痛点&#xff0c;PDFMathTranslate 应运而生。 本文将…...

Docker(二):docker常用命令

一、帮助命令 1、docker 帮助命令 命令说明docker version / docker -v查看docker的版本信息docker info查看docker详细信息docker --help / docker -h查看docker帮助命令&#xff0c;可以查看到相关的其他命令 二、Docker镜像命令 1、docker pull 从远程仓库docker hub 上拉…...

Missashe考研日记-day28

Missashe考研日记-day28 1 专业课408 学习时间&#xff1a;2h学习内容&#xff1a; 今天先是预习了OS关于虚拟内存管理的内容&#xff0c;然后听了一部分视频课&#xff0c;明天接着学。知识点回顾&#xff1a; 1.传统存储管理方式特征&#xff1a;一次性、驻留性。2.局部性原…...

基于esp32实现键值对存储读写c程序例程

在基于 ESP32 的系统中&#xff0c;我们可以使用 NVS&#xff08;Non-Volatile Storage&#xff0c;非易失性存储&#xff09;来实现系统配置参数的掉电存储和读写。NVS 是 ESP32 提供的一种存储机制&#xff0c;允许我们将键值对数据存储在闪存中&#xff0c;即使设备掉电&…...

半导体行业如何开展风险管理?有没有半导体风控案例参考?

近年来&#xff0c;供应链中断事件的频发&#xff0c;成了越来越多半导体人的噩梦&#xff1a; ❗ 地缘冲突引爆“氖气危机”&#xff0c;生产成本激增&#xff01; ❗ 关税政策反复&#xff0c;被迫调整全球供应链布局&#xff01; ❗ 自然灾害导致工厂停工&#xff0c;原材…...

使用 malloc 函数模拟开辟一个 3x5 的整型二维数组

在 C 语言中&#xff0c;二维数组是非常常见的数据结构&#xff0c;用于表示矩阵或者表格形式的数据。而在动态内存分配的情况下&#xff0c;我们通常使用 malloc 函数来为数组分配内存。这篇博客将介绍如何通过 malloc 动态分配一个 3x5 的整型二维数组&#xff0c;并且使用下…...

Github 热点项目 rowboat 一句话生成多AI智能体!5分钟搭建企业级智能工作流系统

今日高星项目推荐&#xff1a;rowboat凭借1705总星数成为智能协作工具黑马&#xff01;亮点速递&#xff1a;①自然语言秒变AI流水线——只需告诉它“帮外卖公司处理配送异常”&#xff0c;立刻生成多角色协作方案&#xff1b;②企业工具库即插即用&#xff0c;Python包HTTP接口…...

Redis05-进阶-主从

零、文章目录 Redis05-进阶-主从 1、搭建主从架构 &#xff08;1&#xff09;概述 单节点Redis的并发能力是有上限的&#xff0c;要进一步提高Redis的并发能力&#xff0c;就需要搭建主从集群&#xff0c;实现读写分离。 &#xff08;2&#xff09;集群概况 我们搭建的主从…...

rockermq多线程消费者配置

rockermq多线程消费者配置 增加消费者数量实现消费者consumer多线程消费 或是 task分布式部署&#xff0c;原理一样 都是增加 consumer数量&#xff0c;程序在多线程 处理的地方已经添加过 分布式redisson锁 保证数据在多线程下的唯一性。 配置 task.yml 配置文件 &#xff08…...

Spring框架的ObjectProvider用法-笔记

在Spring框架中&#xff0c;ObjectProvider 是一个用于灵活获取Bean实例的接口&#xff0c;它允许开发者以编程方式有条件地或可选地获取Bean&#xff0c;而无需强制依赖注入&#xff0c;避免在Bean不存在时启动失败。 1. ObjectProvider 的核心功能 ObjectProvider 是Spring…...

DigitalOcean推出Valkey托管缓存服务

今天我们激动地宣布推出DigitalOcean的Valkey托管缓存服务&#xff0c;这是我们全新的托管数据库服务&#xff0c;能够无缝替换托管缓存&#xff08;此前称为托管Redis&#xff09;。Valkey托管缓存服务在你一直依赖的功能基础上&#xff0c;还提供了增强工具来支持你的开发需求…...

如何通过挖掘需求、SEO优化及流量变现成功出海?探索互联网产品的盈利之道

挖掘需求&#xff0c;优化流量&#xff0c;实现变现&#xff1a;互联网出海产品的成功之路 在当今全球化的数字时代&#xff0c;越来越多的企业和个人选择将业务扩展到国际市场。这一趋势不仅为企业带来了新的增长机会&#xff0c;也为个人提供了通过互联网产品实现盈利的途径…...

ASP.NET图片盗链防护指南

图片盗链(Hotlinking)是指其他网站直接链接到你服务器上的图片资源,这会消耗你的带宽和服务器资源。以下是几种在ASP.NET中防止图片盗链的有效方法: 1. 使用URL重写模块(推荐) 在Web.config中配置URL重写规则: xml <system.webServer> <rewrite> …...

2025-4-25 情绪周期视角复盘(mini)

直接说结论&#xff0c;没有前戏哈&#xff0c;国芳集团这波消费的行情就相当于当时机器人大周期里的DS的一个补涨周期&#xff0c;那么红宝丽就是接替了中毅达的衣钵的趋势穿越龙&#xff0c;趋势穿越龙没有结束&#xff0c;仅仅是主升暂停&#xff0c;高位震荡&#xff0c;后…...

Java求职者面试:从Spring Boot到微服务的技术深度探索

场景&#xff1a;互联网大厂Java求职者面试 角色介绍&#xff1a; 面试官&#xff1a;技术精湛&#xff0c;负责把控面试质量。谢飞机&#xff1a;搞笑的程序员&#xff0c;偶尔能答对问题。 第一轮&#xff1a;基础知识 面试官&#xff1a;谢飞机&#xff0c;你能简要介绍…...

wsl(8) -- 图形界面

1. 前言 记录一些关于wsl2图形界面的事情。 2. x11-apps wsl2默认已支持图形界面&#xff0c;只是我们选择安装的wsl2 ubuntu发行版是非桌面的&#xff0c;其中没有集成桌面应用&#xff0c;Linux的桌面和windows不同&#xff0c;windows的桌面系统是内核的一部分&#xff0…...

socket套接字-UDP(中)

socket套接字-UDP&#xff08;上&#xff09;https://blog.csdn.net/Small_entreprene/article/details/147465441?fromshareblogdetail&sharetypeblogdetail&sharerId147465441&sharereferPC&sharesourceSmall_entreprene&sharefromfrom_link UDP服务器…...

Android源码编译命令详解

一、引言 先看下面几条指令,相信编译过Android源码的人都再熟悉不过的。 source setenv.sh lunch make -j8记得最初刚接触Android时,同事告诉我用上面的指令就可以编译Android源码,指令虽短但过几天就记不全或者忘记顺序,每次编译时还需要看看自己的云笔记,冰冷的指令总…...

AI 发展历史与关键里程碑_附AI 模型清单及典型应用场景以及物流自动化适合的模型选择

AI 发展历史与关键里程碑_附AI 模型清单及典型应用场景以及物流自动化适合的模型选择 下面分三部分进行介绍: 1. AI 发展历史与关键里程碑 1950 年:图灵测试 1950 年,艾伦图灵提出“图灵测试”(Turing Test),首次以可检验的方式讨论机器能否“思考”。# 图灵测试示意:…...

MVCC(多版本并发控制)

MVCC&#xff08;多版本并发控制&#xff09;是数据库实现高并发事务的核心技术之一&#xff0c;其核心是通过数据多版本解决读写冲突。以下从‌技术原理、实现细节、应用场景、优缺点‌四个方面深入解析。 ‌一、技术原理‌ 1. ‌核心思想‌ ‌数据多版本化‌&#xff1a;每…...

可以隐藏列的表格

今天积累一个可以隐藏列的表格的实现方法 需求&#xff1a; 表格中有一部分列可以隐藏&#xff0c;在列名右侧有一个复选框&#xff0c;点击勾选展示&#xff0c;否则隐藏另有一个小工具栏&#xff0c;其中有每一列对应的复选框&#xff0c;点击可以将隐藏的列再次展示 思路…...

学习MySQL的第十二天

夕阳西下 云霞满天 一、存储过程概述 1.1 理解 含义:存储过程的英文是 Stored Procedure。它的思想很简单,就是一组经过预先编译的SQL语句的封装。 执行过程:存储过程预先存储在MySQL服务器上,需要执行的时候,客户端只需要向服务器端发出调用存储过程的命令,服…...

用Python做有趣的AI项目4:AI 表情识别助手

本项目将使用 计算机视觉 CNN 模型来识别人脸表情&#xff0c;例如&#xff1a; 开心 &#x1f60a; | 生气 &#x1f620; | 悲伤 &#x1f622; | 惊讶 &#x1f632; | 厌恶 &#x1f612; | 害怕 &#x1f631; | 中性 &#x1f610; &#x1f9e0; 项目目标 实时摄像头…...

2005-2020年 各省-绿色信贷水平原始数据及测算

各省-绿色信贷水平原始数据及测算&#xff08;2005-2020年&#xff09;.ziphttps://download.csdn.net/download/2401_84585615/90259771 https://download.csdn.net/download/2401_84585615/90259771 绿色信贷是指金融机构向符合环保要求的企业或项目提供的贷款&#xff0c;旨…...

STM32F103_HAL库+寄存器学习笔记21 - CAN接收过滤器:CPU减负神器,提升系统效率的第一道防线

在STM32F103的CAN总线应用中&#xff0c;硬件过滤器&#xff08;Filter&#xff09;承担着关键角色。 本章将从寄存器层面深入剖析CAN接收过滤器的工作机制与配置方法&#xff0c;帮助理解如何高效筛选关键信息&#xff0c;减轻CPU负担。 通过合理使用过滤器&#xff0c;不仅能…...

java_基础Java 转义字符学习笔记

Java 转义字符学习笔记 在Java编程中&#xff0c;转义字符用于表示那些无法直接在代码中表示的字符。以下是一些常用的Java转义字符&#xff1a; \t - 制表符&#xff1a;用于实现对齐功能。\n - 换行符&#xff1a;用于在文本中换行。\ - 反斜杠&#xff1a;表示一个反斜杠字…...

JavaScript基础(七)之web APIs

第二部分:Web APIs 目录 第二部分:Web APIs 五、DOM-节点操作 5.1 日期对象 5.1.1 实例化 5.1.2 时间对象方法 5.1.3 时间戳 5.2 节点操作 5.2.1 DOM节点 5.2.2 查找节点 父节点查找: 子节点查找: 兄弟关系查找: 5.2.3 增加节点 创建节点 5.2.4 删除节点 …...

强化学习机器人路径规划——Sparrow复现

强化学习机器人路径规划——Sparrow-v1.1复现教程 Sparrow是一个开源的移动机器人路径规划模拟器,重视模拟速度和轻量化,使用DDQN强化学习方法进行训练。本文在其基础上,增加了绘制训练曲线教程,并给出了自制地图文件,以实现在自己的地图上进行训练。 模型示意图 源码地…...

怎样给MP3音频重命名?是时候管理下电脑中的音频文件名了

在处理大量音频文件时&#xff0c;给这些文件起一个有意义的名字可以帮助我们更高效地管理和查找所需的内容。通过使用专业的文件重命名工具如简鹿文件批量重命名工具&#xff0c;可以极大地简化这一过程。本文将详细介绍如何利用该工具对 MP3 音频文件进行重命名。 步骤一&am…...

【Nova UI】十二、打造组件库之按钮组件(上):迈向功能构建的关键一步

序言 在上一篇文章中&#xff0c;我们深入探索了 icon 组件从测试到全局注册的全过程&#x1f3af;&#xff0c;成功为其在项目中稳定运行筑牢了根基。此刻&#xff0c;组件库的建设之旅仍在继续&#xff0c;我们将目光聚焦于另一个关键组件 —— 按钮组件。按钮作为用户与界面…...

C++初阶-STL简介

目录 1.什么是STL 2.STL的版本 3.STL的六大组件 4.STL的重要性 4.1在笔试中 4.2在面试中 4.3.在公司中 5.如何学习STL 6.总结和之后的规划 1.什么是STL STL&#xff08;standard template library-标准模板库&#xff09;&#xff1b;是C标准库的重要组成部分&#xf…...

(最短路)洛谷 P6880 JOI2020 奥运公交 题解

题意 给定一个 n n n 点 m m m 边的有向图&#xff0c;每条边从 u u u 指向 v v v&#xff0c;经过这条边的代价为 c c c。点编号为 1 1 1 到 n n n&#xff0c;无自环。 我们可以翻转一条边&#xff0c;即让他从 u u u 指向 v v v 变为从 v v v 指向 u u u&#…...

动态规划算法题1

动态规划做题步骤 确定状态表示&#xff1a;dp表中某一个位置中的值所表示的含义就是状态表示根据状态表示推导状态转移方程&#xff1a;dp[i]等于什么状态转移方程就是什么&#xff0c;用之前或者之后的状态&#xff0c;推导出dp[i]的值初始化(防止越界)&#xff1a;根据状态…...

π0.5:带开放世界泛化的视觉-语言-动作模型

25年4月来自具身机器人创业公司 PI 公司的论文“π0.5: a Vision-Language-Action Model with Open-World Generalization”。 为了使机器人发挥作用&#xff0c;它们必须在实验室之外的现实世界中执行实际相关的任务。虽然视觉-语言-动作 (VLA) 模型在端到端机器人控制方面已…...

ESP32开发入门(四):ESP32-s3多串口开发实践

摘要 本文详细介绍ESP32-S3芯片的UART外设开发方法&#xff0c;涵盖UART0(默认调试串口)、UART1和UART2的配置与使用技巧&#xff0c;并提供完整示例代码&#xff0c;帮助开发者快速实现多设备串口通信。 一、ESP32-S3串口硬件资源 ESP32-S3芯片提供3个UART控制器&#xff1…...

树莓派学习专题<10>:使用V4L2驱动获取摄像头数据--申请和管理缓冲区

树莓派学习专题&#xff1c;10&#xff1e;&#xff1a;使用V4L2驱动获取摄像头数据--申请和管理缓冲区 1. 申请和管理缓冲区代码2. 代码解析3. 实测结果 1. 申请和管理缓冲区代码 /* 数据缓冲区 */ typedef struct tag_BufDesc {void *pvBufPtr ;size_t szBuf…...

Android10.0 Android.bp文件详解,以及内置app编写Android.bp文件

1.前言 在10.0的系统rom定制化开发中,在内置app的时候都是常用的用法,用Android.mk的常用,但是某些时候,会 使用Android.bp的方式来内置app,接下来就来使用常用的方式来写内置so aar jar等文件 2.Android.bp文件详解,以及内置app编写Android.bp文件的介绍 根据设计,An…...

git回退commit

在Git中回退提交(commit)主要有两种方法:使用 `git reset` 或 `git revert`,具体取决于是否需要保留提交历史或是否已推送到远程仓库。以下是详细步骤: 一、使用 `git reset`(适合本地未推送的提交) `git reset` 会移动分支的 HEAD 指针到指定提交,可选择是否保留修改。…...

arcpy列表函数的应用(4)

动态获取字段信息 在处理要素类或表时&#xff0c;可能需要动态获取字段信息&#xff0c;以便根据字段类型或名称进行特定操作。可以使用arcpy.ListFields()函数获取字段列表&#xff0c;并根据需要筛选字段。 示例&#xff1a; python # 获取指定要素类的所有字段 fields …...

02 业务流程架构

业务流程架构提供了自上而下的组织鸟瞰图&#xff0c;是业务流程的全景图。根据所采用的方法不同&#xff0c;有时被称为流程全景图或高层级流程图&#xff0c;提供了业务运营中所有业务流程的整体视图。 这样有助于理解企业内部各个业务流程之间的相互关系以及它们如何共同工…...

「Mac畅玩AIGC与多模态01」架构篇01 - 展示层到硬件层的架构总览

一、概述 AIGC&#xff08;AI Generated Content&#xff09;系统由多个结构层级组成&#xff0c;自上而下涵盖交互界面、API 通信、模型推理、计算框架、底层驱动与硬件支持。本篇梳理 AIGC 应用的六层体系结构&#xff0c;明确各组件在系统中的职责与上下游关系&#xff0c;…...

如何有效防止 SQL 注入攻击?

&#x1f512; 如何有效防止 SQL 注入攻击&#xff1f; SQL 注入&#xff08;SQL Injection&#xff09;是黑客通过构造恶意输入&#xff0c;篡改 SQL 查询语句的攻击方式。以下是 7 大防御策略&#xff0c;涵盖开发、测试和运维全流程。 ✅ 1. 使用参数化查询&#xff08;Pre…...