微服务架构解决方案
第一套:
Spring Boot + Spring Cloud 组件多,功能完备,采用Http方式通信
第二套:
Spring Boot + Dubbo + Zookeeper 组件少,功能非完备,采用RPC方式通信
微服务四大问题
目标:高可用(一直可以用),高并发,高性能
-
问题一:客户端如何访问这么多服务?
解决办法:API网关 -
问题二:服务与服务之间如何通信?
两种通信方式:
同步通信:分为Http通信(可以采用Apache Http Client通信框架),RPC通信(Dubbo, Apache Thrift, gRPC)
异步通信:消息队列(kafka, RabbitMQ, RocketMQ -
问题三:这么多服务如何管理?
服务治理(当一个服务上线就知道上线了,当一个服务下线就知道它下线了,这是服务管理中的一个环节,称之为服务治理):服务注册与发现- 基于客户端的服务注册与发现: Apache Zookeeper
- 基于服务端的服务注册与发现: Netflix Eureka
-
问题四:服务挂了怎么办?
重试机制
服务熔断
服务降级
服务限流
系统架构的演进
单一应用架构
当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键
垂直应用架构
当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆分成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。
分布式服务架构
当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心。使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键。
流动计算架构
当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现。此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。