首页 > 其他分享 >Eureka的运用(服务、注册和发现)

Eureka的运用(服务、注册和发现)

时间:2022-12-09 12:37:47浏览次数:44  
标签:服务 eureka 注册 运用 Eureka 服务端 客户端


1. 搭建与配置 Eureka 服务注册中心

第一步: 创建SpringBoot项目,并且添加相关依赖

第二步: 添加eureka的依赖

<!--Spring Cloud 的 eureka-server 起步依赖--> 
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

第三步: 在 Spring Boot 的入口类上添加一@EnableEurekaServer 注解,用于开启 Eureka 注册中心服务端

第四步: 在 application.properties 文件中配置 Eureka 服务注册中心信息

内嵌定时tomcat的端口
server.port=8761
#设置该服务注册中心的hostname
eureka.instance.hostname=localhost
#由于我们目前创建的应用是一个服务注册中心,而不是普通的应用,默认情况下,这个应用会向注册中心(也是它自己)注册它自己,设置为false表示禁止这种自己向自己注册的默认行为
eureka.client.register-with-eureka=false
#表示不去从服务端检索其他服务信息,因为自己就是服务端,服务注册中心本身的职责就是维护服务实例,它不需要去检索其他服务
eureka.client.fetch-registry=false
#指定服务注册中心的位置
eureka.client.service-url.defaultZone=http://localhost:8761/eureka

2. 启动与测试 Eureka 服务注册中心

第一步: 完成上面的项目搭建后,我们就可以启动 SpringBoot 程序,main 方法运行。(也就是启动类运行)

第二步: 启动成功之后,通过在浏览器地址栏访问我们的注册中心。

3. 向 Eureka 服务注册中心注册服务

我们前面搭建了服务提供者项目,接下来我们就可以将该服务提供者注册到 Eureke 注册中心,步骤如下:

第一步: 在该服务提供者中添加 eureka 的依赖,因为服务提供者向注册中心注册服 务,需要连接 eureka,所以需要 eureka 客户端的支持。

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

第二步: 激活 Eureka 中的 EnableEurekaClient 功能:在 Spring Boot 的入口函数处,通过添加@EnableEurekaClient 注解来表明自己是一个 eureka 客户端,让我的服务提供者可以连接 eureka 注册中心。

第三步: 配置服务名称和注册中心地址

#每间隔2s,向服务端发送一次心跳,证明自己依然"存活"
eureka.instance.lease-renewal-interval-in-seconds=2
#告诉服务端,如果我10s之内没有给你发心跳,就代表我故障了,将我踢出掉
eureka.instance.lease-expiration-duration-in-seconds=10
#告诉服务端,服务实例以IP作为链接,而不是取机器名
eureka.instance.prefer-ip-address=true
#告诉服务端,服务实例的名字
eureka.instance.instance-id=34-springcloud-service-goods
#eureka注册中心的连接地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka

第四步: 启动服务提供者 SpringBoot 程序的 main 方法运行。 (springboot的启动类)

第五步: 启动运行之后,通过在浏览器地址栏访问我们之前搭建好的 eureka 注册中心,就可以看到有一个服务已经注册成功了。

4. 从 Eureka 服务注册中心发现与消费服务

服务的发现由 eureka 客户端实现,而服务的消费由 Ribbon (负载均衡) 实现,也就是说服务的调用需要 eureka 客户端和 Ribbon(负载均衡),两者配合起来才能实现。

Eureka 客户端是一个 Java 客户端,用来连接 Eureka 服务端,与服务端进行交互、负载均衡,服务的故障切换等。

Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡器,当使用 Ribbon 对服务进行访问的时候,它会扩展 Eureka 客户端的服务发现功能,实现从Eureka 注册中心中获取服务端列表,并通过 Eureka 客户端来确定服务端是否己经启动。

Ribbon 在 Eureka 客户端服务发现的基础上,实现了对服务实例的选择策略, 从而实现对服务的负载均衡消费。

接下来我们来让服务消费者去消费服务:

