在上面这个案例中进行修改
首先在Order项目中添加feign客户端依赖,因为它是调用者
<!--开启feign客户端-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
然后写一个feign客户端的接口,feign客户端是采用接口的形式来进行调用服务的,底层还是使用httpclient来进行远程调用的,只不过书写更加简便明了了.
package com.buba.feign;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
//参数填要调用服务的名称
@FeignClient(name = "app-buba-member")
public interface MemberApiFeign {
//在这里只需要写服务的方法就可以了,使用SpringMVC方式调用服务
//也就是服务那边的方法怎么写的,这直接复制就可以了,然后把方法体删掉
@RequestMapping("getMember")
public String getMember();
}
controller使用中只需要注入接口,然后调用接口的方法就可以了.注意Controller中方法名不能和Feign中方法名一样,,不然会报映射错误
在启动类上写@EnableFeignClients来开启feign权限
启动测试,就可以访问到了
设置feign的超时时间
在服务中让等待1.5秒再进行访问的话,会发现报错了
这就是访问超时了,feign默认的处理时间是1秒,在1秒内如果没相应成功就会报错,那怎么办呢?
加上以下配置就可以修改超时时间了,配在消费者Order这边
###设置feign客户端超时时间
###指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间。
ribbon.ReadTimeout=5000
###指的是建立连接后从服务器读取到可用资源所用的时间。
ribbon.ConnectTimeout=5000
feign客户端默认支持ribbon的,也可以直接做负载均衡