什么是微服务
微服务是一种软件架构风格,是以开发一组小型服务的方式来开发一个独立的应用系统。其中每个小型服务都运行在自己的进程中,并经常采用HTTP资源API这样轻量的机制来相互通信。这些服务围绕业务功能进行构建,并能通过全自动的部署机制进行独立部署。这些微服务可以使用不同的语言来编写,并且可以使用不同的数据存储技术。对这些微服务我们仅作最低限度的集中管理。
SOA(service oriented architecture)也是一种软件架构风格,其中应用程序的不同组件通过网络上的通信协议向其他组件提供服务。通信可以涉及简单的数据传递,也可以涉及两个或多个协调彼此之间连接服务的服务。
粗粗一看,微服务和SOA看起来非常相似。主要区别在于范围。简而言之,面向服务的体系结构(SOA)具有企业范围,而微服务体系结构具有应用程序范围。微服务中的服务组件通常只有一个目的,并且确实很好地完成这一任务。另一方面,在SOA中,服务通常包含更多的业务功能,并且通常将它们实现为完整的子系统。
微服务,在某种程度上,是SOA演进的下一步。在提出微服务这个通用名称之前,有人将其称为“微型Web服务”或“细粒度SOA”。
在SOA中,它使用企业服务总线(ESB)进行通信,服务与服务之间通过总线进行消息传递。ESB可能会成为影响整个系统的单点故障。由于每个服务都通过ESB进行通信,因此如果其中一项服务变慢,则可能会阻塞对该服务的请求,从而阻塞ESB。
另一方面,微服务的容错性要好得多。例如,如果一个微服务发生故障,则仅会影响该微服务。所有其他微服务将继续定期处理请求。