一止长渊

Nacos:如何调用其他微服务(中)

N 人看过
字数:796字 | 预计阅读时长:3分钟

上节我们将微服务模块注册到了注册中心 Nacos 中,接下来就是如何实现微服务模块之间接口的调用。
这里我们使用 SpringCloud-Alibaba 提供的 OpenFeign 进行微服务模块之间调用,如果微服务 A 需要调用微服务模块 B 的接口 1,那么我们如何实现呢?

首先介绍一下原理:微服务 A、微服务 B 相互调用,前提是两个微服务都已经注册到注册中心 Nacos 中。然后微服务模块 A1 需要调用微服务 B 时,就去注册中心查看健康可用微服务模块 B 的地址,然后通过 Nacos 返回一个健康可用的微服务模块 B1 的地址给微服务模块 A1,然后微服务模块通过利用 OpenFeign 向从 Nacos 中获得的地址发送HTTP 请求给微服务模块 B1 的接口 1,然后微服务 A1 调用微服务 B1 的接口 1 完成了。

上面介绍了后面的一些原理后,现在我们实现微服务 A 调用微服务 B 的功能,这里以用户服务调用优惠券服务查看该用户的优惠券为例。

  1. 首先两个模块都要注册到注册中心中,上节已经实现
  2. 优惠券服务模块编写被调用接口
@RestController
@RequestMapping("coupon/coupon")
public class CouponController {
    @Autowired
    private CouponService couponService;

    @RequestMapping(value="/member/list")
    public R membercoupons(){
        CouponEntity couponEntity = new CouponEntity();
        couponEntity.setCouponName("满100减10");
        return R.ok().put("coupons", Arrays.asList(couponEntity));
    }
}
  1. 用户服务模块引入 OpenFeign 依赖
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
  1. 用户模块编写一个对应优惠券服务的声明式远程调用接口,指明需要调用微服务的名称以及调用该服务的哪个接口

    OpenFeign 通过声明式远程调用接口来实现调用服务,这样微服务 A 通过该接口就可以实现无感调用

package com.lookstarry.doermail.member.feign;

import com.lookstarry.common.utils.R;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @PackageName:com.lookstarry.doermail.member.feign
 * @NAME:CouponFeignService
 * @Description:
 * @author: yizhichangyuan
 * @date:2021/3/13 21:46
 */

/**
 * 这是一个声明式的远程调用,指明调用注册中心的那个服务的那个接口方法
 */
@FeignClient("doermail-coupon") //调用的微服务名称
public interface CouponFeignService {
    @RequestMapping("/coupon/coupon/member/list") //对应调用哪个接口
    public R membercoupons();
}
  1. 用户服务模块需要加上 EnableFeignClients 开启远程调用功能,指明自己哪个包是远程调用模块
package com.lookstarry.doermail.member;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

/**
 * 1、调用远程调用别人的服务
 * 1)、引入open-feign
 * 2)、编写一个接口,告诉springCloud这个接口需要调用远程服务
 *  1、声明接口的每一个方法都是调用哪个远程服务的哪个请求
 * 3)、开启远程调用功能
 *
 */
@EnableFeignClients(basePackages = "com.lookstarry.doermail.member.feign")
@SpringBootApplication
@EnableDiscoveryClient
public class DoermailMemberApplication {

    public static void main(String[] args) {
        SpringApplication.run(DoermailMemberApplication.class, args);
    }
}

本作品采用 知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议 (CC BY-NC-ND 4.0) 进行许可。