现在很多人都在谈微服务,那么到底什么是微服务呢?这里谈谈我对微服务的理解。

微服务有两个核心:

·        微:服务的粒度要细,即服务要细化到API

·        服务:提供好服务,要让用户感到好用(要做到这一点很不容易)

上面两个核心总结起来,可以用下面这幅图表示:

29.浅谈微服务的架构设计

从上面这幅图看出,微服务特别简单(好的架构就应该简单),我们把服务再拆分成一个个API,API是一个完整的功能。然后我们把API扔到一个“云上”,然后用户就可以到“云上”获取所有API的服务,这个“云”保证能提供好的服务。

我们可以看到,有了微服务之后,服务对用户来说变得特别简单,而且上面dubbo的不足之处在微服务这里都解决了。使用者不再需要依赖任何jar包,不再需要去注册中心查找服务,不再去做鉴权处理,不用担心服务挂掉,不用担心不会使用服务,所有的问题这个都解决了。这也是微服务的核心之一,提供好服务。

说到这里,大家就应该大体知道该怎么做微服务了,图中的是关键。下面我们就慢慢拨开这朵云。

微服务的实现

29.浅谈微服务的架构设计

微服务的关键是服务网关,所以,上面提到的“云”就是服务网关。要做微服务,我们先定义一下微服务需要具备的特点。

微服务的特点

服务需要再细化成API(服务接口——>服务API)

·        每个服务由一组API组成

·        API形式对外提供统一格式的服务

·        使用者无需任何配置,直接调用(http

·        完整的API文档

·        API服务安全可靠稳定

微服务要解决的问题

上面提到了,dubbo还存在一些问题 ,其实dubbo存在的问题 就是 微服务要解决的问题,这里 再总结一下。当然,dubbo和微服务的侧重点不一样,dubbo侧重于内部接口之间的RPC,而微服务则侧重于对外提供服务。

·        统一入口

·        安全控制:防刷限流

·        统一鉴权:应用鉴权、用户鉴权、OAuth鉴权、ACL

·        协议转换:httpdubboProtobuf

·        API配置管理

·        API上线、下线

·        API与服务接口映射

·        监控与报警

·        整体架构的可拓展、高并发、分布式

·        服务容器自动收缩、扩容

实现方案

29.浅谈微服务的架构设计

·        负载均衡层:nginx/lvs/F5

·        微服务层 

·        高性能服务网关

·        统一入口、API配置管理、分流鉴权、服务监控、协议转换

·        API映射、OAuth2.0API文档管理

·        分布式、可拓展

·        服务治理层 

·        成熟的服务治理框架dubbo

·        MQ服务之间解耦

·        弹性云 

·        服务docker

·        基于访问压力的实时集群调度与管理

弹性云

这里简单介绍一下弹性云的概念,微服务要想提供好服务,保证API不能挂掉并且有好的性能,需要很高的运维要求。这里的弹性云便是自动化运维解决方案,对访问压力进行监控,根据监控解决调度应用的发布和回收。

29.浅谈微服务的架构设计

相关文章:

  • 2021-10-11
  • 2021-11-30
  • 2021-09-10
  • 2019-03-28
  • 2021-12-02
  • 2021-12-19
  • 2021-11-18
猜你喜欢
  • 2019-10-26
  • 2022-01-02
  • 2019-08-11
  • 2021-11-02
  • 2021-06-29
  • 2020-06-24
  • 2021-09-18
  • 2021-01-20
相关资源
相似解决方案