简单使用openfeign实现服务间的调用

openfeign依赖(此处选用的版本环境可以看我的nacos的帖子,有详细说明)

        <!--Open Feign依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

首先我们新建两个服务,并将其注册到注册中心(以nacos为例

#服务名设置
spring.application.name=nacos-test
#端口设置
server.port=8081
#nacos服务地址
spring.cloud.nacos.discovery.server-addr=http://localhost:8848
#该服务向nacos服务端发送心跳的间隔,单位为毫秒,默认30秒(用以监听服务是否还存活)
spring.cloud.nacos.discovery.heart-beat-interval=1000
#该服务在停止向nacos发送心跳后,服务状态从健康到不健康的时间
spring.cloud.nacos.discovery.heart-beat-timeout=3000

两个测试服务除了端口外完全相同,均提供hello方法,打印各自的端口号

启动nacos和两个服务,nacos观察我们的nacos-test服务成功注册且实例数量为2 

 新建feign-test服务并将其注册进nacos中

server.port=8082

#服务名设置
spring.application.name=feign-test

#nacos服务地址
spring.cloud.nacos.discovery.server-addr=http://localhost:8848

#该服务向nacos服务端发送心跳的间隔,单位为毫秒,默认30秒(用以监听服务是否还存活)
spring.cloud.nacos.discovery.heart-beat-interval=1000
#该服务在停止向nacos发送心跳后,服务状态从健康到不健康的时间
spring.cloud.nacos.discovery.heart-beat-timeout=3000

注意启动类上加上@EnableFeignClients注解

 核心步骤,在feign-test项目中需要新建一个接口,该接口上添加@FeignClient(value = "nacos-test")注解,并在value中指定我们需要调用的服务名(和nacos中注册的服务名保持一致),并将我们需要调用的方法签名(除了方法主体之外的方法定义,包括注解等)复制过来

 我们在feign-test项目中新建一个测试controller,通过自动注入的方式拿到接口的实例对象,即可调用其中定义的方法(openfeign会通过注册中心帮我们去指定的服务中调用其中的方法)

启动项目, 访问fiegntest的测试controller,成功调用到nacos-test服务中的hello方法

 多次访问我们会发现feign会帮我们依次调用nacos-test服务中8080和8081两个实例中的方法

 这是因为openfeign中自动帮我们集成了ribbon负载均衡组件,如果要了解一些基础原理可以去了解一下restTemplate和ribbon

在微服务架构中,服务需要进行相互调用,而OpenFeign可以作为一种服务调用的工具来实现这一过程。下面是OpenFeign实现服务调用的步骤: 1. 引入OpenFeign依赖 在项目的pom.xml文件中,引入OpenFeign依赖。例如: ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>2.2.2.RELEASE</version> </dependency> ``` 2. 创建Feign接口 在通过OpenFeign调用服务时,需要先创建一个Feign接口,用于定义服务调用的方法及其参数。例如: ``` @FeignClient(name = "service-provider", fallback = ServiceProviderFallback.class) public interface ServiceProviderFeignClient { @GetMapping("/hello") String hello(); @PostMapping("/user") User addUser(@RequestBody User user); @GetMapping("/user/{id}") User getUserById(@PathVariable("id") Long id); } ``` 其中,@FeignClient注解用于指定服务名,fallback属性用于指定服务降级处理类。 3. 调用Feign接口 在需要调用服务的地方,通过注入Feign接口的方式来调用服务。例如: ``` @RestController public class ConsumerController { @Autowired private ServiceProviderFeignClient serviceProviderFeignClient; @GetMapping("/hello") public String hello() { return serviceProviderFeignClient.hello(); } @PostMapping("/user") public User addUser(@RequestBody User user) { return serviceProviderFeignClient.addUser(user); } @GetMapping("/user/{id}") public User getUserById(@PathVariable("id") Long id) { return serviceProviderFeignClient.getUserById(id); } } ``` 通过调用Feign接口的方法,即可实现服务调用。 总体来说,OpenFeign是一种比较方便的服务调用工具,在微服务架构中得到了广泛的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值