1. package com.itmuch.cloud;
  2.  
  3. import org.springframework.boot.SpringApplication;
  4. import org.springframework.boot.autoconfigure.SpringBootApplication;
  5. import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
  6. import org.springframework.cloud.netflix.feign.EnableFeignClients;
  7.  
  8. @SpringBootApplication
  9. @EnableEurekaClient
  10. @EnableFeignClients
  11. public class ConsumerMovieFeignApplication {
  12. public static void main(String[] args) {
  13. SpringApplication.run(ConsumerMovieFeignApplication.class, args);
  14. }
  15. }
  1. package com.itmuch.cloud.controller;
  2.  
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.web.bind.annotation.GetMapping;
  5. import org.springframework.web.bind.annotation.PathVariable;
  6. import org.springframework.web.bind.annotation.RestController;
  7.  
  8. import com.itmuch.cloud.entity.User;
  9. import com.itmuch.cloud.feign.UserFeignClient;
  10.  
  11. @RestController
  12. public class MovieController {
  13.  
  14. @Autowired
  15. private UserFeignClient userFeignClient;
  16.  
  17. @GetMapping("/movie/{id}")
  18. public User findById(@PathVariable Long id) {
  19. return this.userFeignClient.findById(id);
  20. }
  21. }
  1. package com.itmuch.cloud.feign;
  2.  
  3. import org.slf4j.Logger;
  4. import org.slf4j.LoggerFactory;
  5. import org.springframework.stereotype.Component;
  6.  
  7. import com.itmuch.cloud.entity.User;
  8.  
  9. import feign.hystrix.FallbackFactory;
  10.  
  11. @Component
  12. public class HystrixClientFactory implements FallbackFactory<UserFeignClient> {
  13.  
  14. private static final Logger LOGGER = LoggerFactory.getLogger(HystrixClientFactory.class);
  15.  
  16. @Override
  17. public UserFeignClient create(Throwable cause) {
  18. HystrixClientFactory.LOGGER.info("fallback; reason was: {}", cause.getMessage());
  19. return new UserFeignClientWithFactory() {
  20. @Override
  21. public User findById(Long id) {
  22. User user = new User();
  23. user.setId(-1L);
  24. return user;
  25. }
  26. };
  27. }
  28. }
  1. package com.itmuch.cloud.feign;
  2.  
  3. import org.springframework.stereotype.Component;
  4.  
  5. import com.itmuch.cloud.entity.User;
  6.  
  7. @Component
  8. public class HystrixClientFallback implements UserFeignClient {
  9. @Override
  10. public User findById(Long id) {
  11. User user = new User();
  12. user.setId(0L);
  13. return user;
  14. }
  15. }
  1. package com.itmuch.cloud.feign;
  2.  
  3. import org.springframework.cloud.netflix.feign.FeignClient;
  4. import org.springframework.web.bind.annotation.PathVariable;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.RequestMethod;
  7.  
  8. import com.itmuch.cloud.entity.User;
  9.  
  10. @FeignClient(name = "microservice-provider-user", /*fallback = HystrixClientFallback.class, */fallbackFactory = HystrixClientFactory.class)
  11. public interface UserFeignClient {//请求microservice-provider-user的/simple/{id}方法。回调调用的是HystrixClientFactory的findById方法
  12. @RequestMapping(value = "/simple/{id}", method = RequestMethod.GET)
  13. public User findById(@PathVariable("id") Long id);
  14. }
  1. package com.itmuch.cloud.feign;
  2.  
  3. public interface UserFeignClientWithFactory extends UserFeignClient {
  4.  
  5. }
  1. spring:
  2. application:
  3. name: microservice-consumer-movie-feign-with-hystrix-hystrix-factory
  4. server:
  5. port: 7901
  6. eureka:
  7. client:
  8. healthcheck:
  9. enabled: true
  10. serviceUrl:
  11. defaultZone: http://user:password123@localhost:8761/eureka
  12. instance:
  13. prefer-ip-address: true
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5.  
  6. <artifactId>microservice-consumer-movie-feign-with-hystrix-hystrix-factory</artifactId>
  7. <packaging>jar</packaging>
  8.  
  9. <parent>
  10. <groupId>com.itmuch.cloud</groupId>
  11. <artifactId>microservice-spring-cloud</artifactId>
  12. <version>0.0.1-SNAPSHOT</version>
  13. </parent>
  14.  
  15. <properties>
  16. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  17. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  18. <java.version>1.8</java.version>
  19. </properties>
  20.  
  21. <dependencies>
  22. <dependency>
  23. <groupId>org.springframework.boot</groupId>
  24. <artifactId>spring-boot-starter-web</artifactId>
  25. </dependency>
  26.  
  27. <dependency>
  28. <groupId>org.springframework.cloud</groupId>
  29. <artifactId>spring-cloud-starter-eureka</artifactId>
  30. </dependency>
  31.  
  32. <dependency>
  33. <groupId>org.springframework.boot</groupId>
  34. <artifactId>spring-boot-starter-actuator</artifactId>
  35. </dependency>
  36.  
  37. <dependency>
  38. <groupId>org.springframework.cloud</groupId>
  39. <artifactId>spring-cloud-starter-feign</artifactId>
  40. </dependency>
  41. </dependencies>
  42. </project>

