大发uu快3_uu快3技巧_大发uu快3技巧 - 大发uu快3,uu快3技巧,大发uu快3技巧是国务院新闻办确定的全国重点新闻网站,,由中共江苏省委宣传部主管,大发uu快3,uu快3技巧,大发uu快3技巧主办。是新兴的省级主流媒体,是综合性、多媒体的大发uu快3,uu快3技巧,大发uu快3技巧门户网站

[Spring cloud 一步步实现广告系统] 11. 使用Feign实现微服务调用

  • 时间:
  • 浏览:10

上一节朋友使用了Ribbon(基于Http/Tcp)进行微服务的调用,Ribbon的调用比较简单,通过Ribbon组件对请求的服务进行拦截,通过Eureka Server 获取到服务实例的IP:Port,假若再去调用API。本节课朋友使用更简单的措施来实现,使用声明式的Web服务客户端Feign,朋友只时要使用Feign来声明接口,利用注解来进行配置就可不时要使用了,是都不 很简单?实际工作中,朋友也只会用到Feign来进行服务之间的调用(大多数)。接下来,朋友来实例操作一把。

为了代码的重用性,朋友来创建有有1个 新的project mscx-ad-feign-sdk作为Feign的服务调用工具。

  • 创建项目mscx-ad-feign-sdk
  • 三部曲之Step 1(加依赖)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/301/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>mscx-ad</artifactId>
        <groupId>com.sxzhongf</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <packaging>jar</packaging>
    <name>mscx-ad-feign-sdk</name>
    <description>只定义微服务Feign调用用到的请求对象和响应对象,而不涉及具体的实现类。</description>

    <groupId>com.sxzhongf</groupId>
    <artifactId>mscx-ad-feign-sdk</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 引入服务调用的组件 feign 依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>com.sxzhongf</groupId>
            <artifactId>mscx-ad-common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <!-- 引入系统容错hystrix 的依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
            <version>1.2.7.RELEASE</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>
  • 三部曲之Step 2(加注解@EnableFeignClients,加进去去在具体的微服务中,使用朋友自定义的FeignClient)
/**
 * ISponsorFeignClient for service using
 *
 * @author <a href="mailto:magicianisaac@gmail.com">Isaac.Zhang | 若初</a>
 */
@FeignClient(value = "mscx-ad-sponsor", fallback = SponsorClientHystrix.class)
public interface ISponsorFeignClient {
    @RequestMapping(value = "/ad-sponsor/plan/get", method = RequestMethod.POST)
    CommonResponse<List<AdPlanVO>> getAdPlansUseFeign(@RequestBody AdPlanGetRequestVO requestVO);

    @RequestMapping(value = "/ad-sponsor/user/get", method = RequestMethod.GET)
    /**
     * Feign 埋坑之 机会是Get请求,时要在所有参数前加进去去{@link RequestParam},必须使用{@link Param}
     * 会被自动转发为POST请求。
     */
    CommonResponse getUsers(@RequestParam(value = "username") String username);
}


---
@RestController
@Slf4j
@RequestMapping(path = "/search-feign")
public class SearchFeignController {
   /**
   * 注入朋友自定义的FeignClient
   */
    private final ISponsorFeignClient sponsorFeignClient;
    @Autowired
    public SearchFeignController(ISponsorFeignClient sponsorFeignClient) {
        this.sponsorFeignClient = sponsorFeignClient;
    }

    @GetMapping(path = "/user/get")
    public CommonResponse getUsers(@Param(value = "username") String username) {
        log.info("ad-search::getUsersFeign -> {}", JSON.toJSONString(username));
        CommonResponse commonResponse = sponsorFeignClient.getUsers(username);
        return commonResponse;
    }
}
  • 三部曲之Step 3(加配置,工具类库不时要,加进去去在具体的微服务中)

朋友底下的实例富包包含1个 现象,机会说朋友的广告提供服务冒出了现象,这麼朋友通过使用FeignClient 调用的APIsponsorFeignClient.getUsers(username);就会报错,机会长时间报错,会引起大规模的服务错误现象,也都不 是朋友常说的服务雪崩效应,朋友怎样处里有有1个 服务出错而拖垮整个系统的现象呢?这里朋友时要引入有有1个 组件Hystrix来处里服务错误。

  • 三部曲之Step1(加依赖)

从上图朋友可不时要都看,朋友引入Feign依赖的完后 ,它三种机会依赖了Hystrix,根据Maven依赖的传递性,朋友可不时要知道朋友本人的服务机会包含了Hystrix的依赖支持,朋友可不时要直接使用了~

  • 三部曲之Step2(加注解) @EnableHystrix // 开启hystrix 断路器
  • 三部曲之Step3(改配置)
feign:
  hystrix:
    enabled: true
  • 使用Hystrix来配置Feign实现调用容错
@Component
public class SponsorClientHystrix implements ISponsorFeignClient {
    @Override
    public CommonResponse<List<AdPlanVO>> getAdPlansUseFeign(AdPlanGetRequestVO requestVO) {
        return new CommonResponse<>(-1, "mscx-ad-sponsor feign & hystrix get plan error.");
    }

    @Override
    public CommonResponse getUsers(String username) {
        return new CommonResponse<>(-1, "mscx-ad-sponsor feign & hystrix get user error.");
    }
}

ISponsorFeignClient类中,加进去去出错处里类(fallback)

@FeignClient(value = "mscx-ad-sponsor", fallback = SponsorClientHystrix.class)
public interface ISponsorFeignClient {
...

SponsorClientHystrix中,朋友要不怎样注意2点

  1. 该类时要加进去去@Component注解,以便可不时要加入Spring 容器中
  2. 该类时要实现ISponsorFeignClientFeign的客户端接口

通过底下的实现,朋友的服务在调用过程中,机会居于错误,就会进行服务降级,调用到出错应该调用的默认处里类中的措施,也就实现了朋友无需做的短路处里来保护朋友的当前服务。