微服务
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
- 微服务更多的是关注业务逻辑层面的代码,不会和前端混合
- 每个微服务都有自己的存储能力,可以有自己的数据库,也可以有统一的数据库
易于开发人员的理解,修改和维护
……
缺点:
- 分布式系统较复杂
- 多服务维护难度大、成本高
- 系统部署依赖
- 服务间通信成本
- 数据一致性
- 系统集成测试
性能监控
……
微服务技术栈
评论 (0)