Java中的分布式(概念说明)
1. 分布式的基本概念
1.1 什么是分布式系统?
- 分布式系统(Distributed System):由多台服务器(或节点)协同工作,对外提供一个整体服务。
- 不同节点之间通过网络通信来协同处理请求或共享数据,相对于「单体应用」而言,可以带来更高的吞吐量、可用性和灵活扩展能力。
1.2 分布式 vs. 单体架构
-
单体架构
- 所有业务模块部署在同一应用实例中,垂直扩容(升级服务器硬件)成为主要的扩展方式。
- 优点:开发调试较简单,部署方便。
- 缺点:当应用规模过大时,任何一个模块出现故障或性能瓶颈,都会影响整个系统,并且无法灵活扩容单个模块。
-
分布式架构
- 将系统拆分成若干服务或节点,每个节点可以独立运行、独立扩容、独立维护。
- 优点:更好的可扩展性、可靠性,能处理更高并发和数据量。
- 缺点:系统变得复杂,需要处理 网络通信、数据一致性、运维管理 等问题。
1.3 分布式系统的核心挑战
- 数据一致性:多节点同时修改同一数据,如何保证最终数据正确?
- 可用性:某个节点失败不会影响整体服务。
- 可扩展性:需要随业务增长快速增加节点处理能力。
- 网络延迟与可靠性:网络抖动、分区故障等异常场景必须做好应对策略(如重试、降级)。
- 系统复杂度:日志监控、调试、部署都更加繁琐。
2. 分布式架构的主要组成部分
Spring Boot 下的分布式架构通常包含以下几个关键部分:
| 组件 | 作用 |
|---|---|
| 分布式服务(微服务) | 业务拆分,避免单体架构的复杂性 |
| 分布式缓存(Redis) | 提高查询性能,减少数据库压力 |
| 分布式锁(Redis/Zookeeper) | 解决多个节点同时修改数据的一致性问题 |
| 分布式事务(Seata) | 保障数据一致性,避免并发冲突 |
| 分布式消息队列(RabbitMQ/Kafka) | 异步处理任务,提升系统吞吐量 |
| 服务注册与发现(Nacos/Eureka) | 让服务可以自动发现彼此,不需要手动配置 |
| 分布式配置中心(Nacos/Spring Cloud Config) | 统一管理配置,提高可维护性 |
| 负载均衡(Nginx/Spring Cloud Gateway) | 把请求合理分配到多个服务实例 |
| 分布式任务调度(ElasticJob/Xxl-Job) | 让多个服务器协同执行定时任务 |
3. Spring Boot 分布式架构的实现方式
- Redis 提供缓存和分布式锁,提升性能
- Nacos/Eureka 让微服务可以互相发现
- MQ 让服务之间异步通信,减少耦合
- Seata 保证分布式事务一致性
- 负载均衡 + API 网关 让服务更高效
3.1 分布式服务(微服务)
- 含义:把一个庞大的单体应用拆分成若干个服务,每个服务只负责一个“相对独立的业务领域或功能”,称之为“微服务”。
- 示例:
UserService:专注处理用户登录、注册、用户信息管理OrderService:负责订单的创建、查询、支付信息对接ProductService:管理产品、库存、定价等PaymentService:处理支付渠道、账务、对账逻辑
- 示例:
- 好处:
- 解耦:每个服务都可独立部署、升级,互不影响。
- 独立扩展:哪块业务压力大就扩容对应服务的节点,而不是整合到一起。
- 技术栈灵活:不同服务甚至可以用不同的语言或框架。
在 Spring Boot 中如何实现微服务?
-
Spring Boot + Spring Cloud
- Spring Cloud 提供了微服务生态,包括:
- 服务注册与发现(Eureka, Nacos, Consul),让各微服务在一个注册中心上登记并获取彼此的地址
- 负载均衡(Ribbon 或 Spring Cloud LoadBalancer),在调用某个微服务时自动从多个实例中选一台
- 服务调用(Feign),通过 HTTP/REST 的方式去请求其他微服务
- 熔断、限流(Hystrix, Sentinel),在调用失效时防止雪崩
- 网关(Spring Cloud Gateway),统一处理路由、鉴权、流量控制
- Spring Cloud 提供了微服务生态,包括:
-
服务间通信方式
- HTTP/REST:最常见的形式,每个微服务暴露 RESTful API,其他微服务通过 HTTP 调用。
- RPC:部分场景需要高性能的调用,可以使用 RPC(例如 Dubbo、gRPC),减少网络开销,提升效率。
- 消息队列:如果是异步调用场景,还会结合 MQ 来实现解耦与异步化。
3.2 服务注册与发现(Service Discovery)
当我们有了多个微服务之后,问题来了:如何让它们相互找到对方?
- 传统做法:在配置文件里写死每个服务的地址。但一旦服务集群扩容或 IP 地址变动,就要重新修改配置,非常麻烦。
- 分布式做法:服务注册与发现。各个微服务在启动时,自动向“注册中心”报到,注册中心会保存当前可用的服务实例列表。其他服务要调用它时,只需要从注册中心查到目标服务的地址就行。
常见的注册中心:
- Eureka(Netflix OSS)
- Nacos(阿里巴巴开源,功能更强大,也能做配置中心)
- Zookeeper(Apache 基金会项目,也能做服务注册,但更多用于分布式协调)
在 Spring Boot + Spring Cloud 中配置服务注册发现,大致流程:
- 在
pom.xml中引入对应的依赖(例如spring-cloud-starter-alibaba-nacos-discovery)。 - 在
application.yml中配置好注册中心地址server-addr: localhost:8848等。 - 启动时,服务会自动注册到 Nacos(或其他注册中心)。
3.3 分布式配置中心
配置中心 主要解决的是“在分布式环境中,如何统一管理各个微服务的配置”,避免每个服务都各自持有不同的配置文件,难以维护。
- Spring Cloud Config:早期常用的配置中心,基于 Git 存储配置
- Nacos Config:Nacos 同时提供注册发现和配置管理
- Apollo(携程开源)或 Disconf 等也可以
好处:
- 统一管理:所有配置信息都在一个地方(配置中心),修改后可实时生效。
- 动态更新:微服务在运行时能监控到配置变动,自动刷新,无需重启。
- 区分环境:如 DEV, TEST, PROD 环境对应不同配置。
3.4 分布式缓存(Redis 等)
在分布式环境下,数据库通常成为性能瓶颈。为减少对数据库的直接访问和压力,需要一个 高性能的分布式缓存。Redis 是最常用的选择,它具有以下优势:
- 内存存储,读写速度快。
- 丰富的数据结构(字符串、哈希、列表、集合、有序集合等)。
- 支持 主从复制、Cluster 集群,适合分布式部署。
- 常用于 缓存热点数据、分布式 Session、分布式锁 等场景。
使用 Redis 的关键点:
- 设计 合理的缓存键(key),比如
product:detail:{productId}。 - 设置 过期时间,避免缓存数据与数据库数据长期不一致。
- 考虑 缓存穿透、缓存雪崩、缓存击穿 等问题,并进行对应的防护(如 Bloom Filter, 加互斥锁, 合理限流等)。
3.5 分布式锁
在分布式环境中,如果多个节点同时对同一个资源进行写操作,就容易出现数据不一致或并发冲突。因此,需要一种分布式锁来保证 在同一时间,只有一个节点可以获取锁,进行资源操作。
常见方案:
- Redis 分布式锁
- 使用
SETNX(set if not exist) +EXPIRE或SET key value NX PX time命令实现。 - 注意要设置超时时间,避免锁无法释放导致死锁。
- 也要考虑锁的续约和解锁时的原子性操作(Lua 脚本),以避免误删他人的锁。
- 使用
- Zookeeper 分布式锁
- 利用 ZK 的临时顺序节点来竞争锁,监听事件,一旦获取锁的节点断开连接,就自动删除节点,其他节点立即感知到并可重新竞争。
示例:基于 Redis 的简易分布式锁代码(示例性,不是完整生产级)
String lockKey = "lock:order";
String lockVal = UUID.randomUUID().toString();// 尝试加锁
Boolean success = redisTemplate.opsForValue().setIfAbsent(lockKey, lockVal, 10, TimeUnit.SECONDS);
if (Boolean.TRUE.equals(success)) {try {// 执行业务逻辑} finally {// 解锁时,先判断锁是否是自己加的String val = redisTemplate.opsForValue().get(lockKey);if (lockVal.equals(val)) {redisTemplate.delete(lockKey);}}
}
3.6 分布式事务
在单体应用中,事务只需要依赖数据库的本地事务(ACID)即可。但在分布式系统中,可能一个操作需要 跨多个微服务、跨多个数据库,这时就出现了 分布式事务 问题:
- 例如,在电商场景下,创建订单 时,要同时扣减库存、生成支付记录等,这些操作都在不同微服务里完成;如果其中某一步出错,就需要回滚之前的操作。
常见分布式事务方案:
- 2PC(两阶段提交):协调者告诉所有参与者先预提交,然后再统一提交或回滚。实现复杂,性能损耗大,适合对一致性要求极高的场景。
- TCC(Try-Confirm-Cancel):业务系统自己实现各个操作的 “Try, Confirm, Cancel”,实现灵活,但开发成本高。
- Seata:阿里开源的分布式事务框架,提供 AT 模式(对 JDBC 层做代理),也提供 TCC 等模式。
Seata 示例
@GlobalTransactional
public void placeOrder(Order order) {// 跨服务调用inventoryService.decreaseStock(order.getProductId(), order.getQuantity());paymentService.processPayment(order);orderMapper.insert(order);// Seata 会在这里把整个调用过程进行管理,可做到成功或回滚
}
在执行过程中,如果其中一个调用报错,Seata 就会通知其他服务进行回滚。
3.7 分布式消息队列
消息队列 (Message Queue) 用于解耦系统、异步处理和削峰填谷。常见的 MQ 方案有:
- RabbitMQ:轻量级,支持事务与确认机制,适合传统企业应用以及对消息可靠性要求高的场景。
- Apache Kafka:高吞吐,大规模数据流处理的“事实标准”,更多用于大数据、日志收集、流式处理等场景。
- RocketMQ:阿里开源的分布式消息中间件,和 Kafka 类似,也有较高的吞吐。
MQ 的作用:
- 解耦:比如,用户下单后,需要发送优惠券、通知物流、通知商家等,而如果所有这些操作都放在下单接口里,会导致耦合过高;使用 MQ,每个消费者服务负责监听消息并执行相应的业务逻辑。
- 削峰填谷:在高峰时段,订单系统可以快速写入消息队列,后台处理系统再慢慢消费,避免直接压垮数据库或其他服务。
- 异步:不需要同步等待消息处理完成,加快用户请求的响应速度。
3.8 API 网关与负载均衡
当服务拆分越来越多,我们往往需要一个统一的 网关 来管理请求:
- 服务网关(如 Spring Cloud Gateway、Nginx、Kong):
- 统一对外提供访问入口
- 进行路由分发,鉴权,限流,监控等
- 在微服务复杂时,可以屏蔽内部服务接口的变化,对外提供稳定的 API。
- 负载均衡:
- 当某个微服务有多个实例时,网关或负载均衡器需要把请求分散到各个实例上,避免其中一个实例被打满。
- 常见方式:Nginx 反向代理 或 Spring Cloud Ribbon (新版 Spring Cloud LoadBalancer)都可实现负载均衡。
四、整体流程与示例
4.1 典型电商微服务调用链
以 电商订单 流程为例,来看看分布式系统下的一般调用。
- 用户 访问 API 网关(或 Nginx),请求
/api/order/create接口。 - 网关解析路由规则,将请求转发给 OrderService。
- OrderService 调用 UserService 检查用户信息(比如积分、等级等)。
- OrderService 调用 ProductService 检查库存、扣减库存;同时查询商品价格。
- OrderService 写入订单数据库,本地事务或分布式事务处理。
- OrderService 向 MQ 发送消息,用于通知其他服务(如物流、积分系统等)。
- MQ 的消费者(如 LogisticsService)消费消息并执行下一步操作。
在这个过程中,会用到:
- 服务注册中心(保证 OrderService 能动态发现 ProductService 的地址)
- 分布式缓存(可能在 OrderService、ProductService 的查询环节做缓存)
- 分布式锁(避免多次重复扣减库存)
- 分布式事务(如要保证扣库存与下单一致)
- 消息队列(通知其他异步任务)
4.2 部署模式
- 开发/测试环境:一般都是在本地 Docker 或者虚拟机里把注册中心、MQ、Redis、数据库等组件跑起来即可。
- 生产环境:会把各个服务独立部署在多台服务器(或容器云)上:
- 注册中心、配置中心(Nacos/Consul/Eureka)集群
- Redis 高可用集群(主从+哨兵模式或 Redis Cluster)
- MQ 集群(RabbitMQ 集群或 Kafka 集群)
- 分布式文件系统(如 MinIO, FastDFS, OSS 等)
- 后端数据存储(MySQL 或者多分片数据库),需要做读写分离或分库分表
- 若干微服务集群(UserService、OrderService...),通过容器编排(Kubernetes 或 Docker Swarm)进行管理
相关文章:
Java中的分布式(概念说明)
1. 分布式的基本概念 1.1 什么是分布式系统? 分布式系统(Distributed System):由多台服务器(或节点)协同工作,对外提供一个整体服务。不同节点之间通过网络通信来协同处理请求或共享数据&…...
【1.8w字深入解析】从依赖地狱到依赖天堂:pnpm 如何革新前端包管理?
目录 前言npm 的诞生与发展嵌套依赖模型存在的问题npm3架构与yarnYarn 的诞生与局限Yarn 的诞生背景Yarn 仍然存在的问题 何为幽灵依赖依赖结构的不确定性pnpm王牌登场 -- 网状平铺结构安装包速度快依赖管理软链接 和 硬链接 机制 幽灵依赖产生的根本原因包管理工具的依赖解析机…...
【ISO 14229-1:2023 UDS诊断(ECU复位0x11服务)测试用例CAPL代码全解析⑤】
ISO 14229-1:2023 UDS诊断【ECU复位0x11服务】_TestCase05 作者:车端域控测试工程师 更新日期:2025年02月17日 关键词:UDS诊断协议、ECU复位服务、0x11服务、ISO 14229-1:2023 TC11-005测试用例 用例ID测试场景验证要点参考条款预期结果TC…...
137,【4】 buuctf web [SCTF2019]Flag Shop
进入靶场 都点击看看 发现点击work会增加¥ 但肯定不能一直点下去 抓包看看 这看起来是一个 JWT(JSON Web Token)字符串。JWT 通常由三部分组成,通过点(.)分隔,分别是头部(Header&…...
Node.js 异步并发控制:`p-map` 和 `p-limit` 的使用与对比
在 Node.js 中,处理异步任务是开发中非常常见的需求。无论是批量处理数据、调用外部 API,还是操作文件系统,我们经常需要对多个异步任务进行管理。然而,当任务数量较多时,如果不加以控制,并发可能会导致性能…...
【c++】c++内存管理
目录 c和c的内存分布回顾C语言动态管理内存的方式malloccallocreallocfree C动态管理内存的方式new和deleteoperator new和operator delete定位new c和c的内存分布 回顾C语言动态管理内存的方式 malloc void* malloc (size_t size);malloc可以在堆上开辟指定内存的空间&#…...
EtherNet/IP转Modbus TCP:新能源风电监控与分析实用案例
EtherNet/IP转Modbus TCP:新能源风电监控与分析实用案例 一、案例背景 在某新能源汽车电池生产线上,需要将采用EtherNet/IP协议的电池检测设备与采用ProfiNet协议的生产线控制系统进行集成,以实现对电池生产过程的全面监控和数据采集。 二、…...
伪装目标检测(Camouflaged Object Detection, COD)教程
1. 引言 伪装目标检测(Camouflaged Object Detection, COD)是一项计算机视觉任务,旨在识别和分割背景中难以察觉的目标,如动物伪装、隐形物体检测等。由于伪装目标通常与背景高度相似,这项任务比传统的目标检测更具挑…...
烧烤炉出口亚马逊欧盟站CE认证EN1860安全标准
什么是欧盟CE认证: 在欧盟市场“CE”标志属强制性认证标志,不论是欧盟内部企业生产的产品,还是其他国家生产的产品,要想在欧盟市场上自由流通,就必须加贴“CE”标志,以表明产品符合欧盟《技术协调与标准化新…...
动态DNS神器nip.io使用指南:快速实现域名与IP的动态映射--告别配置本地hosts
动态DNS神器nip.io使用指南:快速实现域名与IP的动态映射--告别配置本地hosts 一、项目简介二、快速入门三、进阶配置四、典型应用场景 本文基于开源项目 v1.2.1版本撰写,适用于开发测试、CI/CD等场景 一、项目简介 nip.io 是由Exentrique Solutions开发…...
人工智能 - 机器学习、深度学习、强化学习是人工智能领域的理论基础和方法论
机器学习、深度学习、强化学习是人工智能领域的三大核心方向,各自具有独特的理论基础和方法论。以下是它们的核心理论知识总结: 一、机器学习(Machine Learning, ML) 1. 基础概念 目标:通过数据驱动的方式,让机器从经验中学习规律,完成预测、分类或决策任务。 核心范式…...
数字电路-基础逻辑门实验
基础逻辑门是数字电路设计的核心元件,它们执行的是基本的逻辑运算。通过这些基本运算,可以构建出更为复杂的逻辑功能。常见的基础逻辑门包括与门(AND)、或门(OR)、非门(NOT)、异或门…...
国产编辑器EverEdit - 如虎添翼的功能:快速选择
1 快速选择 1.1 应用场景 快速选择适用于批量选择和修改的场景,比如:变量改名。 1.2 使用方法 1.2.1 逐项快速选择 将光标放置在单词前或单词中,选择主菜单查找 -> 快速选择 -> 快速选择或使用快捷键Ctrl D 注:光标放…...
国内外网络安全政策动态(2025年1月)
▶︎ 1.国家互联网信息办公室发布《个人信息出境个人信息保护认证办法(征求意见稿)》 1月3日,国家互联网信息办公室发布《个人信息出境个人信息保护认证办法(征求意见稿)》。根据《意见稿》,个人信息出境个…...
68页PDF | 数据安全总体解决方案:从数据管理方法论到落地实践的全方位指南(附下载)
一、前言 这份报告旨在应对数字化转型过程中数据安全面临的挑战,并提供全面的管理与技术体系建设框架。报告首先分析了数字化社会的发展背景,强调了数据安全在国家安全层面的重要性,并指出数据安全风险的来源和防护措施。接着,报…...
AI大模型的文本流如何持续吐到前端,实时通信的技术 SSE(Server-Sent Events) 认知
写在前面 没接触过 SSE(Server-Sent Events),AI大模型出来之后,一直以为文本流是用 WebSocket 做的偶然看到返回到报文格式是 text/event-stream,所以简单认知,整理笔记博文内容涉及 SSE 认知,以及对应的 D…...
Electron:使用electron-react-boilerplate创建一个react + electron的项目
使用 electron-react-boilerplate git clone --depth 1 --branch main https://github.com/electron-react-boilerplate/electron-react-boilerplate.git your-project-name cd your-project-name npm install npm start 安装不成功 在根目录加上 .npmrc文件 内容为 electron_…...
Spring Boot三:Springboot自动装配原理
精心整理了最新的面试资料,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 原理初探 pom.xml 核心依赖在父工程中 spring-boot-dependencies所有的jar包都在这里管理 我们在写或者引入一些依赖的时候,不需要指定版本 启动器 <…...
【ISO 14229-1:2023 UDS诊断全量测试用例清单系列:第十八节】
ISO 14229-1:2023 UDS诊断服务测试用例全解析(ResponseOnEvent_0x86服务) 作者:车端域控测试工程师 更新日期:2025年02月14日 关键词:UDS协议、0x86服务、事件响应、ISO 14229-1:2023、ECU测试 一、服务功能概述 0x86…...
Qt 中使用 SQLite 数据库的完整指南
SQLite 是一款轻量级、嵌入式的关系型数据库,无需独立的服务器进程,数据以文件形式存储,非常适合桌面和移动端应用的本地数据管理。Qt 通过 Qt SQL 模块提供了对 SQLite 的原生支持,开发者可以轻松实现数据库的增删改查、事务处理…...
2024 年 CSDN 博客之星年度评选:技术创作与影响力的碰撞(统计时间2025-02-17 11:06:06)
摘要:在技术的海洋里,每一位博主都像是一座独特的灯塔,用自己创作的光芒照亮他人前行的道路。2024 年 CSDN 博客之星年度评选活动,正是对这些灯塔的一次盛大检阅,让我们看到了众多优秀博主在技术创作领域的卓越表现以及…...
Java零基础入门笔记:(3)程序控制
前言 本笔记是学习狂神的java教程,建议配合视频,学习体验更佳。 【狂神说Java】Java零基础学习视频通俗易懂_哔哩哔哩_bilibili Scanner对象 之前我们学的基本语法中我们并没有实现程序和人的交互,但是Java给我们提供了这样一个工具类&…...
后端生成二维码,前端请求接口生成二维码并展示,且多个参数后边的参数没有正常传输问题处理
一、后端代码 1、controller GetMapping("/generateQRCode/{url}")ApiOperation(value "生成url链接二维码",notes "生成url链接二维码")public JsonResult<NewsQRCodeVo> generateQRCode(PathVariable String url,HttpServletRespons…...
(8/100)每日小游戏平台系列
项目地址位于:小游戏导航 新增一个打地鼠游戏! 打地鼠(Whack-a-Mole)是一款经典的休闲游戏,玩家需要点击随机出现的地鼠,以获取分数。游戏时间有限,玩家需要在规定时间内尽可能多地击中地鼠&am…...
【jar包启动命令简单分享】
最近在做springcloud项目,整理了下启停脚本 批量启动脚本 #!/bin/bashAPP_HOME/data/java/ APP_NAMES("ruoyi-auth.jar""ruoyi-gateway.jar""ruoyi-modules-file.jar""ruoyi-modules-gen.jar""ruoyi-modules-job.jar…...
[Python人工智能] 五十.PyTorch入门 (5)快速搭建神经网络及模型保存
从本专栏开始,作者正式研究Python深度学习、神经网络及人工智能相关知识。前文讲解PyTorch构建分类神经网络。这篇文章将介绍如何利用PyTorch快速构建神经网络,之前的代码比较复杂,通过自定义Net类实现,本文通过Torch函数定义神经网络。前面我们的Python人工智能主要以Tens…...
SpringBoot+Vue+数据可视化的动漫妆造服务平台(程序+论文+讲解+安装+调试+售后等)
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,我会一一回复,希望帮助更多的人。 系统介绍 在当今数字化高速发展的时代,动漫产业迎来了前所未有的繁荣,动漫…...
Go入门之语言变量 常量介绍
func main(){var a int8 10var b int 5var c int 6fmt.Println("a", a, "b", b, "c", c)d : 10fmt.Printf("a%v leixing%T\n", d, d) } main函数是入口函数,fmt包有三个打印的函数Println,Print,Printf。第…...
基于web的留守儿童网站的设计与实现
开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…...
鸡兔同笼问题
鸡兔同笼问题是这样一个问题: 现有鸡、兔合装在一个笼子里。数头一共100个头,数脚一共300只脚。问有多少只鸡多少只兔? 在这里讨论这个问题的解法当然太小儿科了。但是y_tab这个C语言解释器只提供了1维数组。如果需要用到2维数组时ÿ…...
