什么是微服务
目前而言,对于微服务业界没有一个统一的标准定义,但是通常而言是提倡把一个单一的应用程序划分为一组小的服务,每个小的服务都会进行再自己的进程中,服务之间通过轻量级通信机制(http的restful API)进行通信,那么这每一个小的服务就是微服务。
什么是微服务架构
微服务架构是一种架构模式(用于服务管理微服务的),它把一组小的服务互相协调,互相配合,并且完成功能。每个服务运行在独立的进程中,服务于服务之间采用轻量级的通信机制互相协作(通常是Http的Restful API)。
每个服务都围绕着具体的业务进行构建,并且能够被独立的部署到生产环境。
另外,应当尽量避免统一的,集中式的服务管理机制,对具体的一个服务而言,应根据业务上下文,选择合适的语言,工具对其进行构建
单体架构与微服务架构
单体架构:比如传统单一电商应用,订单,支付,用户,商品等等所有模块都在一个项目中,若某一个模块出现异常,则会导致整个版本发布的回退。
微服务架构:就是把单一应用里的每一个模块拆成一个一个的微服务,比如订单微服务,支付微服务,用户微服务,商品微服务等等,若某一个微服务出现错误则不会导致整个版本的回退。
微服务的优缺点
优点
- 每个服务足够内聚,足够小,代码容易理解,能聚焦一个指定的业务功能或需求(职责单一)
- 开发简单、效率高,一个服务就是专一的只干一件事,能够被小团队单独开发(2-5人)
- 可以使用不同的语言开发。
- 易于和第三方集成,允许容易且灵活的方式集成自动部署,通过持续集成工具,如Jenkins等…
- 微服务只是业务逻辑的代码功能接口,不会和HTML&CSS或其他界面组件混合。
- 每个微服务都有自己的存储能力,可以有自己的数据库。也可以有统一数据库。
缺点
- 开发人员要处理分布式系统的复杂性(分布式事物等)
- 系统部署依赖
- 服务间通信成本
- 数据一致性