springcloud hystrix+openfeign服务降级案例


前言

随着springcloud的使用越来越多,最近使用了服务降级功能,写出来作为自己的记录以及分享。

一、环境准备

1.本次环境springcloud版本为

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Greenwich.RELEASE</version>
            </dependency>

springboot版本为

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.5.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

前置准备
1.一个producer服务,一个comsumer服务,一个eureka服务。
这个就不展示了,其他博客教程很多,这里主要演示服务降级相关内容。

二、使用步骤

服务降级可以分为两种,一个是客户端降级,一个是服务端降级。
如果服务端配置了降级,那么就是服务端的降级生效,否则是客户端生效,下面两种情况都会做演示。

1.客户端降级

1.1 引入hystrix包,其实不引入也可以,openfeign已经引入了这个包了。

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

1.2 开启hystrix
springcloud hystrix+openfeign服务降级案例_第1张图片
1.3 配置文件application.yml加上配置

#开启feign.hystrix服务降级功能
feign:
  hystrix:
    enabled: true

1.4 调用openfeign的接口写上FallbackFactory参数,这里的sayhello就是我们要调用的远程服务方法。

@FeignClient(value = "eureka-service-hi",fallbackFactory = RemoteInterfaceImpl.class)
@Component
public interface RemoteInterface {

    @RequestMapping(value = "/hello",method = RequestMethod.GET)
    public String sayHello();
}

1.5 重写降级方法,如果远程服务sayhello故障则进入下面的sayhello方法
返回fuwujiangji.

package com.my.comsumer.service.impl;

import com.my.comsumer.service.RemoteInterface;
import feign.hystrix.FallbackFactory;
import org.springframework.stereotype.Component;

@Component
public class RemoteInterfaceImpl implements FallbackFactory<RemoteInterface> {


    @Override
    public RemoteInterface create(Throwable throwable) {
        RemoteInterface remoteInterface = new RemoteInterface() {
            @Override
            public String sayHello() {
                return "fuwujiangji";
            }
        };
        return remoteInterface;
    }
}

1.6 测试结果。
消费端的control如下:

@RestController
public class Control {

    @Autowired
    private RemoteInterface remoteInterface;

    @RequestMapping(value = "/comsumer",method = RequestMethod.GET)
    public String comsumer(){
        String s = "xxxx"+remoteInterface.sayHello();

        return s;
    }
}

可以看到返回了xxxx加上fuwujiangji 符合预期结果。
springcloud hystrix+openfeign服务降级案例_第2张图片

2.服务端降级

2.1 服务端pom加上依赖

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

2.2 启动类加上注解

@SpringBootApplication
@EnableEurekaClient
@EnableHystrix
public class ProducerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ProducerApplication.class, args);
    }

}

2.3 服务接口加上降级方法。


import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class Control {

    @RequestMapping(value = "/hello",method = RequestMethod.GET)
    @HystrixCommand(fallbackMethod="aaa")
    public String sayHello(){

        String result = System.currentTimeMillis()+"hello";
        throw new NullPointerException();
    }

    public String aaa(){
        return "produce fuwu jiangji";
    }

}

2.4 测试结果
在服务端的接口我们手动抛出异常,现在是两边都加上了降级配置,我们测试下哪个会先生效。
springcloud hystrix+openfeign服务降级案例_第3张图片

可以看到返回了produce fuwu jiangji 说明如果两边都配置的情况是服务侧的会生效。

总结

这里仅仅是springcloud的降级演示,其实生成端除了现在的这种降级方式,还可以针对整个类或者全局做降级处理,这里就不展开了,感兴趣的小伙伴,自行查阅资料。

你可能感兴趣的:(spring,cloud,spring,boot,java)