首页 > 其他分享 >【Eureka】Eureka 介绍与实战

【Eureka】Eureka 介绍与实战

时间:2024-08-22 18:51:48浏览次数:19  
标签:实战 负载 服务 介绍 Server 实例 均衡 Eureka

1. Eureka 简介

Eureka 是 Netflix 开发的一个服务注册和发现组件,主要用于微服务架构中。它的核心功能是帮助微服务之间进行通讯和管理,使得服务能够动态地发现彼此,实现灵活的服务调用和负载均衡。

1.1 核心概念

  • 服务注册中心(Eureka Server):这是一个中央注册中心,所有微服务实例都会将自己的信息注册到这个中心,并定期发送心跳来维持其租约。
  • 服务提供者(Service Provider):提供服务的应用,在启动时向 Eureka Server 注册自己,并定期续租。可以是 SpringBoot 应用或其他技术实现,只要对外提供的是Rest风格服务即可。
  • 服务消费者(Service Consumer):使用服务的应用,通过 Eureka Server 查找可用的服务实例。消费应用从注册中心获取服务列表,从而得知每个服务方的信息,知道去哪里调用服务方。

1.2 工作流程

  1. 服务注册:服务实例启动时,会向 Eureka Server 注册自己的信息,包括服务名、IP地址、端口号等。
  2. 服务续租:服务实例定期(默认30秒)向 Eureka Server 发送心跳,以续租其租约。
  3. 服务注销:服务实例关闭时,会向 Eureka Server 发送注销请求。Eureka Server将此实例从注册列表中移除。
  4. 获取服务列表:服务消费者会从 Eureka Server 获取服务列表,并根据负载均衡策略选择一个服务实例进行调用。

1.3 高可用

Eureka Server 支持集群部署,多个 Eureka Server 实例相互注册,形成高可用的服务注册中心。

1.4 主要特点

  • 开源:Eureka 是开源的,可以免费使用和修改。
  • 可靠性:具有内置的容错机制,能够在服务器崩溃时保持可用。
  • 动态性:服务实例可以动态地注册和注销,适应服务的动态变化。
  • 易于集成:可以轻松地与 Spring Cloud 等框架集成。
  • 基于 RESTful:使用 RESTful API,可以与其他基于 HTTP 的服务轻松集成。
    通过使用 Eureka,可以实现以下功能:
  • 服务注册:每个微服务实例在启动时会自动将自己的信息注册到 Eureka Server。
  • 服务发现:服务可以通过 Eureka Client 查询 Eureka Server 来获取可用服务的列表。
  • 负载均衡:Eureka Client 提供了简单的轮询负载均衡策略。
  • 故障转移:如果某个服务实例出现故障,Eureka Client 会自动检测并从服务列表中移除这个实例。

Eureka 是一个强大而可靠的服务注册与发现工具,适用于云原生应用和微服务架构,能够提高系统的可用性和可伸缩性。

2. Eureka 故障处理

处理服务实例故障通常涉及以下几个步骤:

  1. 健康检查
    • 服务端检查:服务实例应定期向服务注册中心(如Eureka Server)发送心跳,表明自己处于健康状态。如果服务实例无法在预定时间内发送心跳,注册中心可能会将其标记为不健康或已下线。
    • 客户端检查:客户端在调用服务之前,可以执行健康检查,以确认服务实例是否可用。
  2. 故障检测
    • 超时检测:客户端在尝试与服务实例通信时,如果发生超时,可以认为服务实例可能出现了故障。
    • 异常检测:服务实例在处理请求时,如果抛出异常,可以根据异常类型和频率来判断服务是否出现故障。
  3. 服务下线
    • 当服务实例被检测到故障时,应该从服务注册中心下线,以避免其他客户端继续尝试调用这个故障实例。
  4. 重试机制
    • 客户端在调用服务时,如果遇到故障,可以实施重试机制,尝试其他服务实例。
  5. 负载均衡
    • 当某个服务实例故障时,负载均衡器应该能够检测到这一点,并停止向这个实例发送请求,而是将请求分发到其他健康的实例。
  6. 熔断机制
    • 当服务实例持续故障,可以启用熔断机制,暂时停止对故障服务的调用,防止系统雪崩。
  7. 故障通知
    • 系统应具备故障通知机制,当服务实例出现故障时,及时通知运维人员。
  8. 自动恢复
    • 对于可以自动恢复的故障(如临时网络问题),系统应能在问题解决后自动重新注册服务实例。
  9. 日志记录和监控
    • 记录详细的日志信息,以便分析故障原因。
    • 通过监控系统实时监控服务状态,一旦发现异常立即采取措施。
  10. 人工干预
    • 对于无法自动恢复的故障,需要人工介入进行问题排查和修复。

