一、C/S结构
C/S架构指的是Client/Server架构,即客户端和服务器架构。在这种架构中,软件系统被划分为两个主要部分:客户端和服务器。
-
客户端(Client): 客户端是用户直接与之交互的部分,通常是安装在用户设备上的应用程序。客户端负责处理用户界面、用户输入和一些本地计算。它向服务器发起请求以获取数据或执行某些操作,并将结果呈现给用户。
-
服务器(Server): 服务器是中央计算机或计算机集群,负责处理客户端发起的请求。服务器执行业务逻辑、存储和检索数据,并向客户端提供相应的结果。服务器端通常拥有更大的计算能力和存储资源,能够支持多个客户端同时连接
优点:
二、B/S结构
-
浏览器(Browser): 用户通过Web浏览器(如Chrome、Firefox、Safari等)访问应用程序。浏览器负责呈现用户界面,处理用户输入,并通过网络协议与服务器进行通信。
-
服务器(Server): 服务器端包含应用程序的业务逻辑和数据处理部分。它接收来自浏览器的请求,执行相应的业务逻辑,然后将结果返回给浏览器。服务器通常托管应用的核心功能和数据,可能与数据库进行交互以检索或更新数据。
三、 微服务架构
微服务(Microservices)是一种架构风格,它将一个应用程序拆分为一组小型、独立的服务,每个服务都专注于一个特定的业务功能。这些服务可以独立开发、部署、扩展和维护,从而提高系统的灵活性、可伸缩性和可维护性。微服务架构的核心思想是将大型系统划分为小型服务单元,每个服务单元都有自己的数据库和独立通信机制。
以下是微服务架构的一些关键特点和原则:
-
独立性(Independence): 微服务是独立的业务功能单元,每个服务都有自己的代码库、数据库和数据存储。这种独立性使得团队可以独立开发和部署服务,降低了系统的耦合度。
-
分布式架构(Distributed Architecture): 微服务通常是分布式的,每个服务可以运行在不同的服务器或容器中。服务之间通过网络进行通信,采用轻量级的通信机制,如HTTP或消息队列。
-
自治性(Autonomy): 微服务是自治的,即每个服务都有自己的开发团队和生命周期。团队可以使用不同的编程语言、框架和技术栈,使得选择最适合特定任务的技术变得更加容易。
-
弹性(Resilience): 微服务架构鼓励设计具有弹性的系统。由于每个服务都是独立的,因此系统在某个服务出现故障时可以保持部分功能的可用性。
-
轻量级通信(Lightweight Communication): 服务之间的通信通常采用轻量级的协议,例如RESTful API、JSON或消息队列。这有助于提高系统的性能和响应速度。
-
可伸缩性(Scalability): 微服务可以根据需求独立扩展,只需对特定的服务进行水平扩展,而不必整体扩展整个系统。
-
多语言支持(Polyglotism): 不同的服务可以使用不同的编程语言和技术,根据特定的需求选择最适合的工具。
微服务架构适用于需要快速迭代、易于扩展和高度灵活的应用程序。然而,引入微服务架构也带来了一些挑战,如服务间通信的管理、一致性维护等,因此在设计和实施微服务架构时需要仔细考虑这些方面。https://www.bilibili.com/video/BV1mW4y1q7h9/?spm_id_from=333.337.search-card.all.click&vd_source=2b89fb32c94aaa076a0bbf42ab94a268