eureka注册中心上的服务消费者访问服务提供者(重要!!!!!)

本文主要是介绍eureka注册中心上的服务消费者访问服务提供者(重要!!!!!),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原理:

其中涉及到3中角色:

服务注册中心:作为eureka的一个server,提供服务注册和发现的功能。在启动类中加注解@EnableEurekaServer

服务提供者:作为eureka的一个客户端组件,可以对外提供服务。在启动类中加注解@EnableEurekaClient

服务消费者:作为eureka的一个客户端组件,用来消费服务。在启动类中加注解@EnableEurekaClient

过程:

1.服务注册中心eureka server先启动

2.eureka client的服务提供者向服务注册中心eureka server进行注册。

3.eureka client的服务消费者向服务注册中心eureka server注册,同时从注册中心获取一份服务注册列表的信息,该列表包含了所有向服务注册中心eureka server注册的服务信息。获取服务注册列表信息之后,服务消费者就知道服务提供者的IP地址,可以通过HTTP远程调度来访问提供者提供的服务。

4.服务消费者和服务提供者对于服务注册中心来讲,都是客户端。

consumer:

controller:

package com.ljf.weifuwu.springcloud.eureka.consumer.controller;import com.ljf.weifuwu.springcloud.eureka.consumer.model.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;@RestController
public class ConsumerUserController
{   @Autowired
private RestTemplate restTemplate;@GetMapping("/consumer-eureka/{id}")public User findById(@PathVariable Long id) {return this.restTemplate.getForObject("http://localhost:7900/eureka-provider/" + id, User.class);//为何不能用下面这种方式??????????//return this.restTemplate.getForObject("http://ms-eureka-provider/eureka-provider/" + id, User.class);}
}

启动类:

package com.ljf.weifuwu.springcloud.eureka.consumer;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;/*** Hello world!**/
@SpringBootApplication
@EnableEurekaClient
public class ConsumerEurekaApp
{   @Bean
public RestTemplate restTemplate() {return new RestTemplate();
}public static void main( String[] args ){SpringApplication.run(ConsumerEurekaApp.class, args);System.out.println( "eureka-consumer启动起来了!!!" );}
}

provider:

controller:

package com.ljf.weifuwu.springcloud.eureka.provider.controller;import com.ljf.weifuwu.springcloud.eureka.provider.model.EurekaUser;import com.ljf.weifuwu.springcloud.eureka.provider.respository.EurekaUserRespository;
import com.netflix.appinfo.InstanceInfo;
import com.netflix.discovery.EurekaClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;@RestController
public class UserController {@Autowired@Qualifier("eurekaClient")private EurekaClient eurekaClient;@Autowiredprivate DiscoveryClient discoveryClient;@Autowiredprivate EurekaUserRespository userRepository;@GetMapping("/eureka-instance")public String serviceUrl() {//和配置文件配置的application.name=ms-eureka-provider保持一致//获取配置文件的ip和端口号:http://localhost:7900/eureka-instanceInstanceInfo instance = this.eurekaClient.getNextServerFromEureka("ms-eureka-provider", false);return instance.getHomePageUrl();}@GetMapping("/instance-info")public ServiceInstance showInfo() {//http://localhost:7900/instance-info//"host":"192.168.1.225","port":7900,"serviceId":"ms-eureka-provider","metadata":{},"secure":false,"uri":"http://192.168.1.225:7900"}ServiceInstance localServiceInstance = this.discoveryClient.getLocalServiceInstance();return localServiceInstance;}@GetMapping("/eureka-provider/{id}")public EurekaUser getSingleUser(@PathVariable Long id){return this.userRepository.findOne(id);}
}

respository:

package com.ljf.weifuwu.springcloud.eureka.provider.respository;import com.ljf.weifuwu.springcloud.eureka.provider.model.EurekaUser;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface EurekaUserRespository extends JpaRepository<EurekaUser, Long> {}data.sql:
insert into eurekauser(id,username, name, age, balance) values(1,'user1', 'liu', 20, 100.00);
insert into eurekauser(id,username, name, age, balance) values(2,'user2', 'jian', 20, 100.00);
insert into eurekauser(id,username, name, age, balance) values(3,'user3', 'fu', 20, 100.00);
insert into eurekauser(id,username, name, age, balance) values(4,'user4', 'jurf', 20, 100.00);

schema.sql:

drop table eurekauser if exists;
create table eurekauser(id bigint generated by default as identity,username varchar(40),name varchar(20),age int(3),balance decimal(10,2), primary key(id)
);

启动类:

package com.ljf.weifuwu.springcloud.eureka.provider;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;/*** Hello world!**/
@SpringBootApplication
@EnableEurekaClient
public class EurekaProviderApp
{public static void main( String[] args ){SpringApplication.run(EurekaProviderApp.class,args);System.out.println( "eurka中的提供者启动成功!" );}
}

页面访问:http://localhost:7901/consumer-eureka/1

 

 

这篇关于eureka注册中心上的服务消费者访问服务提供者(重要!!!!!)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1013241

相关文章

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

通过配置nginx访问服务器静态资源的过程

《通过配置nginx访问服务器静态资源的过程》文章介绍了图片存储路径设置、Nginx服务器配置及通过http://192.168.206.170:8007/a.png访问图片的方法,涵盖图片管理与服务... 目录1.图片存储路径2.nginx配置3.访问图片方式总结1.图片存储路径2.nginx配置

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方