博客
关于我
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加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(2)~单表查询、mysql查询常用的函数
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
MySQL千万级多表关联SQL语句调优
查看>>
mysql千万级大数据SQL查询优化
查看>>
MySQL千万级大表优化策略
查看>>
MySQL单实例或多实例启动脚本
查看>>
MySQL压缩包方式安装,傻瓜式教学
查看>>
MySQL原理、设计与应用全面解析
查看>>
MySQL原理简介—1.SQL的执行流程
查看>>
MySQL原理简介—10.SQL语句和执行计划
查看>>
MySQL原理简介—11.优化案例介绍
查看>>
MySQL原理简介—12.MySQL主从同步
查看>>
MySQL原理简介—2.InnoDB架构原理和执行流程
查看>>
MySQL原理简介—3.生产环境的部署压测
查看>>
MySQL原理简介—6.简单的生产优化案例
查看>>