微服务架构的关键思想是功能分解。这意味着您无需开发单个大型应用程序,就可以将您的应用程序结构分解为一组逻辑服务。 应用程序的体系结构很重要,因为它决定了服务的质量
软件构架应用程序的体系结构是将其分解为组件以及这些组件之间的关系。 分解很重要,因为它有助于团队之间的工作和知识分配,并提供应用程序整体工作的清晰度。 软件架构的4 + 1视图模型 它定义了软件体系结构的四个视图 逻辑视图
开发视图 /实施意见
进程视图
物理视图
4 + 1视图模型中的+1代表动画视图,并描述特定视图中的各个组件如何协同工作以处理请求。 架构风格分层架构 分层体系结构将软件组件分层组织。层可以依赖于其下面的任何层。 流行的三层架构是分层架构 分层架构的缺点
六角形架构基于建筑风格的整体 整体架构可以定义为一种架构样式,该架构样式将实现 视图表示为单个组件:单个可执行文件或可部署文件。 基于架构风格的微服务 架构风格的微服务架构表示一个具有一组多个组件的实现视图:可执行文件和Wars。 组件是服务,关系是通过通信协议进行的。尽管通常实现六边形体系结构,但是各个服务可以自由选择其体系结构。 微服务架构服务的关键约束应该松散耦合。 服务服务是实现某些有用功能的独立,可独立部署的组件。 服务通常提供两类动作
服务还会发布事件。 松耦合任何两个服务将仅通过API进行通信。API隐藏了服务的内部实现。两个服务不共享同一数据库以提供运行时隔离,因此一个服务无法持有将阻止另一服务的锁。 定义应用程序的微服务架构 步骤如下:
识别系统操作将系统视为黑匣子。现在确定所有系统操作。 系统操作是应用程序必须处理的请求的抽象。它可以是命令,也可以是查询。 它涉及以下操作:
定义服务有两种方法可以识别系统中的服务:
分解原理单一责任原则
开放关闭原则
将应用程序分解为服务的障碍
定义服务API服务API有两类
|
|
来自: 菌心说 > 《编程+、计算机、信息技术》