我们前面搭建了服务消费者项目,接下来我们就可以使用该服务消费者通过注册 中心去调用服务提供者,步骤如下:

第一步: 在该消费者项目中添加 eureka 的依赖,因为服务消费者从注册中心获取服 务,需要连接 eureka,所以需要 eureka 客户端的支持。

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

第二步: 激活 Eureka 中的 EnableEurekaClient 功能: 在 Spring Boot 的入口函数处,通过添加@EnableEurekaClient 注解来表明自己是一个 eureka 客户端,让我的服务消费者可以使用 eureka 注册中心.

第三步: 配置服务的名称和注册中心的地址:

spring.application.name=34-springcloud-service-portal
eureka.client.service-url.defaultZone=http://localhost:8761/eureka

第四步: 前面我介绍了服务的发现由 eureka 客户端实现,而服务的真正调用由 ribbon实现,所以我们需要在调用服务提供者时使用 ribbon 来调用:

@LoadBalanced//使用Ribbon实现负载均衡的调用
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}

加入了 ribbon 的支持,那么在调用时,即可改为使用服务名称来访问:

//这个地址是服务端名称
restTemplate.getForEntity("http://34-SPRINGCLOUD-SERVICE-GOODS/service/goods", String.class).getBody();

第五步: 完成上面的步骤后,我们就可以启动消费者的 SpringBoot 程序,main 方法运行。

第六步: 启动成功之后,通过在浏览器地址栏访问我们的消费者,看是否可以正常调用远程服务提供者提供的服务。


标签:服务,eureka,注册,运用,Eureka,服务端,客户端
From: https://blog.51cto.com/u_15907536/5924850

相关文章

  • chatGPT注册流程
    chatGPT注册1.准备条件1.1需要准备国外的网络环境​ 选择海外结点(不要选择香港)1.2海外的虚拟号码​ sms-activate.org先注册搜索服务OpenAI找一个价格......
  • 初步注册
        在搜polybius的时候发现写古典密码的大佬博客居然是博客园的,印象中博客园的美工技术大概是20年前的风格(滑跪)  回头发现是可以自己编辑的,花了一点时间开通......
  • 运用ogg迁移oracle 11g到19c
    文档课题:运用ogg迁移oracle11g到19c.核心思想:利用数据泵导入导出功能初始化数据后通过OGG同步增量数据.源端:192.168.133.103数据库oracle11.2.0.464位,实例名:orcl目......
  • SourceTree免注册并连码云
    1在C:\Users\用户\AppData\Local\Atlassian\SourceTree目录下新建accounts.json其中AppData是隐藏文件夹2输入 [{"$id":"1","$type":"Sou......
  • 【数据挖掘】数据预处理和运用概念以及对鸢尾花数据集分类的分位数图和直方图的实际运
    一.数据预处理和运用1.1数据科学家在机器学习的工作统计1.2数据清理大部分的机器学习模型所处理的都是特征,特征通常是输入变量所对应的可用于模型的数值表示。大部分......
  • springcloud Eureka服务注册中心
    1.注册中心实现原理分布式微服务架构中,服务注册中心用于存储服务提供者地址信息、服务发布相关的属性信息,消费者通过主动查询和被动通知的方式获取服务提供者的地址信息,......
  • gin源码学习-路由注册(2)
    gin框架主要是在标准库net/http的基础上对路由进行改写,本文将从net/http与gin的路由注册分享路由方面的一些理解。1.net/http的路由注册1.1路由注册首先来个demo:pack......
  • Spring cloud集成 Nacos实现服务注册与发现
    Nacos服务注册与发现​​Centos7下Nacos安装和部署​​​​springcloud集成NACOS配置中心实现动态配置​​服务模块之间本来是互相独立的不能相互访问Nacos提供的注册服......
  • Eureka
    Eureka服务搭建创建一个module引入maven坐标注意这里是starter-neflix不要把starter漏掉了<!--Eureka服务器--><dependency><groupI......
  • 组件注册
    全局注册: Vue.component("my-aa",{data:function(){return{aa:"123",......