springcloud中服务间的调用,注册中心的使用,Ribbon的负载均衡以及feign使用接口方式调用服务

当一个springcloud项目使用了eureka和ribbon后在使用feign来做接口服务调用(本人不喜欢这种方式,相当于多加了一层)
在原先中用Ribbon做负载均衡
在这里插入图片描述

首先,我们再没有进行负载均衡,也就是没有使用Ribbon时,我们进行服务的调用,只能通过 RestTemplate 来进行服务调用。

第一步,实例化RestTmplate
我们通过配置类,装bean
在这里插入图片描述

第二步,在我们的调用服务的控制层,进行调用
在这里插入图片描述
第三步,这种直接根据所要调用的服务地址,来进行服务调用的方式
在这里插入图片描述
这里面的方法,就是直接通过restTemplate.postForObject或者是restTemplate.getForObject方法进行调用,也就是post方法与get方法,
里面的参数就是(url,requestMap,ResponseBean.class) 这三个参数分别代表
REST请求地址,请求参数,Http响应转换 被 转换成的对象类型。
url就是我们所定义的地址加上所要调用服务端的完整请求url
在这里插入图片描述
这就是提供服务的那一端的方式
在这里插入图片描述
以上就是简单的直接进行服务间调用的方式!!!

用注册中心Eureka,来获取服务!!!
建一个项目,当作注册中心
导包,写配置,启动类上加注解@EnableEurekaServer //EnableEurekaServer表示这是服务端的启动类,可以接受别人注册进来
这一步省略
我们将提供服务端(提供服务)的启动类上加上这个注解
在这里插入图片描述
在调用服务的服务端(获取服务)的启动类上也加上这个注解,
**但是!!!**区别在于获取服务的这一段不像注册中心进行注册,因为我们要去取服务,所以不用把自身注册进去。而提供服务的那一段要把自己注册进去,供获取服务的这一端进行调用!
可以搭建个eureka集群,就是把上面写的eureka注册中心,在copy几份,就只更改个配置文件,更爱defaultZone,将不同的ip加端口号,加进去,把几个注册中心关联起来,就是eureka集群
在这里插入图片描述
同时提供服务的那一端就的配置文件也要改,也是改defaultZone
在这里插入图片描述
获取服务的那一端也要改
在这里插入图片描述
到如此,我们可以从集群中获取服务,而且使用Ribbon获取服务时
要加上注解@LoadBalanced
在这里插入图片描述

获取服务端的controller层(也就是调用服务的那一层)也要改变

这时候,用Ribbon的方式做了负载均衡,从三个Eureka注册中心中,选择一个获取服务,所以我们之前调用的那种,写死提供服务端的url这种方式就不行了。
这时候调用的方式发生改变,也就是我们之前写的地址变为这个,也即是提供服务的那一端,向注册中心注册自己的时候取的名字。根据这个,从注册中心,拿到服务进行调用!(仅仅只改个这个地址)
在这里插入图片描述

这种服务间的调用也完成了。

我们如果要看见负载均衡的效果,我们可以多写几个提供服务端,就是把上面的提供服务端,多copy几份,改个端口,充当不同的服务器。
在这里插入图片描述
将这几个提供服务端开启,放入注册中心,可以看见后面显示了三个相同服务,却在不同服务器上的场景。

我们可以开启获取服务端,不断发起请求,来看是否进入到了不同的提供服务端!!!

如果我们要使用Feign

feign是声明式的web service客户端,它让微服务之间的调用变得更简单了,类似controller调用
service。
Spring Cloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端。
只需要创建一个接口,然后添加注解即可!
feign ,主要是社区,大家都习惯面向接口编程。这个是很多开发人员的规范。调用微服务访问两种方法:

  1. 微服务名字 【ribbon】
  2. 接口和注解 【feign 】

Feign旨在使编写Java Http客户端变得更容易
前面在使用Ribbon + RestTemplate时,利用RestTemplate对Http请求的封装处理,形成了一套模板化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用。所以,Feign在此基础上做了进一步封装,由他 来帮助我们定义和实现依赖服务接口的定义,在Feign的实现下,我们只需要创建一个接口并使用注解的方式来配置它(类似于以前Dao接口上标注Mapper注解,现在是一个微服务接口上面标注一个Feign注解即可。)即可完成对服务提供方的接口绑定,简化了使用Spring Cloud Ribbon时,自动封装服务调用客户端的开发量。

用了Feign,也即是加了一层
用接口的方式实现调用服务在这里插入图片描述
就像以前我们写的service,然后我们调用服务端的controller变为这样:
在这里插入图片描述
就像controller层调用service层,Feign就干这个!!!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值