博客
关于我
Springcloud微服务-组件三Ribbon
阅读量:521 次
发布时间:2019-03-07

本文共 1073 字,大约阅读时间需要 3 分钟。

继上两篇接着说我们将服务注册到Eureka注册中心后,那么服务之间的调用是怎么完成的?

我们的消费者想要去注册中心上消费我们的服务这里就需要使用到springcloud 的组件ribbon 。

一、Ribbon是什么?

Ribbon是一个基于HTTP和TCP的客户端负载均衡器。当使用Ribbon对服务进行访问的时候,它会实现从Eureka注册中心中获取服务端列表,并通过Eureka客户端来确定服务端已经启动。Ribbon在Eureka客户端服务发现的基础上,实现了对服务实例的选择策略,因此Ribbon也是实现负载均衡的策略的。

二、Ribbon在项目中怎么使用?

1、起步依赖

org.springframework.cloud
spring-cloud-starter-netflix-eureka-client

2、激活 Eureka 中的EnableEurekaClient 功能:

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

3、配置服务的名称和注册中心的地址:

spring.application.name=03-springcloud-web-consumereureka.client.service-url.defaultZone=http://localhost:8761/eureka

4、Ribbon来实现服务的调用

@loadBalance 该注册就是Ribbon的核心,Springcloud对Ribbon实现的封装,让我们开发变得非常的方便,我们在项目中一般会见一个配置类,例如:

@LoadBalanced@Beanpublic RestTemplate restTemplate () { return new RestTemplate();}

那么我们可以说我们新建了一个RestTemplate模板对象,交由spring来管理,我们需要调用微服务的时候就可以使用该模板对象来调用了。例如

需要注意的时:加入了Ribbon的支持,在调用服务的过程中,就是使用服务的名称来调用。

restTemplate.getForEntity("http://01-SPRINGCLOUD-SERVICE-PROVIDER/cloud/hello", String.class).getBody();

转载地址:http://wnunz.baihongyu.com/

你可能感兴趣的文章
Nacos在双击startup.cmd启动时提示:Unable to start embedded Tomcat
查看>>
Nacos基础版 从入门到精通
查看>>
Nacos如何实现Raft算法与Raft协议原理详解
查看>>
Nacos安装教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(上)
查看>>
Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(下)
查看>>
Nacos心跳机制实现快速上下线
查看>>
nacos报错com.alibaba.nacos.shaded.io.grpc.StatusRuntimeException: UNAVAILABLE: io exception
查看>>
nacos服务提供和发现及客户端负载均衡配置
查看>>
Nacos服务注册与发现demo
查看>>
Nacos服务注册与发现的2种实现方法!
查看>>
nacos服务注册和发现原理简单实现案例
查看>>
Nacos服务注册总流程(源码分析)
查看>>
nacos服务注册流程
查看>>
Nacos服务部署安装
查看>>
nacos本地可以,上服务器报错
查看>>
Nacos注册Dubbo(2.7.x)以及namespace配置
查看>>
Nacos注册中心有几种调用方式?
查看>>
nacos注册失败,Feign调用失败,feign无法注入成我们的bean对象
查看>>
nacos源码 nacos注册中心1.4.x 源码 nacos源码如何下载 nacos 客户端源码下载地址 nacos discovery下载地址(一)
查看>>