微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

springcloud中cunsul,ribbon

一 、consul

1.什么是consul

consul是用来代替eureka的框架,和eureka使用起来一样,导入的包不同。

<dependencies>
<!--SpringCloud consul-server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>

因为和eureka相似就不多赘述

 

二、ribbon

1.什么是ribbon

ribbon是用在客户端、控制客户端如何选择服务端口的控制负载均衡的工具

2.怎么使用ribbon

在eureka中,本来就有导入ribbon包,可以直接使用不必再导入

 

 

 

ribbon一般和restTempalte一起使用,这里说明一下restTemplate

RestTemplate 是由 Spring 提供的一个 HTTP 请求工具。

这里一共调用

getForObject  get方式   Objict可以理解为返回的是json类型的数据
postForObject
getForEntity     Entity 返回的是有规则的显示所有内容的对象,因为需要序列化所以调用的时间长,建议使用object然后在json解析器里剖析
postForEntity

四种方法

使用restTemplate需要在config包里新建配置信息,注入bean对象使用

 

ribbon使用步骤:

为了不让我们自定义的ribbon类被所有要使用ribbon的的客户端共享,我们必须在@ComponentScan扫描的包之外的地方再创建一个新配置

注:@ComponentScan扫描的是当前类所在的包以及子包   @SpringBootApplication注解包含此注解

方法:点击包的三角形,到看不到该类的时候就不在这包下啦

 

 

 

 如图所示在外包下创建配置

以下是所有ribbon自带调用服务算法

 

 

在主启动类添加@RibbonClient 

 

总结: ribbon在eureka就已经有包的存在所以不需要自动导包;因为要特殊配置客户端的ribbon类型所以要在CommonpentScan扫描不到的地方创建配置类,并用bean注入;在配置包RestTemplate上添加@LoadBalanced注解;在主启动类要添加@RibbonClient注解。

3.手写ribbon算法

为了清楚的看到效果,我们要在服务端的controller类里添加

 

并在原有的代码上,取消掉上面ribbon使用的注解。

思路:首先要得到在这个application的这个服务下一共有多少个服务端口(使用ServiceInstance),我们才能依据这个设计方法(略过,这个我也不会,正在思考),最后在controller层实现

创建一个接口,该接口的方法查询有多少个服务端(ServiceInstance.size()) 再创建实现类,继承该接口,再该实现类里写上设计方法

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