❤️‍🔥微服务的拆分策略

前言

假设当前手上有一个单体应用,现在准备将其转换为BFF架构。

自然需要一个前端 、一个BFF层 以及多个微服务(今天的重点)

本文主要讲述如何拆分这多个微服务

正文

假设当前应用有

  1. 访客模块
  2. 博客模块
  3. 在线人数模块
  4. ...

问题1:各个服务之间的数据库要共用还是各个服务有各个的数据库?

回答:

推荐每一个服务独立的数据库

其实主要是为了【提高项目的可扩展性&&避免各个服务之间的耦合】。

当我们需要新增某一些功能的时候------比如我要在现有的基础上新增一个【打赏功能】。

我只要做功能的新增,而不用对之前的各个服务进行任何的调整。

还有一个好处就是,我可以根据不同的业务,选择最适合的数据库。

上口诀:事务用MySQL,灵活用Mongo,快选用Redis

问题2:如何设计各个服务之间的协议

回答:

协议的使用是与当前的业务的特性息息相关的。

我会用场景来对应协议,而不是光说理论:

场景1】我要做在线人数的统计服务

这个东西是高频的、低延迟的。

我推荐:

WebSocket(前端到BFF) + gRPC(BFF到微服务)

场景2】支付功能

这个东西安全第一,关于【安全】的可以优先考虑:

HTTPS(对外) + gRPC(内部)

场景3】日志收集

我们假设这个日志是特别多的那种,看了头皮发麻的那种巨量日志。

你应该脑海里有一个词在不断横跳才对------"削峰填谷"

没错,选Kafka/RabbitMQ这样的消息队列方案直接秒:首先将消息全塞到消息队列,再安排一个服务慢慢消费即可。

场景4】稀松平常的获取博客

这种就属于比较平常的业务了。

选择HTTP/gRPC即可。

【小贴士:gRPC性能>HTTP】

最后

贪多嚼不烂

暂时只举这些场景

后续如需要会再补充。

相关推荐
code_li1 小时前
Android 16KB页面大小适配
java·架构·android-studio
学IT的周星星1 小时前
Spring Boot Web 开发实战:第二天,从零搭个“会卖萌”的小项目
spring boot·后端·tomcat
郑州光合科技余经理1 小时前
可独立部署的Java同城O2O系统架构:技术落地
java·开发语言·前端·后端·小程序·系统架构·uni-app
听麟1 小时前
HarmonyOS 6.0+ PC端多人联机游戏开发实战:Game Service Kit深度集成与跨设备性能优化
游戏·华为·性能优化·架构·harmonyos·ai-native
知识即是力量ol1 小时前
深度解析:基于 JWT + Redis 白名单的双令牌高安全认证架构
redis·安全·架构
Remember_9931 小时前
Spring 事务深度解析:实现方式、隔离级别与传播机制全攻略
java·开发语言·数据库·后端·spring·leetcode·oracle
要做一个小太阳2 小时前
华为Atlas 900 A3 SuperPoD 超节点网络架构
运维·服务器·网络·华为·架构
vx-bot5556662 小时前
企业微信接口在混合云环境下的集成架构与网络互联方案企业微信接口在混合云环境下的集成架构与网络互联方案
网络·架构·企业微信
编程彩机2 小时前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务
编程彩机2 小时前
互联网大厂Java面试:从Spring WebFlux到分布式事务的技术场景解析
java·微服务·面试·分布式事务·spring webflux