微服务

suaxi
2020-12-30 / 0 评论 / 65 阅读 / 正在检测是否收录...

微服务

1、什么是微服务?

将传统的一站式应用,拆分为单个的服务,彻底去耦合,每一个微服务提供单个业务功能的服务,能够自行单独启动和销毁,拥有自己独立的数据库。

2、微服务与微服务架构

  • 微服务强调服务的大小,它关注的是某一个点,即解决具体问题/提供对应服务的一个服务应用,类似于IDEA一个项目中的单个Moudel
  • 微服务架构强调架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调,互相配合,且每个服务围绕着具体的业务进行构建,并且能被独立的部署到生产环境中。对具体的一个服务而言,应根据业务上下文,选择合适的语言,工具对其进行构建。

3、现有的微服务解决方案(举例)

Spring Cloud Netflix(一站式解决方案)

  • API网关,Zuul组件
  • Feign
  • 服务注册与发现:Eureka
  • Hystrix熔断机制

Apache Dubbo Zookeeper

  • 第三方组件API
  • Dubbo
  • 服务注册与发现:Zookeeper
  • 借助Hystrix熔断机制

Spring Cloud Alibaba全家桶

4、微服务优缺点

优点:

  • 单一职责
  • 每个服务足够内聚,足够小,聚焦一个指定的业务功能或需求
  • 能够被2-5人的小团队单独开发
  • 耦合低,在开发或部署阶段都是独立的
  • 多语言开发
  • 易于和第三方集成,微服务允许容易且灵活的方式集成自动部署,通过持续集成工具,例如:jenkins、Hudson、bamboo
  • 微服务更多的是关注业务逻辑层面的代码,不会和前端混合
  • 每个微服务都有自己的存储能力,可以有自己的数据库,也可以有统一的数据库
  • 易于开发人员的理解,修改和维护

    ……

缺点:

  • 分布式系统较复杂
  • 多服务维护难度大、成本高
  • 系统部署依赖
  • 服务间通信成本
  • 数据一致性
  • 系统集成测试
  • 性能监控

    ……

微服务技术栈

微服务06-技术栈.png

0

评论 (0)

取消