Eureka+Ribbon实现服务注册与发现

目录

一、相关文章

二、兼容说明

三、服务注册

四、服务发现


一、相关文章
二、兼容说明
  • 与SpringBoot3兼容的SpringCloud里的eureka-client依赖不含Ribbon,新增了LoadBalancer。

  • 如果想使用Ribbon,需要使用SpringBoot2,兼容版本参照https://blog.csdn.net/cherishSpring/article/details/149472557

  • 使用SpringBoot3,即使单独引用了Ribbon也是不生效的。

  • 如果是按SpringBoot3.2.4创建的工程,需要将一些配置改为如下:

Groovy 复制代码
plugins {  
	id 'org.springframework.boot' version '2.3.12.RELEASE'  
	id 'io.spring.dependency-management' version '1.0.11.RELEASE' // 引入dependency-management插件  
}

//JDK版本太高可能和SpringBoot不兼容
sourceCompatibility = 11  
targetCompatibility = 11

runtimeOnly 'mysql:mysql-connector-java'

//mybatis  
implementation 'org.mybatis.spring.boot:mybatis-spring-boot-starter:2.3.1'

//mybatis-plus  
implementation 'com.baomidou:mybatis-plus-boot-starter:3.5.2'
三、服务注册

1、父工程build.gradle引入版本依赖管理

Groovy 复制代码
dependencyManagement {  
	//版本号需根据springboot版本确定
	imports { mavenBom "org.springframework.cloud:spring-cloud-dependencies:Hoxton.SR12" }  
} 

2、子工程build.gradle引入eureka-client

Groovy 复制代码
//eureka-client  
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'

3、配置application.yml

Groovy 复制代码
eureka:  
	client:  
		service-url:  
			# 注册中心地址  
			defaultZone: http://127.0.0.1:10086/eureka/  
  
user-service:  
	ribbon:  
		# eureka负载均衡规则  
		NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule  
  
ribbon:  
	eager-load:  
		# 开启饥饿加载,启动时初始化,给首次访问加速  
		enabled: true  
		clients:  
			# 指定饥饿加载的服务名称  
			- user-service

4、参考idea中同服务启动多个-CSDN博客启动两个user-service,在Eureka服务端查看

四、服务发现

1、在OrderApplication类创建RestTemplate

java 复制代码
@Bean  
@LoadBalanced  //添加使用负载均衡注解
RestTemplate restTemplate() {  
	return new RestTemplate();  
}

2、服务远程调用

java 复制代码
//示例:在order服根据用户ID拉取user服用户信息
@Override  
public Order getOrderById(Long orderId) {  
	//获取订单信息  
	Order order = orderMapper.getOrderById(orderId);  
	  
	//根据订单用户ID获取用户信息,通过host:port拼接请求路径
	//String url = "http://localhost:8083/user/" + order.getUserId();  
	
	//eureka方式:通过user-service服务名拼接请求路径
	String url = "http://user-service/user/" + order.getUserId();  
	
	//执行远程调用
	User user = restTemplate.getForObject(url, User.class);  
	order.setUser(user);  
	  
	return order;  
}
相关推荐
广州服务器托管10 小时前
NVIDIA最新591.74显卡驱动精简版:支持DLSS 4.5、所有RTX显卡都可使用,最新N卡驱动下载
计算机网络·网络安全·云原生·个人开发·可信计算技术
lbb 小魔仙13 小时前
【Linux】云原生运维效率提升:Linux 终端工具链(kubectl + tmux + fzf)组合拳教程
linux·运维·云原生
Cyber4K17 小时前
【Kubernetes专项】DockerFile、数据持计划、网络模式及资源配额
运维·网络·云原生·容器·kubernetes
Zsr102318 小时前
K8s核心组件Pod:基础篇
云原生·容器·kubernetes
nix.gnehc18 小时前
Serverless
云原生·serverless
拔剑纵狂歌18 小时前
helm-cli安装资源时序报错问题问题
后端·docker·云原生·容器·golang·kubernetes·腾讯云
techzhi18 小时前
Docker & Docker Compose 安装方案
docker·容器·eureka
weixin_4481199419 小时前
如何装docker
java·云原生·eureka
jjjxxxhhh12319 小时前
【项目】-Docker入门实战:从零到一运行FastDDS Shapes Demo
docker·容器·eureka
Aaron_94519 小时前
Pathway LLM-App:企业级AI管道与实时RAG应用的云原生解决方案
人工智能·云原生