微服务架构

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
简介: 微服务架构

SpringCloud是一系列框架的有序集合,它利用SpringBoot的开发便利性简化了分布式系统的开发


如:服务发现,负载均衡,断路器,智能路由,微代理,控制总线等等


微服务架构示例包含:


服务注册与发现(Eureka),客户端负载均衡(Ribbon),断路器(Hystrix)


  • 微服务架构的优势

可扩展性:微服务架构可以通过添加或者删除服务来扩展或缩小系统规模

独立部署:微服务可以独立部署,使得开发人员可以在不影响整个系统的情况下更新和维护单个服务。

灵活性:微服务可以使用不同的技术和语言进行开发,使得开发人员可以选择最合适他们的工具。


  • 核心设计理念

1   注册中心:服务发现和注册是微服务架构的核心,SpringCloud使用Eureka,Consul或者Zookeeper等注册中心来实现服务的发现和注册。

Eureka是通过心跳检测,健康检查和客户端缓存等机制,提高系统的灵活性,可伸缩性和可用性


Eureka包含两个组件:Eureka Server和Eureka Client,Eureka Client是一个Java客户端。用于简化与Eureka Server 的交互,Eureka Server 提供服务发现的能力,各个微服务启动时,会通知Eureka Client和Eureka Server进行注册自己的信息,Eureka Server 会存储该服务的信息。


30S 客户端会每个30S去获取并更新数据


60S 服务端每隔60S 对客户端链接进行检查


90S 服务端超过90S没有接到客户端心跳,会移除该实例


15分钟 80% 如果15分钟内80%的客户端失效,就会启动自我保护机制。


@EnableEurekaServer 和 @EnableEurekaClient 注解分别用于标记应用为注册中心和服务提供者/消费者。服务消费者使用 @FeignClient 注解定义了一个远程调用的接口。当服务消费者需要调用服务提供者的服务时,它会通过 Feign 客户端进行远程调用。


2 负载均衡:在微服务架构中,服务可能会被部署在多个实例上,因此需要使用负载均衡算法来平衡流量,SpringCloud提供了Ribbon实现客户端负载均衡。


负载均衡是高并发高可用系统必不可少的组件


负载均衡器是基于Netflix Ribbon实现的,是一个客户端负载均衡器,它可以在客户端配置服务提供者的列表,并且可以根据特定的负载均衡策略来选择服务提供者。


Ribbon的配置和使用通常是隐式的,因为Spring Cloud集成了Ribbon,并且通过Spring Cloud Netflix提供了一套简化的声明式服务调用模板。


负载均衡的策略


轮询:默认策略,请求按顺序依次分配到各服务器


随机:请求随机分配到各服务器


最少活跃调用数:使用服务器的活跃请求数量来决定分配


最小响应时间:根据服务器响应时间来决定分配。


调用示例:


通常会有一个服务消费者(RestTemplate)来调用服务提供者。


服务提供者会注册到服务发现组件比如Eureka


消费者会使用服务提供者的名字进行调用,Ribbon会根据服务提供者的名字来查询服务列表,并根据配置的负载均衡策略来选择具体的服务提供者实例。


分为客户端的负载均衡和服务端的负载均衡


服务端的负载均衡,比如订单服务调用商品服务,此时订单服务就是客户端,商品服务就是服务端


Nginx就是一个比较有名的负载均衡器,请求会先到达负载均衡器,然后通过负载均衡算法,在多个服务之间访问。

客户端服务均衡时客户端进行负载均衡算法的分配,客户端先到注册中心获取服务列表,接下来客户端把负载均衡以代码公共类库的方式放到客户端,然后客户端获取服务列表之后,根据算法进行选择访问

负载均衡是一种思想,即按照什么样的策略进行负载均衡分配,目前支持

轮询策略和随机策略,Spring Cloud LoadBalancer 默认的策略是轮训策略

public class CustomLoadBalancerConfiguration {
 
    @Bean
    ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,
                                                            LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
        return new RandomLoadBalancer(loadBalancerClientFactory
                .getLazyProvider(name, ServiceInstanceListSupplier.class),
                name);
    }
}

3 服务网关:服务网关是微服务架构中的另一个重要组件,它可以将客户端的请求路由到不同的微服务实例上。Gateway和Netflix Zuul是常用的服务网关。


过滤器和Zuul的过滤器在概念上类似,可以使用Filter拦截和修改请求,实现对上游的响应,进行二次处理,实现横切与应用无关的功能,如安全、访问超时设置、限流等功能


路由,网关配置的基本组成模块,和Zuul的路由配置模块类似。一个Route模块由一个ID、一个目标URI、一组断言和一组过滤器组成。如果断言为真,则路由匹配,目标URI会被访问


断言


4 熔断器:在微服务架构中,由于服务之间调用可能会产生故障,因此需要使用熔断器来保护系统免受故障的影响,SpringCloud Hystrix提供了熔断器的实现。


原理是基于断路器模式,这是一种分布式系统中防止服务雪崩效应的重要机制,


