微服务架构 | 1. 微服务相关基础知识

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 本篇主要介绍一些通用概念概述、组件对比与系列笔记的目录结构说明;

前言

参考资料
《Spring Microservices in Action》
《Spring Cloud Alibaba 微服务原理与实战》
《B站 尚硅谷 SpringCloud 框架开发教程 周阳》

本篇主要介绍一些通用概念概述、组件对比与系列笔记的目录结构说明;


1. 分布式相关理论

1.1 分布式计算系统的 CAP 理论

https://www.runoob.com/w3cnote/zookeeper-tutorial.html

1.2 BASE 理论

https://www.runoob.com/w3cnote/zookeeper-tutorial.html


2. 微服务架构发展历程

2.1 单体架构

  • 通常来说,如果一个 war 包或者 jar 包里包含一个应用的所有功能,则称为单体架构;
  • 优点:架构简单、能快速开发与上线;
  • 缺点:后端服务器负载越来越高、业务场景复杂;

商城系统单体架构

2.2 集群与垂直化

  • 当业务量扩大时,服务负载过高,维护和部署成本增加,可以从两个方面优化:

    • 横向增加服务器,把单台机器变成多机集群;
    • 按照业务的垂直领域进行拆分,减少业务的耦合度,以及降低单个 war 包带来的伸缩性困难问题;

商城系统集群架构

2.3 SOA(面向服务架构)

  • SOA 核心目标是把一些通用的、会被多个上层服务调用的共享业务提取成独立的基础服务,这些被提取出来的共享服务相对来说比较独立,并且可以重用;
  • SOA 架构主要解决了两个问题:信息孤岛、共享业务的重用;

商城系统 SOA 架构

2.4 微服务架构

  • 面向服务(SOA)和微服务本质上都是服务化思想的一种体现;
  • 如果 SOA 是面向服务开发思想的雏形,那么微服务就是针对可重用业务服务的更进一步优化;
  • 可以把 SOA 看成微服务的超集,也就是多个微服务可以组成一个SOA服务;
  • 实施微服务的前提是软件交付链路及基础设施的成熟化;
  • 因此微服务本质上是服务化思想的最佳实践方向;

商城系统微服务架构

2.4.1 SOA 与微服务架构的关注点

  • SOA:服务的重用性及解决信息孤岛问题;
  • 微服务架构:解耦,降低业务之间的耦合度。微服务会更多地关注在 DevOps 的持续交付上,微服务与容器化技术的结合更加紧密;


3. 云计算概述

3.1 云计算的几种模式

三种核心基本模式

  • 基础设施即服务(Infrastructure as a Service, IaaS);
  • 平台即服务(Platform as a Service, PaaS);
  • 软件即服务(Software as a Service, SaaS);

    • Spring Cloud 讨论的是基于 IaaS 的微服务;

两种新兴模式

  • 函数即服务(Functions as a Service, FaaS);
  • 容器即服务(Container as a Service, CaaS)


4. 微服务架构概述

4.1 一个简单的微服务架构图

一个简单的微服务架构图

4.2 微服务架构的五大特性

微服务架构的五大特性

  • 位置透明;
  • 大小适当;
  • 可伸缩;
  • 可重复;
  • 有弹性;

4.3 微服务架构讨论了什么

微服务架构讨论了什么

  • 服务粒度;
  • 通信协议;
  • 接口设计;
  • 配置管理;
  • 事件处理;

4.4 按模式分的微服务组件

在这里插入图片描述
按模式分的微服务组件

4.5 微服务架构的优点与挑战

微服务架构的优点让我们选择微服务作为企业级架构方案,微服务的技术挑战则要通过学习、设计甚至开发一些组件去解决;
  • 架构优点

    • 复杂度可控;
    • 技术选型更灵活;
    • 独立部署;
    • 容错性;
  • 架构挑战

    • 故障排查;
    • 分布式架构的复杂性;
    • 服务依赖;
    • 运维成本;
  • 技术挑战

    • 分布式配置中心;
    • 服务路由;
    • 负载均衡;
    • 熔断限流;
    • 链路监控;

4.6 本系列笔记将讨论什么

本系列笔记将在介绍微服务架构需要什么功能同时给出市面上常见的几种解决方案,他们通常被称为组件;

五大核心功能及其组件

  • 配置中心;
  • 注册中心;
  • 服务调用;
  • 服务容灾与降级;
  • 网关路由;

其他特色扩展功能及其组件

  • 安全保护;
  • 事件驱动;
  • 服务总线;
  • 分布式追踪;
  • 分布式事务;
  • RPC 通信;
  • 等...


5. 主流 Spring Cloud 组件

  • Spring Cloud 不是一个框架,而是一套规范。其对 Spring Boot 在次封装后屏蔽复杂的配置,给开发者提供了良好的开箱即用的微服务规范;
  • Spring Cloud Netflix、Spring Cloud Condul、Spring Cloud Alibaba 才是 Spring Cloud 规范的实现;
  • 目前主流的 Spring Cloud 治理方案主要由 Spring Cloud Netflix 和 Spring Cloud Alibaba 提供;
  • 相比 Spring Cloud Netflix,Spring Cloud Alibaba 在服务治理方面更适用于国内技术场景;

5.1 组件对比图

大致为 Netflix 版与 Alibaba 版的对比;

组件对比图

5.2 Spring Cloud五大组件:

  • 注册中心 Netflix Eureka;
  • 客服端负载均衡 Netflix Ribbon;
  • 断路器 Netflix Hystrix;
  • 服务网关 Netflix Zuul;
  • 布式配置 Config;

5.3 Spring Cloud Alibaba 技术架构图

Spring Cloud Alibaba 技术架构图

5.4 各厂商 Spring Cloud 技术架构图