在微服务架构中,服务注册与发现组件(如Eureka)通常会提供上述大部分功能,以帮助自动处理服务实例的故障。通过这些机制,可以大大提高系统的稳定性和可用性。

3. Eureka 三种负载均衡策略

3.1 默认负载均衡策略

Eureka 与 Ribbon 结合使用时,Ribbon作为客户端负载均衡器,确实有一个默认的负载均衡策略。默认情况下,Ribbon 使用的是RoundRobinRule策略,这是一种简单的轮询策略,它会按照顺序逐一将请求分配到各个服务实例上。

这意味着如果你没有在配置文件中显式指定负载均衡策略,Ribbon 将默认使用RoundRobinRule。这种策略在大多数情况下都能提供基本的负载均衡功能,确保请求在各个服务实例之间均匀分布。

如果你想要查看或修改默认的负载均衡策略,可以在 Spring Cloud 应用的配置文件(application.propertiesapplication.yml)中进行设置。例如,下面是如何在application.yml中显式设置默认轮询策略的示例:

ribbon:
  eureka:
    enabled: true
  NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule

尽管这里显式设置了默认策略,实际上即使不设置,Ribbon 也会默认使用RoundRobinRule。如果你想要使用其他策略,只需要将NFLoadBalancerRuleClassName的值改为其他策略的实现类即可。

3.2 随机负载均衡策略

要设置 Ribbon 的随机负载均衡策略,你需要修改 Spring Cloud 应用的配置文件,指定使用RandomRule类作为负载均衡规则。以下是具体的步骤和示例:

  1. 添加Ribbon依赖
    确保你的 Spring Boot 项目已经包含了 Spring Cloud Ribbon 的依赖。在pom.xmlbuild.gradle文件中,你应该看到如下依赖:

    Maven示例:

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
    </dependency>
    
  2. 配置Ribbon
    在你的应用配置文件(通常是application.propertiesapplication.yml)中,设置NFLoadBalancerRuleClassName属性为com.netflix.loadbalancer.RandomRule

    application.yml配置示例:

    ribbon:
      eureka:
        enabled: true  # 确保Eureka用于服务发现
      NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule  # 设置随机负载均衡策略
    

    如果你使用的是application.properties格式,配置将如下所示:

    ribbon.eureka.enabled=true
    ribbon.NFLoadBalancerRuleClassName=com.netflix.loadbalancer.RandomRule
    
  3. 重启应用
    修改配置后,你需要重启你的Spring Boot应用,以便新的配置生效。

使用RandomRule后,Ribbon 将随机选择服务实例来处理请求,而不是按照轮询或其他规则。这适用于当你想要在服务实例之间实现真正的随机分布请求时。

Warning: 如果你在使用 Spring Cloud Finchley 或更高版本,Ribbon 已经被重新设计为通过 Spring Cloud Commons 中的LoadBalancerClient接口工作,此时配置方式可能会有所不同。在这种情况下,你可能需要使用@LoadBalanced注解来创建一个RestTemplateWebClient,并使用相应的负载均衡策略。

3.3 自定义负载均衡策略