springcloud10---feign-with-hystrix_factory的更多相关文章

  1. Spring Cloud 声明式服务调用 Feign

    一.简介 在上一篇中,我们介绍注册中心Eureka,但是没有服务注册和服务调用,服务注册和服务调用本来应该在上一章就应该给出例子的,但是我觉得还是和Feign一起讲比较好,因为在实际项目中,都是使用声 ...

  2. Feign使用Hystrix无效原因及解决方法

    最近项目重构使用了Spring Boot和Spring Cloud.这两者结合确实给项目带来了方便,同时也遇到了一些问题.其中使用feign作为服务消费,但是断路器hystrix一直不起作用让人很费解 ...

  3. 在dropwizard中使用feign,使用hystrix

    前言 用惯了spring全家桶之后,试试dropwizard的Hello World也别有一帆风味.为了增强对外访问API的能力,需要引入open feign.这里简单在dropwizard中使用fe ...

  4. spring cloud feign不支持@RequestBody+ RequestMethod.GET,报错

    1.问题梳理: 异常:org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'POST' not ...

  5. 【微服务】之五:轻松搞定SpringCloud微服务-调用远程组件Feign

    上一篇文章讲到了负载均衡在Spring Cloud体系中的体现,其实Spring Cloud是提供了多种客户端调用的组件,各个微服务都是以HTTP接口的形式暴露自身服务的,因此在调用远程服务时就必须使 ...

  6. Spring Cloud Feign 整合 Hystrix

    在前面随笔Spring Cloud 之 Feign的feign工程基础上进行改造 1.pom.xml依赖不变 2.application.yml文件添加feign.hystrix.enabled=tr ...

  7. Spring Cloud 之 Feign

    新建Spring Boot工程,命名为feign 1.pom.xml添加依赖 <?xml version="1.0" encoding="UTF-8"?& ...

  8. SpringCloud Feign对Hystrix(断路由)的支持

    第一步:首先开启Feign对Hystrix的支持,在properties文件中添加以下配置: feign.hystrix.enabled=true. 第二步:在上一篇Feign的基础上添加Hystri ...

  9. SpringCloud Feign使用详解

    添加依赖: <dependency> <groupId>org.springframework.cloud</groupId> <artifactId> ...

  10. 工作随笔——自动重发的凶手--feign

    公司使用的feign(https://github.com/OpenFeign/feign)作为http客户端. 开发时debug后端程序,发现同一个请求会多次收到. 为了判断是谁在搞鬼,在客户端和服 ...

随机推荐

  1. Keil(MDK-ARM)在线调试(Ⅰ)(转)

    Ⅰ.写在前面 Keil在线调试的内容有很多,本文带来在线调试常用的内容:Debug Toolbar调试工具栏(复位.全速运行.停止运行.单步调试.逐行调试.跳出调试.运行到光标行.跳转到暂停行.调试窗 ...

  2. ThreadUtil 多线程处理List,回调处理具体的任务

    每次想多线程处理一个大的结果集的时候 都需要写一大堆代码,自己写了个工具类 方便使用 package com.guige.fss.common.util; import com.guige.fss.c ...

  3. PHP Web 木马扫描器代码

    scanner.php:<?php/**************PHP Web木马扫描器************************//* [+] 作者: alibaba *//* [+] ...

  4. 【jQuery系列之插件】jquery插件之jquery-validation

    equalTo方法: equalTo: function( value, element, param ) { // Bind to the blur event of the target in o ...

  5. LeetCode——N-Queens

    Description: The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that n ...

  6. Android搜索自动提示功能 AutocompleteTextView

    1.配置main.xml中自动提示控件: <AutoCompleteTextView android:id="@+id/autotv_searchresult" androi ...

  7. netty的解码器与粘包和拆包

    tcp是一个“流”的协议,一个完整的包可能会被TCP拆分成多个包进行发送,也可能把小的封装成一个大的数据包发送,这就是所谓的TCP粘包和拆包问题. 假设客户端分别发送数据包D1和D2给服务端,由于服务 ...

  8. Popular Cows---poj2186(缩点,强联通)

    题目链接:http://poj.org/problem?id=2186 求有多少个点满足其他n-1个点都能到达这个点,是单向图: 所以我们可以把图进行缩点,之后求出度为0的那个点内包含的点的个数就是求 ...

  9. 简单的共享文件http

    如果你急需一个简单的Web Server,但你又不想去下载并安装那些复杂的HTTP服务程序,比如:Apache,ISS等.那么, Python 可能帮助你.使用Python可以完成一个简单的内建 HT ...

  10. wget 命令大全

    wget 命令大全   wget默认会以最后一个符合”/”的后面的字符来命令,对于动态链接的下载通常文件名会不正确 wget http://www.minjieren.com/wordpress-3. ...