监控与统计:Hystrix为每个依赖服务的调用都包装成一个HystrixCommand或HystrixObservableCommand对象。它会跟踪该命令的成功、失败、超时和拒绝等指标,并维护这些指标的统计信息


断路器状态:Hystrix的断路器有三种状态:关闭(Closed)、开启(Open)和半开(Half-Open)。


  •   关闭状态:初始状态,允许请求正常通过到后端服务。
  •   开启状态:当一定时间内失败率达到阈值(如50%失败率)时,断路器切换到开启状态,此时所有对该服务的请求将不再实际执行,而是直接失败并调用降级逻辑(Fallback)。
  •   半开状态:经过一段时间(如默认的5秒),断路器会自动切换到半开状态,此时会允许少量请求尝试通过,如果这些请求成功,则认为服务恢复正常,断路器回到关闭状态;如果请求仍然失败,则断路器再次变为开启状态。


降级逻辑:当断路器开启时,Hystrix会执行预先定义的降级逻辑(Fallback),提供一个备选的响应,而不是让请求长时间阻塞或抛出异常。


资源隔离:通过线程池或信号量来实现服务间的资源隔离,即使某个服务出现故障或延迟,也不会耗尽整个系统的线程资源


5 配置中心:微服务架构中的配置管理也是非常重要的,SpringCloud提供了Config Server和Config Client来管理分布式系统的配置。


微服务意味着要将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中会出现大量的服务。由于每次服务都需要必要的配置信息才能运行,所以也面临了一些问题


随着微服务工程的越来越多,每个工程都有一套配置文件,系统膨胀,如果每个项目都有公共的比如数据库连接信息,没有统一的管理,想要修改则需要每个工程都有修改,所以我们通常有很多系统环境如: prod-生产环境,test-测试环境,dev-预发布环境。因此一套集中式的,动态的管理设施是必不可少的。


相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
1月前
|
API 微服务
微服务架构
微服务架构是一种将Web应用拆分为多个小型服务的架构方式。每个服务都是独立的、可独立部署和升级的模块,它们之间通过API进行通信。微服务架构的优点是提高了系统的可扩展性和可维护性,同时也降低了系统的复杂度。通过微服务架构,我们可以将Web应用拆分为多个独立的服务,每个服务负责处理特定的业务逻辑和数据交互。
|
8月前
|
存储 数据库 微服务
我对微服务架构的简单理解
本文讨论了微服务架构的核心价值,即设计时考虑未来独立部署,允许功能模块通过远程接口灵活调用,实现业务扩展和数据库拆分,以应对增长的业务量和数据规模。微服务是分布式开发技术的一种,强调数据一致性,遵循ACID原则。尽管并非所有企业都需采用微服务,对于数据量不大或非网络依赖型的企业,可能无需面对分布式系统的复杂性。技术的发展往往源于实际需求,解决痛点即为创新和进步的表现。
|
7月前
|
运维 负载均衡 数据库
为什么要使用微服务架构?
本文讨论了从传统单体架构到微服务架构的转变。单体架构将所有功能集成在一个代码库中,导致复杂性高、扩展性和维护困难。相比之下,微服务架构将大型应用拆分为独立服务,降低了耦合度,优点包括易于开发和维护、快速启动、按需伸缩和更强的稳定性。然而,微服务也带来了部署管理难度增加、分布式事务一致性问题和故障定位困难等挑战。为解决这些问题,推荐了.NET微服务框架Wing。
|
6月前
|
监控 Java 数据库
「架构」微服务
微服务架构将应用拆分成小服务,每个服务聚焦特定功能,通过轻量级通信协同工作。特点是松耦合、独立部署和扩展。优点包括灵活性、可维护性和容错性,但也有复杂性、数据一致性和网络延迟等挑战。设计策略遵循单一职责、明确API和服务自治。实现时常用技术如Spring Cloud、Docker、Kubernetes和Prometheus等。
33 0
|
7月前
|
XML 监控 API
初探微服务架构
初探微服务架构
|
API 持续交付 数据库
你真的了解微服务架构吗?
你真的了解微服务架构吗?
|
SQL 缓存 运维
微服务架构解决了什么问题
微服务架构解决了什么问题
211 0
微服务架构解决了什么问题
|
存储 大数据 数据库
元数据驱动的微服务架构(上)
传统的模型方式的核心目标是能够自动生成代码,故定义过于复杂。而微服务间的“语言”的目标与传统不同,用元数据作为“语言”驱动整个微服务架构是不错的选择。本文为普元软件产品部副总兼大数据产品线总经理王轩在云计算架构设计群的微课堂分享。
7539 0
|
存储 安全 Java
微服务架构 | 7. 安全保护
安全性是暴露由许多微服务组成的公共访问 API 时要考虑的最重要的一个方面。Spring 有一些有趣的功能和框架,使我们的微服务安全配置更容易;
398 0
微服务架构 | 7. 安全保护
|
敏捷开发 运维 NoSQL
什么是微服务架构?
什么是微服务架构?
231 0
什么是微服务架构?