各厂商 Spring Cloud 技术架构图


6. 一些资源链接

7. 本系列笔记的编写思想

7.1 目录结构

  • 主要分有一级标题和二级标题,一二级标题都是一篇文章;

    • 为方便说明,下面用 XXX 代表:配置中心、注册中心、服务调用等功能;
    • 用 YYY 代表:Eureka、Spring Cloud Config、Zuul 等细分组件;
  • 其中一级标题表示概述,目录结构如下:

    • XXX 基础知识:对微服务(注册中心、配置、网关等)做系统的概述;
    • YYY 组件分析:里面有个链接,可以跳转至对应细分文章;
  • 二级标题为组件实战,目录结构如下:

    • YYY 基础知识:介绍一些 YYY 组件的理论知识与面试考点;
    • 使用 YYY 组件构建服务:实战部分;
    • 其中 YYY 组件实战部分又可大致总结为:

      • 引入 pom.xml 依赖文件;
      • 修改 .yml 配置文件;
      • 在主程序类上添加注解;
      • 编写业务类(Config、Service、Controller 等);


相关文章
|
10天前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
10天前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
12天前
|
JSON 监控 安全
探索微服务架构中的API网关模式
【9月更文挑战第22天】在微服务架构的海洋中,API网关如同一位智慧的守门人,不仅管理着服务的进出,还维护着整个系统的秩序。本文将带你一探究竟,看看这位守门人是如何工作的,以及它为何成为现代云原生应用不可或缺的一部分。从流量控制到安全防护,再到服务聚合,我们将一起解锁API网关的秘密。
|
22天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
29 3
|
26天前
|
监控 负载均衡 应用服务中间件
探索微服务架构下的API网关设计与实践
在数字化浪潮中,微服务架构以其灵活性和可扩展性成为企业IT架构的宠儿。本文将深入浅出地介绍微服务架构下API网关的关键作用,探讨其设计原则与实践要点,旨在帮助读者更好地理解和应用API网关,优化微服务间的通信效率和安全性,实现服务的高可用性和伸缩性。
38 3
|
1月前
|
存储 Java Maven
从零到微服务专家:用Micronaut框架轻松构建未来架构
【9月更文挑战第5天】在现代软件开发中,微服务架构因提升应用的可伸缩性和灵活性而广受欢迎。Micronaut 是一个轻量级的 Java 框架,适合构建微服务。本文介绍如何从零开始使用 Micronaut 搭建微服务架构,包括设置开发环境、创建 Maven 项目并添加 Micronaut 依赖,编写主类启动应用,以及添加控制器处理 HTTP 请求。通过示例代码展示如何实现简单的 “Hello, World!” 功能,并介绍如何通过添加更多依赖来扩展应用功能,如数据访问、验证和安全性等。Micronaut 的强大和灵活性使你能够快速构建复杂的微服务系统。
61 5
|
9天前
|
Kubernetes Go Docker
掌握微服务架构:从Go到容器化的旅程
摘要,通常简短概述文章内容,要求精炼。在本文中,我们将打破常规,采用一种故事化叙述的摘要,旨在激发读者的好奇心和探究欲: “从宁静的海滨小城出发,我们踏上了一场技术探险之旅,探索微服务架构的奥秘。我们将学习如何用Go编写微服务,以及如何通过Docker和Kubernetes将它们打包进小巧的容器中。在这场旅程中,我们将遇到挑战、收获知识,最终实现应用的快速部署与可扩展性。”
|
10天前
|
Cloud Native Java 对象存储
揭秘微服务架构之争:Spring Cloud与Netflix OSS巅峰对决,谁将称霸弹性云原生时代?
近年来,微服务架构成为企业应用的主流设计模式。本文对比了两大热门框架Spring Cloud和Netflix OSS,探讨其在构建弹性微服务方面的表现。Spring Cloud依托Spring Boot,提供全面的微服务解决方案,包括服务注册、配置管理和负载均衡等。Netflix OSS则由一系列可独立或组合使用的组件构成,如Eureka、Hystrix等。两者相比,Spring Cloud更易集成且功能完善,而Netflix OSS则需自行整合组件,但灵活性更高。实际上,两者也可结合使用以发挥各自优势。通过对两者的对比分析,希望为企业在微服务架构选型上提供参考。
30 0
|
18天前
|
缓存 负载均衡 数据管理
深入探索微服务架构的核心要素与实践策略在当今软件开发领域,微服务架构以其独特的优势和灵活性,已成为众多企业和开发者的首选。本文将深入探讨微服务架构的核心要素,包括服务拆分、通信机制、数据管理等,并结合实际案例分析其在不同场景下的应用策略,旨在为读者提供一套全面、深入的微服务架构实践指南。**
**微服务架构作为软件开发领域的热门话题,正引领着一场技术革新。本文从微服务架构的核心要素出发,详细阐述了服务拆分的原则与方法、通信机制的选择与优化、数据管理的策略与挑战等内容。同时,结合具体案例,分析了微服务架构在不同场景下的应用策略,为读者提供了实用的指导和建议。
|
2月前
|
数据库 Java 数据库连接
Hibernate 实体监听器竟如魔法精灵,在 CRUD 操作中掀起自动化风暴!
【8月更文挑战第31天】在软件开发中,效率与自动化至关重要。Hibernate 通过其强大的持久化框架提供了实体监听器这一利器,自动处理 CRUD 操作中的重复任务,如生成唯一标识符、记录更新时间和执行清理操作,从而大幅提升开发效率并减少错误。下面通过示例代码展示了如何定义监听器类,并在实体类中使用 `@EntityListeners` 注解来指定监听器,实现自动化任务。这不仅简化了开发流程,还能根据具体需求灵活应用,满足各种业务场景。
32 0
下一篇
无影云桌面