简配Eureka Server、Eureka Discovery Client、feign及遇到的问题

本文介绍了如何使用SpringBoot构建微服务架构,包括设置EurekaServer,添加EurekaDiscoveryClient,以及集成Feign进行服务调用。详细步骤涉及新模块创建、依赖管理、配置和测试等内容。
摘要由CSDN通过智能技术生成

一、Eureka Server

1.1、项目new-module-Spring Initializr,现在jdk仅支持17及以上版本

1.2、注意Spring Boot版本,勾选Eureka Server,点击Create

1.3、配置该模块下的application文件

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    register-with-eureka: false
    fetch-registry: false
    service-url:
      defaultZone: http://localhost:8761/eureka

4、Application类使用 @EnableEurekaServer,否则会报错 

Cannot invoke "org.springframework.cloud.netflix.eureka.CloudEurekaClient.getApplications()" because the return value of "org.springframework.cloud.netflix.eureka.serviceregistry.EurekaRegistration.getEurekaClient()" is null

二、Eureka Discovery Client

2.1本次操作从 start.spring.io 中下载,添加的依赖有Eureka Discovery Client、MyBatis Framework、MySQL Driver、Spring Web,点击GENERATE生成压缩文件

2.2解压压缩文件,复制到工作空间的项目中,idea将自动导入(此时两个项目还没有相关性,需要添加到mvn列表里);在idea界面maven project的“+”,选择文件,package有蓝光表示导入成功。

2.3在Application.java添加@EnableDiscoveryClient

2.4、配置该模块下的application文件

2.5、启动Eureka Server、Eureka Client,输入网址localhost:8761

三、feign

3.1、重复1.1步骤(注意name)

3.2、选择dependencies

3.3、在Application.java添加@SpringBootApplication、@EnableDiscoveryClient、@EnableFeignClients

3.4、配置该模块下的application文件

server:
  port: 8081
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka
spring:
  application:
    name: base

cloud:
  openfeign:
    client:
      config:
        feignName:
          connect-timeout: 5000
          read-timeout: 5000

3.5、测试

a、templates下编写index.html,发送test1.do请求,

b、请求到达TestAction类,在类上用@RestController或@Controller处理,在方法上使用@RequestMapping标注访问路径,

c、运行BaseApplication类

d、访问localhost:8081,点击test1,显示“ok”,成功

  • 19
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Eureka Server是Netflix开源的服务发现组件,用于实现微服务架构中的服务注册与发现。它充当了服务注册中心的角色,负责管理所有微服务的注册信息,并提供查询、监控等功能。 Eureka Client是基于Eureka Server的客户端,用于将自己的服务注册到Eureka Server上,并从Eureka Server上获取其他服务的信息。它可以自动地将自己的服务注册到Eureka Server上,并定时向Eureka Server发送心跳,以保证自己的服务状态始终可用。同时,它还可以从Eureka Server上获取其他服务的信息,以便进行服务调用。 ### 回答2: Eureka是Netflix开发的一套基于REST的服务发现系统,允许服务在运行期间注册、协调和发现。Eureka由两个主要组件构成:Eureka serverEureka clientEureka serverEureka系统的核心组件,它是服务注册中心。Eureka server维护着所有可用服务的信息,包括服务的实例列表、IP地址和端口号等。Eureka server还会定期检查服务的可用性,以便列表中只包含可用的服务实例。服务实例将自己注册到Eureka server,并向其发送心跳以表明自己仍然可用。Eureka server还会在服务实例出现故障或无响应时将其从列表中删除,确保调用者只会访问到可用的服务。 Eureka client是服务提供方的组件,它将自己注册到Eureka server并发送心跳以表明自己仍然可用。Eureka client会定期从Eureka server获取服务列表,以便知道哪些服务实例是可用的。一旦服务实例出现故障或无响应,Eureka client会重新注册自己以确保服务列表的正确性。 Eureka serverEureka client的结合使得我们能够轻松地实现服务的注册、发现和协调,实现服务间的高效通信。Eureka还提供了丰富的扩展点和API,允许我们自定义各种功能和策略,以满足不同场景和需求的要求。 ### 回答3: Eureka是Netflix开源的一款服务发现框架,它支持在云端部署的服务,它能够帮助我们在环境中(如微服务架构)自动化的管理和维护服务的地址,从而使各个服务之间更加高效和协作。其中,Eureka ServerEureka Client分别是Eureka的服务端和客户端。 Eureka Server是一个可用的服务注册中心,在微服务架构中,它扮演了一个重要的角色。Eureka Server负责维护注册表,所有的微服务都可以在这个注册中心注册自己,记录它们所处的地址以及端口等(在Eureka Server中他们被称之为服务实例)。 对于一个服务,当这个服务确定好自己的服务ID、服务名和服务地址等信息后,首先需要将自己注册到Eureka Server中,这样其他微服务才能够通过查询到这个服务所在的地址,来访问到这个服务。 而Eureka Client则扮演着微服务的客户端,他是整个微服务系统中向注册中心Eureka Server注册的微服务,就像是公司ERP系统那样的一个客户端,负责跟Eureka Server通信、注册微服务实例,以及从Eureka Server中查询服务实例列表等等。 在微服务架构中,微服务的数量很多。当微服务的数量越来越多时,Eureka Server作为微服务的注册中心起到了非常重要的作用,它们可以更方便的找到其他服务以及管理和协调服务。而Eureka Client则为各个微服务之间提供了一个很好的通信平台,协同运行微服务。 总之,Eureka ServerEureka Client是构成Eureka体系的两个重要组成部分,它们能够共同协作,来建立一个高效的微服务体系,为现代化的应用架构提供了必要的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值