为了账号安全,请及时绑定邮箱和手机立即绑定

Spring Cloud 微服务(六) 服务消费Feign

标签:
Spring Cloud

本篇我们介绍在另外一个服务里面消费这个服务,并实现负载均衡。在Spring Cloud家族中,Feign是负责服务间内部调用消费,以及负责均衡的组件,但是和Eureka不一样,Feign没有Server这么一说,Feign本身就是个Client,它是可插拔的,可以配置在其他服务中。
Feign的两个特点是(1)

  • 负载均衡采用Ribbon轮询方式

  • 服务用注解以及接口来定义

  • 可插拔

构建Feign

和前几篇一样,我们还是通过IntelliJ的Spring Initializer构建Feign Server。构建出来的项目目录结构也是一个入口类和一个配置文件,pom文件里面多了feign的依赖。我们需要定义一个@EnableDiscoverClient来表明这是个Eureka客户端,并且在配置文件定义好Eureka的端口,开放的端口,以及服务名字。唯一的区别是我们加了@EnableFeignClients来表明这是个Feign。

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-feign</artifactId></dependency>
@SpringBootApplication@EnableDiscoveryClient@EnableFeignClientspublic class FeignApplication {    public static void main(String[] args) {
        SpringApplication.run(FeignApplication.class, args);
    }
}
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8081/eureka/server:
  port: 8766spring:
  application:
    name: service-feign
用注解提供服务消费

为了演示,我们在Spring Cloud 微服务(二) 创建一个简单的服务 创建的服务上加个/hi服务,输入一个名字参数,输出问候语,以及该服务监听的端口,因为我们将会起两个DummyService,分别在不同的端口监听,然后用Feign消费这个服务。定义完这个服务之后,我们起两个DummyService,分别监听8870和8871。

@RequestMapping("/hi")public String home(@RequestParam String name) {  return "hi "+name+" from port: " + port;
}

接下来是Feign配置服务的环节,Feign通过定接口来提供服务,所以我们需要新建一个接口,取名叫DummyService,我们定义了一个sayHi方法,以及它的方法是GET类型,路径是/hi,还有一个参数是name,都跟dummy service对应,这里最关键的是Feign怎么找到dummy-service。通过@FeignClient(value="dummy-service")里面的value,跟在Eureka上注册的service name对应起来,我们把它映射到dummy service,到这时关于Feign的配置已经完成。

@FeignClient(value = "dummy-service")public interface DummyService {    @RequestMapping(value = "/hi",method = RequestMethod.GET)    String sayHi(@RequestParam(value = "name") String name);
}

调用方法很简单,我们需要定义一个服务来测试我们的Feign,然后把我们的DummyService注入进来,直接调用sayHi方法,带上我们的参数。

@RestControllerpublic class FeignTestController {    @Autowired
    DummyService schedualService;    @RequestMapping(value = "/hi",method = RequestMethod.GET)    public String sayHi(@RequestParam String name){        return schedualService.sayHi(name);
    }
}

把服务开起来后,我们就可以访问http://localhost:8766/hi?name=jeff ,多点几下,就会发现dummy service是交替调用两个端口上的服务来返回的:

hi jeff from port: 8870hi jeff from port: 8871hi jeff from port: 8870hi jeff from port: 8871



作者:Lin_XJ
链接:https://www.jianshu.com/p/07303bc4b015
处。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 1
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消