内容简介:Spring Cloud 微服务(六) 服务消费Feign
我们在Spring Cloud 微服务(二) 创建一个简单的服务 创建了一个简单的服务,并且在Spring Cloud 微服务(三) 服务发现把这个简单的服务注册到了Eureka上,本篇我们介绍在另外一个服务里面消费这个服务,并实现负载均衡。在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 @EnableFeignClients public class FeignApplication { public static void main(String[] args) { SpringApplication.run(FeignApplication.class, args); } }
eureka: client: serviceUrl: defaultZone: http://localhost:8081/eureka/ server: port: 8766 spring: 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方法,带上我们的参数。
@RestController public 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: 8870 hi jeff from port: 8871 hi jeff from port: 8870 hi jeff from port: 8871
上一篇:Spring Cloud 微服务(四) Docker化
(1) http://blog.csdn.net/forezp/article/details/69808079
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- SpringCloud构建微服务架构:服务消费
- 7、服务发现&服务消费者Ribbon
- 8、服务发现&服务消费者Feign
- Dubbo 之服务消费原理
- Dubbo 之服务消费原理
- 微服务的消费 | 从0开始构建SpringCloud微服务(11)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Fortran95程序设计
彭国伦 / 中国电力出版社 / 2002-9 / 59.00元
本书介绍了当前国际上广泛流行的高级算法语言Fortran的全新版本Fortran 95。 本书循序渐进、由浅到深,使用结构化及面向对象程序设计观念,以简捷明了的方式把Fortran 95介绍给读者。书中主要讲述了Fortran 95程序设计的方法,包括数值计算、计算机绘图、窗口程序设计、与Visual C/Visual Basic/Delphi的链接、甚至是游戏程序的编写。 本书语言简洁,实......一起来看看 《Fortran95程序设计》 这本书的介绍吧!