微服务2025/2/15

微服务是一种软件架构风格,它是以专注于单一职责的很多小型项目为基础,组合出复杂的大型应用。

微服务是一种架构。

微服务是一种架构。

微服务是一种架构。

以前自己做项目最常用的架构是单体架构。单体项目不适合开发大型项目。

学习微服务技术来解决服务拆分碰到的问题。

使用微服务技术(工具)把单体项目拆成微服务项目。

上图是一些微服务技术,解决相应问题。

什么是单体架构

将业务的所有功能集中在一个项目中开发,打成一个包部署。

优点:架构简单、部署成本低。

缺点:团队协作成本高、系统发布效率低、系统可用性差。

总结:单体架构适合开发功能相对简单,规模较小的项目。

微服务架构

微服务架构,是服务化思想指导下的一套最佳实践架构方案。服务化,就是把单体架构中的功能模块拆分为多个独立项目。

SpringCloud

SpringCloud是目前国内使用最广泛的微服务框架。SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了这些组件的自动装配,从而提供了良好的开箱即用体验。(但对于Springboot的版本也有要求)

(题外话:Springboot最擅长自动装配和依赖管理)、

拆分原则

目标:高内聚、低耦合

拆分方式:横向拆分(抽取公共服务,提高复用性)、纵向拆分(按照业务模块拆分)

拆分服务

工程结构有两种:独立project、Maven聚合

远程调用

一旦微服务进行了拆分,数据产生了隔离,服务也产生了隔离,没法像以前一样调用了,如果想要像以前一样查询,查别人的数据,就必须通过网络调用。

相关推荐
jakeswang1 小时前
StarRocks
后端·架构
未来影子1 小时前
SpringAI(GA):SpringAI下的MCP源码解读
人工智能·架构·ai编程
互联网搬砖老肖2 小时前
Web 架构之缓存策略实战:从本地缓存到分布式缓存
前端·缓存·架构
思绪漂移2 小时前
云原生玩法三问:构建自定义开发环境
云原生·腾讯云
MYH5162 小时前
mamba架构和transformer区别
深度学习·架构·transformer
潘锦3 小时前
从架构师的角度来看 AI 编程带来的技术债务
架构·ai编程·cursor
慌ZHANG3 小时前
云原生思维重塑数字化基座:从理念到实践的深度剖析
云原生
qq_463944863 小时前
【Spark征服之路-2.3-Spark运行架构】
大数据·架构·spark
tomorrow.hello3 小时前
集群与分布式与微服务
分布式·微服务·架构
掘金-我是哪吒4 小时前
分布式微服务系统架构第144集:FastAPI全栈开发教育系统
分布式·微服务·架构·系统架构·fastapi