zoukankan      html  css  js  c++  java
  • springCloud初识4-远程调用Feign

    Feign是Netflix开发的声明式、模板化的HTTP客户端,其灵感来自Retrofit、 JAXRS-2.0以及WebSocket.Feign 可帮助我们更加便捷、优雅地调用HTTP API。
    在SpringCloud中,使用Feign非常简单----创建一个接口,并在接口上添加一些注解,代码就完成了。Feign 支持多种注解,例如Feign自带的注解或者JAX-RS注解等。
    Spring Cloud对Feign进行了增强,使Feign支持了Spring MVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。

    1--引入启动器(消费服务端)

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

    2--覆盖默认配置

    也可以不做任何配置
    

    3--引导类启用feign ==== 4--内容已经封装好restTemplate了可以不再引入

    package com.xiaoai.service;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.client.SpringCloudApplication;
    import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
    import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
    import org.springframework.cloud.client.loadbalancer.LoadBalanced;
    import org.springframework.cloud.openfeign.EnableFeignClients;
    import org.springframework.context.annotation.Bean;
    import org.springframework.web.client.RestTemplate;
    
    //@SpringBootApplication
    //@EnableDiscoveryClient  //启用eureka客户端,@EnableEurekaClient也可以
    //@EnableCircuitBreaker   //开启熔断
    @SpringCloudApplication   //组合注解 相当于@SpringBootApplication、@EnableDiscoveryClient 、@EnableCircuitBreaker
    @EnableFeignClients   //启动feign组件
    public class XiaoaiServiceConsumerApplication {
    
    //	@Bean
    //	@LoadBalanced  //开启负载均衡
    //	public RestTemplate restTemplate(){
    //		return new RestTemplate();
    //	}
    
    	public static void main(String[] args) {
    		SpringApplication.run(XiaoaiServiceConsumerApplication.class, args);
    	}
    }
    
    

    5--定义一个接口

    package com.xiaoai.service.client;
    
    import com.xiaoai.service.pojo.User;
    import org.springframework.cloud.openfeign.FeignClient;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.PathVariable;
    
    @FeignClient("service-provider") //声明一个接口是feign接口,参数为提供服务端的id,即注册时自己所取的名称
    public interface UserClient {
    
        @GetMapping("user/{id}")  //和提供服务端控制器里的方法一样 ,路径可以手动补,不建议使用@RequestMapping注解在接口上定义
        public User queryUserById(@PathVariable("id")Long id);
    }
    
    

    6--控制类方法内

    package com.xiaoai.service.controller;
    
    import com.netflix.hystrix.contrib.javanica.annotation.DefaultProperties;
    import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
    import com.xiaoai.service.client.UserClient;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.*;
    import org.springframework.web.client.RestTemplate;
    
    @RestController
    @RequestMapping("/consumer/user")
    //@DefaultProperties(defaultFallback = "FalbackMethod") // 定义全局熔断方法
    public class UserController {
    
    //    //-----------------------------------------------改造消费方,解决地址硬编码问题    启用ribbon负载均衡后
    ////    @Autowired
    ////    private RestTemplate restTemplate;
    //
    //    @GetMapping
    //    @ResponseBody
    //    @HystrixCommand //声明熔断方法。使用全局默认方法,属性fallbackMethod = "queryUserByIdFalback"可以不用了,但注解还是要。
    //    public String queryUserById(@RequestParam("id")Long id){
    //        return this.restTemplate.getForObject("http://service-provider/user/"+id,String.class);
    //    }
    //
    //    //熔断方法
    //    public String queryUserByIdFalback(Long id){ //熔断方法返回值必须和控制方法返回值一样
    //        return "queryUserByIdFalback熔断:服务器正忙,请稍后再试!";
    //    }
    //
    //    //熔断方法
    //    public String FalbackMethod(){
    //       return "全局熔断:服务器正忙,请稍后再试!";
    //    }
    
        //-----------------------------------------------feign的使用
        @Autowired
        private UserClient userClient;
    
        @GetMapping
        @ResponseBody
        //@HystrixCommand //声明熔断方法。
        public String queryUserById(@RequestParam("id")Long id){
            return this.userClient.queryUserById(id).toString();
        }
    
    }
    
    

    其底层是实例化自己集成的restTemlate,通过注解中的服务名称获取实例,通过路径远程调用提供服务端完成

    feign自动集成ribbon负载均衡以及hystrix熔断。所以其也可以达到负载均衡的功能以及支持熔断。
    feign默认关闭hystrix熔断,如果需要开启需要手动配置。如:在消费服务端的application配置文件中配置开启熔断。

    feign:
      hystrix:
        enabled: true #开启Feign的熔断功能
    

    feign自定义熔断方法

    1--定义一个类实现feign接口,实现方法,方法即是熔断方法 缺点:当接口有多个方法时需要实现多个方法了

    package com.xiaoai.service.client;
    
    import com.xiaoai.service.pojo.User;
    import org.springframework.stereotype.Component;
    
    @Component
    public class UserClientFallback implements UserClient{
    
        @Override
        public User queryUserById(Long id) {
            User user = new User();
            user.setUserName("服务器正忙,请稍后访问!");
            return user;
        }
    
    }
    
    

    2--feign接口注解引入实现类即熔断类

    package com.xiaoai.service.client;
    
    import com.xiaoai.service.pojo.User;
    import org.springframework.cloud.openfeign.FeignClient;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.PathVariable;
    
    @FeignClient(value = "service-provider",fallback = UserClientFallback.class)
    public interface UserClient {
    
        @GetMapping("user/{id}")  //和提供服务端控制器里的方法一样 ,路径可以手动补,不建议使用@RequestMapping注解在接口上定义
        public User queryUserById(@PathVariable("id")Long id);
    
    }
    
    

    3--控制器方法一样

    package com.xiaoai.service.controller;
    
    import com.xiaoai.service.client.UserClient;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.*;
    
    @RestController
    @RequestMapping("/consumer/user")
    public class UserController {
    
        //-----------------------------------------------feign的使用
    
        @Autowired
        private UserClient userClient;
    
        @GetMapping
        @ResponseBody
        public String queryUserById(@RequestParam("id")Long id){
            return this.userClient.queryUserById(id).toString();
        }
    
    }
    
    

    关闭提供服务端访问相应url 如下:

    小结

    • 引入openFeign启动器
    • 覆盖默认配置 (feign.hystrix.enable=true可以开启feign的熔断功能)
    • 引导类上@EnableFeignClients启用
    • 创建一个接口 ,使用注解@FeignClient value属性标识提供服务端名称 fallback="熔断方法.class"
    • 在接口中定义一些方法,这些方法的书写方式跟之前服务提供端controller中方法类似。
    • 可以创建熔断类实现feign接口,实现对应的方法,这些方法就是熔断方法
  • 相关阅读:
    【BZOJ1023】仙人掌图(SHOI2008)-圆方树+DP+单调队列
    【BZOJ4816】数字表格(SDOI2017)-莫比乌斯反演+数论分块
    【BZOJ3529】数表(SDOI2014)-莫比乌斯反演+树状数组
    【BZOJ3714】Kuglarz(PA2014)-最小生成树
    javascript div元素后追加节点
    php多文本框提交
    有几数组表单,js怎么获得数组并动态相加输出到文本框
    SqlCommand.Parameters.add()方法
    ASP.net后台弹出消息对话框的方法!【转】
    Access中的SELECT @@IDENTITY
  • 原文地址:https://www.cnblogs.com/xiaoaiying/p/13434678.html
Copyright © 2011-2022 走看看