app应用架构描述了设计和构建应用的模式与技术。该架构可以提供构建应用时应遵循的路线图和最佳实践,构建一个结构合理的应用。app应用架构包含前端和后端服务。前端开发事关应用的用户体验,而后端开发则侧重于提供对数据、服务及其他现有系统的访问,以确保应用正常工作。
一、什么是app应用架构
app应用架构描述了设计和构建应用的模式与技术。该架构可以提供构建应用时应遵循的路线图和最佳实践,构建一个结构合理的应用。app应用架构包含前端和后端服务。前端开发事关应用的用户体验,而后端开发则侧重于提供对数据、服务及其他现有系统的访问,以确保应用正常工作。
二、app应用架构分类
目前应用架构有很多,但根据服务间的关系,当今最重要的应用架构是:单体式和 N 层架构(紧密耦合)、微服务(非耦合),以及事件驱动架构和面向服务的架构(松散耦合)。
1、分层或 N 层架构
分层或 N 层架构是一种传统架构,通常用于构建内部和企业应用,而且常常与传统应用相关联。
在分层架构中,应用由多个层(通常为 3 层,但也可以有更多层)构成,且每一层都有自己的职责。
分层有助于管理依赖关系并执行逻辑功能。在分层架构中,层与层之间是水平排列的,因此它们只能调用自己下面的一层。
每层既可以调用紧挨在它下面的层,也可以调用它下面的任何一层。
2、单体式架构
单体式应用(另一种与传统系统关联的架构类型)就是一个应用中包含所有功能的应用堆栈。无论是服务之间的交互还是开发与交付方式,都采用紧密耦合的形式。
更新或扩展单体式应用的某一方面会对整个应用及其底层的基础架构产生影响。
对应用代码的任何更改都需要重新发布整个应用。因此,更新和新版本发布通常每年只能进行一次或两次,并且可能只包括常规维护,而不会添加新功能。
3、微服务架构
微服务既是一种架构,也是构建软件的方法。在微服务中,应用被拆分成最小的组件,彼此独立。其中的每一个组件或流程都是一个微服务。
微服务采用分布式、松散耦合结构,因此它们之间不会相互影响。这对于动态可扩展性和容错能力都有一定的好处:可以在不占用大量基础架构的情况下按需扩展单个服务,或者可以在不影响其他服务的情况下进行故障转移。
使用微服务架构的目的是更快地交付高质量的软件。您可以并行开发多个微服务。由于服务是独立部署的,因此在发生更改时无须重建或重新部署整个应用。
4、事件驱动架构
对于事件驱动系统而言,事件的捕获、通信、处理和持久保留是解决方案的核心结构。这和传统的请求驱动模型有很大不同。
事件是指系统硬件或软件的状态出现任何重大改变。而事件的来源可能是内部也可能是外部原因。
事件驱动架构可以最大程度减少耦合度,因此是现代化分布式应用架构的理想之选。
事件驱动架构可以基于发布/订阅模型或事件流模型。
5、面向服务的架构
面向服务的架构(SOA)是一种非常成熟的软件设计模式,它有点类似于微服务架构模式。
SOA 将应用构建为可重复使用的离散型服务,这些服务会通过企业服务总线(ESB)进行通信。
采用这种架构时,各项服务会分别围绕特定的业务流程进行组织,遵循相应的通信协议(如 SOAP、ActiveMQ 或 Apache Thrift),并通过 ESB 平台来提供服务。总而言之,前端应用会利用这套通过 ESB 集成的服务为企业或客户提供价值。
延伸阅读
Android适配
Android适配需要考虑屏幕尺寸、分辨率和像素密度等因素。一般来说,屏幕尺寸以英寸为单位,分辨率越高,像素密度越大。同时,根据用户选择的文本大小来调整大小。默认情况下,sp作为单位,但可根据用户的首选文本大小进行调整。
文章标题:什么是app应用架构,发布者:E.Z,转载请注明出处:https://worktile.com/kb/p/53782