• 财政部就“财税改革和财政工作”答问 2019-06-21
  • 后伊布时代 北欧海盗能否再扮演“豪门杀手” 2019-06-10
  • 中国宗教研究学者:儒道佛三教关系为世界宗教发展提供新启迪 2019-06-10
  • “六一”特刊丨尤叔叔的安(xìng)全(fú)小课堂 2019-06-05
  • 微信“信用卡还款”3.0版本上线 支持招商银行账单查询 2019-05-30
  • 上海发布来沪人员就业报告 2019-05-30
  • 新华时评:美逆潮流而动,必将付出代价 2019-05-24
  • 杭州约谈58同城等3家网上房源发布平台负责人 2019-05-24
  • 《典出山西》考试季特辑:“武状元”那些事 2019-05-22
  • 首趟中欧班列整车进口专列抵达西安 2019-05-22
  • 航旅纵横疑似泄露隐私,企业应管好用户信息 2019-05-18
  • 美国防部宣布暂停8月美韩联合军演 2019-05-17
  • 党媒《红网湘乡手机报》是如何做到接地气、聚人气的? 2019-05-17
  • 刘嘉玲:长江后浪一直涌来 2019-05-16
  • 营养-热门标签-华商生活 2019-05-16
  • 北京虎仔冰球俱乐部:

    北京 切换校区

    全国24小时免费热线

    400-009-1906

    SpringCloud之初识Feign —– 分布式负载自动拼接请求的URL

    时间:2019-03-08   来源:尚学堂   阅读:371

    在前面的学习中,我们使用了Ribbon的负载均衡功能,大大简化了远程调用时的代码:

     String baseUrl = "//user-service/user/";
     User user = this.restTemplate.getForObject(baseUrl + id, User.class)

    如果就学到这里,你可能以后需要编写类似的大量重复代码,格式基本相同,无非参数不一样。有没有更优雅的方式,来对这些代码再次优化呢?

    这就是我们接下来要学的Feign的功能了。

    1.1.简介

    有道词典的英文解释:

    ? 为什么叫伪装?

    ? Feign可以把Rest的请求进行隐藏,伪装成类似SpringMVC的Controller一样。你不用再自己拼接url,拼接参数等等操作,一切都交给Feign去做。

    ? 项目主页:https://github.com/OpenFeign/feign

    1.2.快速入门

    ? 1.2.1.导入依赖

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

    1.2.2.Feign的客户端

    @FeignClient("user-service")
    public interface UserFeignClient {
    
       @GetMapping("/user/{id}")
       User queryUserById(@PathVariable("id") Long id);
    }
    • ? 首先这是一个接口,Feign会通过动态代理,帮我们生成实现类。这点跟mybatis的mapper很像

    • ? @FeignClient,声明这是一个Feign客户端,类似@Mapper注解。同时通过value属性指定服务名称

    • ? 接口中的定义方法,完全采用SpringMVC的注解,Feign会根据注解帮我们生成URL,并访问获取结果

    ?改造原来的调用逻辑,不再调用UserDao:

    @Service
    public class UserService {
       @Autowired
       private UserFeignClient userFeignClient;
       public List<User> queryUserByIds(List<Long> ids) {
       List<User> users = new ArrayList<>();
       ids.forEach(id -> {
         // 我们测试多次查询,
         users.add(this.userFeignClient.queryUserById(id));
       });
       return users;
      }
    }

    1.2.3.开启Feign功能

    ?我们在启动类上,添加注解,开启Feign功能

    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableHystrix
    @EnableFeignClients // 开启Feign功能
    public class UserConsumerDemoApplication {
       public static void main(String[] args) {
          SpringApplication.run(UserConsumerDemoApplication.class, args);
        }
    }

    你会发现RestTemplate的注册被我删除了。Feign中已经自动集成了Ribbon负载均衡,因此我们不需要自己定义RestTemplate了

    ? 1.2.4.启动测试:

    ? 访问接口:

    正?;袢〉搅私峁?。

    ?1.3.负载均衡

    ? Feign中本身已经集成了Ribbon依赖和自动配置:

    ?因此我们不需要额外引入依赖,也不需要再注册RestTemplate对象。

    ?另外,我们可以像上节课中讲的那样去配置Ribbon,可以通过ribbon.xx来进行全局配置。也可以通过服务名.ribbon.xx来对指定服务配置:

    user-service:
      ribbon:
        ConnectTimeout: 250 # 连接超时时间(ms)
        ReadTimeout: 1000 # 通信超时时间(ms)
        OkToRetryOnAllOperations: true # 是否对所有操作重试
        MaxAutoRetriesNextServer: 1 # 同一服务不同实例的重试次数
        MaxAutoRetries: 1 # 同一实例的重试次数

    1.4.Hystrix支持

    ?Feign默认也有对Hystix的集成:

    只不过,默认情况下是关闭的。我们需要通过下面的参数来开启:

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

    但是,Feign中的Fallback配置不像Ribbon中那样简单了。

    ?1)首先,我们要定义一个类,实现刚才编写的UserFeignClient,作为fallback的处理类
    @Component
    public class UserFeignClientFallback implements UserFeignClient {
      @Override
      public User queryUserById(Long id) {
       User user = new User();
       user.setId(id);
       user.setName("用户查询出现异常!");
      return user;
        }
    }
    2)然后在UserFeignClient中,指定刚才编写的实现类
    @FeignClient(value = "user-service", fallback = UserFeignClientFallback.class)
    public interface UserFeignClient {
    
      @GetMapping("/user/{id}")
      User queryUserById(@PathVariable("id") Long id);
    }

    3)重启测试:

    ?我们关闭user-service服务,然后在页面访问:

    1.5.请求压缩(了解)

    feign:
     compression:
       request:
       enabled: true # 开启请求压缩
       response:
       enabled: true # 开启响应压缩

    同时,我们也可以对请求的数据类型,以及触发压缩的大小下限进行设置:

    feign:
      compression:
        request:
        enabled: true # 开启请求压缩
        mime-types: text/html,application/xml,application/json # 设置压缩的数据类型
        min-request-size: 2048 # 设置触发压缩的大小下限

    注:上面的数据类型、压缩大小下限均为默认值。

    相关资讯

    • 北京校区
    • 山西校区
    • 郑州校区
    • 武汉校区
    • 四川校区
    • 长沙校区
    • 深圳校区
    • 上海校区
    • 广州校区
    • 保定招生办

    北京海淀区校区(总部):北京市海淀区西三旗街道建材城西路中腾建华商务大厦东侧二层尚学堂
    北京京南校区:北京亦庄经济开发区科创十四街6号院1号楼 赛蒂国际工业园
    咨询电话:400-009-1906 / 010-56233821
    面授课程:?JavaEE+微服务+大数据? ???大数据+机器学习+平台架构?????Python+数据分析+机器学习??人工智能+模式识别+强化学习???WEB前端+移动端+服务端渲染

     

    山西学区地址:山西省晋中市榆次区大学城大学生活广场万科商业A1座702

    郑州学区地址:河南电子商务产业园6号楼4层407
    咨询电话:0371-55177956

    武汉学区地址:武汉市东湖高新区光谷金融港B22栋11楼
    咨询电话:027-87989193

    四川学区地址:成都市高新区锦晖西一街99号布鲁明顿大厦2栋1003室
    咨询电话:028-65176856 / 13880900114

    网址://www.cssxt.com/
    咨询电话:0731-83072091

    深圳校区地址:深圳市宝安区航城街道航城大道航城创新创业园A4栋210(固戍地铁站C出口)
    咨询电话:0755-23061965 / 18898413781

    上海尚学堂松江校区地址:上海市松江区荣乐东路2369弄45号绿地伯顿大厦2层
    咨询电话:021-67690939

    广州校区地址:广州市天河区元岗横路31号慧通产业广场B区B1栋6楼尚学堂(地铁3号线或6号线到“天河客运站”D出口,右拐直走约800米)
    咨询电话:020-2989 6995

    保定招生办公室

    地址:河北省保定市竞秀区朝阳南大街777号鸿悦国际1101室

    电话:15132423123

    Copyright 2006-2019 北京尚学堂科技有限公司  京ICP备13018289号-19  京公网安备11010802015183  
    媒体联系:18610174079 闫老师  

    Java基础班,免费试学三周

  • 财政部就“财税改革和财政工作”答问 2019-06-21
  • 后伊布时代 北欧海盗能否再扮演“豪门杀手” 2019-06-10
  • 中国宗教研究学者:儒道佛三教关系为世界宗教发展提供新启迪 2019-06-10
  • “六一”特刊丨尤叔叔的安(xìng)全(fú)小课堂 2019-06-05
  • 微信“信用卡还款”3.0版本上线 支持招商银行账单查询 2019-05-30
  • 上海发布来沪人员就业报告 2019-05-30
  • 新华时评:美逆潮流而动,必将付出代价 2019-05-24
  • 杭州约谈58同城等3家网上房源发布平台负责人 2019-05-24
  • 《典出山西》考试季特辑:“武状元”那些事 2019-05-22
  • 首趟中欧班列整车进口专列抵达西安 2019-05-22
  • 航旅纵横疑似泄露隐私,企业应管好用户信息 2019-05-18
  • 美国防部宣布暂停8月美韩联合军演 2019-05-17
  • 党媒《红网湘乡手机报》是如何做到接地气、聚人气的? 2019-05-17
  • 刘嘉玲:长江后浪一直涌来 2019-05-16
  • 营养-热门标签-华商生活 2019-05-16
  • 恩波利主客场球衣 赌场大赢家电子游艺 内蒙古泳坛夺金开奖查询 姚记扑克型号图片大全 七乐彩走势图(带连线) 捕鱼之海底总动员破解版 qq飞车手游a车获取 全民突击金属风暴好吗 福彩有哪些高频彩种 巫师梅林援彩金 巴拉多利德VS赫塔菲 蒋方舟 云南时时彩周几开奖时间 意甲新闻尤文图斯 黑龙江十一选五中奖号 澳门bbin电子游戏