在 Spring Cloud 中,Eureka 通常与 Ribbon 结合使用来实现客户端的负载均衡。Ribbon 是一个客户端负载均衡器,它可以与 Eureka 配合工作,根据 Eureka 中注册的服务列表来选择调用的服务实例。以下是如何配置 Eureka 的负载均衡策略的基本步骤:

  1. 添加依赖
    在你的Spring Boot应用的pom.xmlbuild.gradle文件中,确保你已经添加了Spring Cloud Eureka和Spring Cloud Ribbon的依赖。

    Maven示例:

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
    </dependency>
    
  2. 配置Ribbon
    在你的应用配置文件(如application.propertiesapplication.yml)中,你可以设置Ribbon的负载均衡策略。

    示例配置:

    # application.yml
    ribbon:
      eureka:
        enabled: true  # 启用Eureka来获取服务列表
      NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule  # 负载均衡策略
    

    这里NFLoadBalancerRuleClassName是配置负载均衡规则的关键。以下是一些常用的负载均衡规则:

    • com.netflix.loadbalancer.RoundRobinRule:轮询策略,默认策略。
    • com.netflix.loadbalancer.RandomRule:随机策略。
    • com.netflix.loadbalancer.AvailabilityFilteringRule:会过滤掉故障实例和那些高并发连接的实例。
    • com.netflix.loadbalancer.WeightResponseTimeRule:根据响应时间加权选择服务器。
    • com.netflix.loadbalancer.BestAvailableRule:选择并发请求最小的服务器。
  3. 自定义负载均衡策略
    如果你需要自定义负载均衡策略,可以创建一个类实现IRule接口,然后配置你的应用使用这个类。

    示例代码:

    public class MyCustomRule extends AbstractLoadBalancerRule {
        @Override
        public Server choose(Object key) {
            // 自定义选择逻辑
            return null;
        }
        @Override
        public void initWithNiwsConfig(IClientConfig clientConfig) {
            // 初始化配置
        }
    }
    

    然后在配置文件中指定你的自定义规则:

    ribbon:
      NFLoadBalancerRuleClassName: com.example.MyCustomRule
    

通过以上步骤,你可以配置和自定义 Eureka 客户端的负载均衡策略,以适应特定需求。

4. Eureka 实践

下面将展示如何使用Eureka搭建一个简单的服务注册与发现环境。

1. 创建 Eureka Server

使用 Spring Initializr 创建一个 Spring Boot 项目,并添加 Eureka Server 依赖。

<!-- pom.xml -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

在主类上添加@EnableEurekaServer注解。

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

配置文件中设置 Eureka Server 的端口和其他属性。

# application.yml
server:
  port: 8761
eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
2. 创建服务提供者

创建另一个 Spring Boot 项目,并添加 Eureka Client 依赖。

<!-- pom.xml -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

在主类上添加@EnableDiscoveryClient注解。

@SpringBootApplication
@EnableDiscoveryClient
public class ServiceProviderApplication {
    public static void main(String[] args) {
        SpringApplication.run(ServiceProviderApplication.class, args);
    }
}

配置文件中指定 Eureka Server 的地址。

# application.yml
spring:
  application:
    name: service-provider
server:
  port: 8080
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
3. 创建服务消费者

创建另一个 Spring Boot 项目,添加 Eureka Client 和 Web依赖。

<!-- pom.xml -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

在主类上添加@EnableDiscoveryClient注解,并创建一个 REST 控制器。

@SpringBootApplication
@EnableDiscoveryClient
public class ServiceConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ServiceConsumerApplication.class, args);
    }
}
@RestController
public class ConsumerController {
    @Autowired
    private RestTemplate restTemplate;
    @GetMapping("/greeting")
    public String getGreeting() {
        // 假设服务提供者有一个/greeting的端点
        return restTemplate.getForObject("http://service-provider/greeting", String.class);
    }
}

配置文件中指定 Eureka Server 的地址。

# application.yml
spring:
  application:
    name: service-consumer
server:
  port: 8081
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

确保在ConsumerController中注入了RestTemplate,并在其上添加了@LoadBalanced注解,以启用负载均衡功能。

@Bean
@LoadBalanced
public RestTemplate restTemplate() {
    return new RestTemplate();
}
4. 启动服务

按照以下顺序启动服务:

  1. 启动Eureka Server:运行EurekaServerApplication的主类。
  2. 启动服务提供者:运行ServiceProviderApplication的主类,并确保它成功注册到 Eureka Server。
  3. 启动服务消费者:运行ServiceConsumerApplication的主类。
5. 测试服务发现和调用

