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

相关文章

nginx跨域访问配置的几种方法实现

《nginx跨域访问配置的几种方法实现》本文详细介绍了Nginx跨域配置方法,包括基本配置、只允许指定域名、携带Cookie的跨域、动态设置允许的Origin、支持不同路径的跨域控制、静态资源跨域以及... 目录一、基本跨域配置二、只允许指定域名跨域三、完整示例四、配置后重载 nginx五、注意事项六、支持

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

linux ssh如何实现增加访问端口

《linuxssh如何实现增加访问端口》Linux中SSH默认使用22端口,为了增强安全性或满足特定需求,可以通过修改SSH配置来增加或更改SSH访问端口,具体步骤包括修改SSH配置文件、增加或修改... 目录1. 修改 SSH 配置文件2. 增加或修改端口3. 保存并退出编辑器4. 更新防火墙规则使用uf

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

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指令