美文网首页程序员
SpringCloud-基于feign自带熔断器实现熔断

SpringCloud-基于feign自带熔断器实现熔断

作者: zpwd63 | 来源:发表于2019-04-09 13:33 被阅读0次

一、maven配置

 <groupId>com.wk.sc</groupId>
    <artifactId>springcloud-demo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.SR1</spring-cloud.version>
    </properties>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.4.RELEASE</version>
        <relativePath/>
    </parent>

    <dependencies>
         <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

二、application.yml配置

server:
  port: 7071

eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka
spring:
  application:
    name: service-feign
feign:
  hystrix:
    enabled: true  # feign自带熔断器,默认是关闭的,需要手动开启

三、启动类

@SpringBootApplication
@EnableDiscoveryClient
@EnableEurekaClient
@EnableFeignClients
public class ServiceFeignApplication {

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

}

四、服务调用

  • 接口定义
/**
 * feign服务调用示例
 *
 */
@FeignClient(value = "service-hi",fallback = HelloServiceImpl.class)  //配置feign自带熔断器,fallback指定熔断后调用方法
public interface IHelloService {
    /**
     * 调用服务
     *
     * @param name
     * @return
     */
    @RequestMapping(value = "/hi", method = RequestMethod.GET)
    String sayHi(@RequestParam("name") String name);
}

  • 接口实现
/**
 * Feign 熔断服务实现
 *
 */
@Component
public class HelloServiceImpl implements IHelloService {
    @Override
    public String sayHi(String name) {
        return "sorry  " + name;
    }
}

五、控制器调用服务

/**
 * feign远程调用
 *
 */
@RestController
public class HiController {

    @Autowired
    private IHelloService helloService;

    @GetMapping(value = "/hi")
    public String sayHi(@RequestParam String name) {
        return helloService.sayHi(name);
    }

}

相关文章

  • SpringCloud-基于feign自带熔断器实现熔断

    一、maven配置 二、application.yml配置 三、启动类 四、服务调用 接口定义 接口实现 五、控制...

  • springcloud使用(四) 熔断器Hystrix

    熔断器的概念和优点参考 springcloud(四):熔断器Hystrix, 讲的很详细 基于feign的Hyst...

  • golang-熔断器

    熔断器 go-zero在breaker里面基于google的sre算法实现了熔断器逻辑,并在redis等客户端操作...

  • SpringCloud主要框架

    服务发现——Netflix Eureka 服务调用——Netflix Feign 熔断器——Netflix Hys...

  • 使用熔断器防止服务雪崩

    学习完整课程请移步 互联网 Java 全栈工程师 本节视频 【视频】微服务框架-SpringCloud-使用熔断器...

  • Springcloud-熔断器Hystrix

    雪崩效应 在微服务架构中通常会有多个服务层调用,基础服务的故障可能会导致级联故障,进而造成整个系统不可用的情况,这...

  • 熔断器的选择方法(3)

    熔断器的选择 (1)UN熔断器≥UN线路. (2)IN熔断器≥IN线路. (3)熔断器的最大分断能力应大于被保护线...

  • Spring Cloud Alibaba——Sentinel断路

    前言 Sentinel的熔断降级通过断路器实现,本文通过介绍熔断器的定义、如何构建熔断器、断路器校验逻辑、断路器状...

  • 不怕难之Spring Cloud系列之Hystrix

    一、简介 1. 引言 什么是熔断器? 为什么要有熔断器? 熔断器有哪些考虑指标? 熔断器有哪些适用的设计模式? 熔...

  • SpringCloud 熔断器+feign

    依赖 配置 feign的使用需要通过注册中心以接口形式调用其他服务的接口 feign要使用熔断器需要在配置文件中开...

网友评论

    本文标题:SpringCloud-基于feign自带熔断器实现熔断

    本文链接:https://www.haomeiwen.com/subject/inebiqtx.html