什么是OpenFeign?
Feign是一个声明式Web Service客户端。使用Feign能让编写Web Service客户端更加简单。也就是为了使用Java HTTP客户端变得更加容易。通俗的讲就是发起一个HTTP请求,获取资源的操作。
OpenFeign是Feign的升级版,支持了Spring MVC的注解并且它们的底层都结合了Ribbon进行负载均衡操作。
以上描述我们可以清楚的了解它的本质也就是一个Http请求操作而已,简化了代码,一个注解即可。
OpenFeign的基础使用
接下来就需要我们在页面方面处理,具体如下:
利用以前学习Spring Cloud中的资源进行演示:
将服务注册在Eureka集群中:
目前Eureka出过文章,若不了解的话,请参考文章。
通过OpenFeign+Ribbon将请求分发在我们所需要的系统上:
目前Ribbon出过文章,若不了解的话,请参考文章。
OpenFeign的基础配置以及使用:
OpenFeign POM文件
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
OpenFeign 建立请求配置
# Feign的连接建立超时时间,默认为10秒
feign.client.config.default.connectTimeout=10000
# Feign的请求处理超时时间,默认为60
feign.client.config.default.readTimeout=60000
# Feign使用默认的超时配置,在该类源码中可见,默认单次请
feign.client.config.default.retryer=feign.Retryer.Default
# 为指定类设置日志级别
# 开启openfeign的日志功能,并设置日志级别
# feign日志以什么级别监控哪个接口
logging.level.com.service.ILoadBalancerService=info
Hystrix在此处也可以进行配置,但是目前官网不进行更新了,了解一下即可!
接口配置以及开启OpenFeign:
开启OpenFeign注解:
@EnableFeignClients
OpenFeign接口配置:
// @FeignClient 里面的Value的值也就是注册中心的服务实例名
@Component
@FeignClient(value = "EUREKA-ORDER")
public interface ILoadBalancerService {
// 对应微服务名称下的接口地址
@RequestMapping(value = "")
Staff getMyStaff(@RequestParam("staffIdNo")String staffIdNo);
}
把交给Spring管理的对象,直接注入使用即可!
若需要打印日志的话,增加配置文件即可!具体日志级别以及配置如下所示:
Hystrix结合OpenFeign简单了解与使用
开启断路器:
feign.hystrix.enabled=true
配置服务降级的方法fallback:
@Component
@FeignClient(value = "EUREKA-ORDER",fallback=类.class)
// 对应微服务名称下的接口地址
@RequestMapping(value = "/order/userController/getMyStaff")
Staff getMyStaff(@RequestParam("staffIdNo")String staffIdNo);
}
/**
* 服务降级:
* 若微服务端(被调用方)没自定义降级操作,那么使用调用方定义的降级操作方法。
* 若微服务(被调用方)自定义降级操作,那么使用被调用方的降级操作方法
*/
@Component
public class LoadBalancerService implements ILoadBalancerService {
@Override
public Staff getMyStaff(String staffIdNo) {
return "getHystrix 降级操作";
}
}
以上就是Hystrix服务降级的简单使用!当然Hystrix也有监控页面以及全局降级、自定义降级配置用来更好的解决服务降级!
针对某个方法使用自定义的服务降级配置如下选择符合自己配置即可。不建议学习,因为官方停止更新了,参考一下即可!