博客
关于我
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/

你可能感兴趣的文章
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>
mysql添加用户及权限
查看>>
Mysql添加用户并授予只能查询权限
查看>>
mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>
mysql清理undo线程_MySQL后台线程的清理工作
查看>>