一旦所有服务都启动并运行,你可以测试服务消费者是否能够发现服务提供者并调用其 API。

  1. 打开浏览器,访问 Eureka Server 的仪表板:http://localhost:8761/。你应该能看到注册的服务列表,包括SERVICE-PROVIDERSERVICE-CONSUMER
  2. 访问服务消费者的端点:http://localhost:8081/greeting。如果一切配置正确,你应该会看到服务提供者返回的响应。
6. 注意事项
  • 心跳续租:服务提供者必须定期发送心跳来续租其在 Eureka Server 上的租约。如果 Eureka Server 在90秒内没有接收到服务提供者的心跳,它会将该实例从其注册列表中移除。
  • 自我保护模式:在特定情况下,Eureka Server 可能会进入自我保护模式,这会阻止它注销那些没有发送心跳的服务实例。这是为了在网络分区或服务中断期间保持系统的稳定性。
  • 实例元数据:服务实例可以在注册时提供额外的元数据,这些元数据可以在服务发现时被消费者使用。

通过上述步骤,我们进行了 Eureka 的基本使用,并了解了它在微服务架构中的作用。Eureka 使得服务之间的发现和调用变得更加灵活和可靠,是构建分布式系统的重要组件之一。

标签:实战,负载,服务,介绍,Server,实例,均衡,Eureka
From: https://blog.csdn.net/Young_Pro/article/details/141426945

相关文章

  • 配置策略路由实战 附带基础网络知识
    背景作为一个软件开发人员,不可能做到只负责业务开发工作,一旦功能上线或者系统切换就会遇到非常多考验开发人员个人能力的场景,网络调整就是非常重要的一个方面,如果你在系统上线的过程中无法处理一些简单的网络问题或者听不懂网工在说什么,那么就会导致自己负责的工作很难推进,因......
  • 网易新闻爬虫实战
    目录1.导入所需库2.定义请求头3.获取所有板块的链接4.获取新闻标题和详情链接5.获取新闻详情页内容6.多进程加速爬取7.保存数据到CSV文件分享一个关于如何使用Python编写网易新闻爬虫的项目。在这个项目中,我们将使用requests库来获取网页源代码,使用lxml库来解......
  • 大型语言模型从训练到推理的介绍
    参考论文:https://arxiv.org/pdf/2401.02038v1一、训练方面1、数据预处理(1)除噪音a.去除离群值:使用统计方法(如z-score、IQR)识别并移除异常数据点。importnumpyasnpfromscipyimportstatsdata=np.array([10,12,12,13,12,100])#100是离群值#计算z-s......
  • 动态化-鸿蒙跨端方案介绍
    一、背景......
  • nohup介绍
    nohup介绍用途:不挂断地运行命令。语法:nohupCommand[Arg…][&]-无论是否将nohup命令的输出重定向到终端,输出都将附加到当前目录的nohup.out文件中。-如果当前目录的nohup.out文件不可写,输出重定向到$HOME/nohup.out文件中。-如果没有文件能创建或打开以用......
  • MySQL 亿级数据平滑迁移实战
    作者:来自vivo互联网服务器团队-LiGang本文介绍了一次MySQL数据迁移的流程,通过方案选型、业务改造、双写迁移最终实现了亿级数据的迁移。一、背景预约业务是vivo游戏中心的重要业务之一。由于历史原因,预约业务数据表与其他业务数据表存储在同一个数据库中。当其他业务......
  • JAVA 的介绍和安装
    JAVA的介绍和安装Java的三大版本JavaSE:标准版(桌面程序,控制器开发)JavaME:嵌入式开发(忽略)JavaEE:E企业级开发(web端,服务器开发……)学习思路SE→EEJava的组成JDK、JRE、JVMJDK:javadevelopmentkit(java开发者工具)JRE:JavaruntimeenvironmentJVM:javavirtu......
  • AI大模型应用开发实战-Agent应用对话情感优化
    1使用prompt设计agent性格与行为添加系统prompt:代码语言:python代码运行次数:0复制CloudStudio代码运行self.SYSTEMPL="""你是一个非常厉害的算命先生,你叫JavaEdge人称Edge大师。以下是你的个人设定:1.你精通阴阳五行,能够算命、紫薇斗数、姓名测算......