• 为山西公安“一网通一次办”点赞 2019-04-22
  • 奥委会将办特殊乒乓赛:钦点马龙丁宁 福原爱复出 2019-04-21
  • 真的很美!越冬候鸟迎来迁徙高峰 2019-04-21
  • ——客观唯物主义哲学思想的“幸福”的定义:“幸福”就是在“客观规律和定律”的制约中满足了人的直接感觉的好的结果。这样,也就存在着客观唯物主义哲学思想的不幸福感。 2019-04-19
  • 推进科技兴军 建设世界一流军队的伟大实践 2019-04-12
  • 罗伯特·劳伦斯·库恩 2019-04-12
  • 广东摧毁全国首例“呼死你”犯罪团伙 2019-04-11
  • 上合再出发 开启新征程 2019-04-09
  • 传Switch即将支持媒体应用 看电影听音乐不是梦传Switch即将支持媒体应用-行情资讯 2019-04-08
  • 北京地铁早高峰大数据:7时30分至8时30分客流最大 2019-04-08
  • 日本大阪北部地区6.1级地震 2019-04-03
  • 走奋发图强之路,壮我中华科技实力。 2019-03-30
  • 端午小长假旅游去这些地方逛逛吧 2019-03-30
  • 《中国教育报》电子版 2019-03-24
  • 精神分裂患者全病程规范管理,有望重返真实世界 2019-03-24
  • 冰球比赛视频: 冰球打架中国对韩国

    北京 切换校区

    全国24小时免费热线

    400-009-1906

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

    在前面的学习中,我们使用了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全栈培训、 H5+PHP全栈工程师培训

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

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

    武汉学区地址:湖北省武汉市江夏区江夏大道26号 宏信悦谷创业园4楼
    咨询电话: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-04-22
  • 奥委会将办特殊乒乓赛:钦点马龙丁宁 福原爱复出 2019-04-21
  • 真的很美!越冬候鸟迎来迁徙高峰 2019-04-21
  • ——客观唯物主义哲学思想的“幸福”的定义:“幸福”就是在“客观规律和定律”的制约中满足了人的直接感觉的好的结果。这样,也就存在着客观唯物主义哲学思想的不幸福感。 2019-04-19
  • 推进科技兴军 建设世界一流军队的伟大实践 2019-04-12
  • 罗伯特·劳伦斯·库恩 2019-04-12
  • 广东摧毁全国首例“呼死你”犯罪团伙 2019-04-11
  • 上合再出发 开启新征程 2019-04-09
  • 传Switch即将支持媒体应用 看电影听音乐不是梦传Switch即将支持媒体应用-行情资讯 2019-04-08
  • 北京地铁早高峰大数据:7时30分至8时30分客流最大 2019-04-08
  • 日本大阪北部地区6.1级地震 2019-04-03
  • 走奋发图强之路,壮我中华科技实力。 2019-03-30
  • 端午小长假旅游去这些地方逛逛吧 2019-03-30
  • 《中国教育报》电子版 2019-03-24
  • 精神分裂患者全病程规范管理,有望重返真实世界 2019-03-24
  • 秒速时时彩开挂软件下载 体育彩票走势图 360彩票 购买网上彩票北京pk10犯法吗 天津时时彩的官网开奖结果 排列五 体彩p5跨度走势图带连线 广东时时彩平台 中彩网3d试机号 体彩大乐透 篮彩预测大小分 重庆时时彩平台 2017年图迷七3b牛彩网 河南泳坛夺金直播 体彩排列五 4场进球玩法奖金对照