【教程】微服务使用Feign接口进行远程调用的步骤

Sample

以 finance 模块 调用 exchange 模块 的 MarketService 为例。

Steps

服务提供者(exchange):搭建接口

  1. 在 exchange-api 下,新建 MarketDto 和 MarketServiceFeign。并在 exchange-service 下使用 MapStruct 进行映射。

在 dto 包,

java 复制代码
@Data
@ApiModel(value = "Market RPC数据的传输对象")
public class MarketDto {
	// ......(一些属性)
}

在 feign 包,

java 复制代码
@FeignClient(name = "exchange-service", configuration = OAuth2FeignConfig.class, path = "/markets")
public interface MarketServiceFeign {
	@GetMapping("/getMarket")
    MarketDto findByCoinId(Long sellCoinId, Long buyCoinId);
}

在 mappers 包,

java 复制代码
// MapStruct 会自动生成实现类
@Mapper(componentModel = "spring")
public interface MarketDtoMappers {
    MarketDtoMappers INSTANCE = Mappers.getMapper(MarketDtoMappers.class);

    MarketDto entity2Dto(Market market);

    Market dto2Entity(MarketDto marketDto);

    List<MarketDto> entity2Dto(List<Market> market);

    List<Market> dto2Entity(List<MarketDto> marketDto);
}
  1. 在 exchange-service 的 MarketController 下实现 MarketServiceFeign,
java 复制代码
@RestController
@RequestMapping("/markets")
@Api(tags = "交易市场的控制器")
public class MarketController implements MarketServiceFeign {
	// ......(其他controller)

    @Override
    public MarketDto findByCoinId(Long sellCoinId, Long buyCoinId) {
        MarketDto marketDto = marketService.findByCoinId(buyCoinId, sellCoinId);
        return marketDto;
    }

服务消费者(finance):调用接口

在 finance-service 的对应实现类注入 MarketServiceFeign 并调用方法,

java 复制代码
@Service
public class AccountServiceImpl extends ServiceImpl<AccountMapper, Account> implements AccountService{
	@Autowired
    private MarketServiceFeign marketServiceFeign;
    
    @Override
    public UserTotalAccountVo getUserTotalAccount(Long userId) {
    	// ......(业务逻辑)
    	// 调用 Feign 远程接口
        MarketDto marketDto = marketServiceFeign.findByCoinId(basicCoinId, coinId);
        // ......
    }
相关推荐
coffee_baby9 分钟前
化繁为简:中介者模式如何管理复杂对象交互
java·spring boot·microsoft·交互·中介者模式
ღ᭄ꦿ࿐Never say never꧂13 分钟前
微服务架构中的负载均衡与服务注册中心(Nacos)
java·spring boot·后端·spring cloud·微服务·架构·负载均衡
所待.38315 分钟前
小小扑克牌算法
java·算法
.生产的驴22 分钟前
SpringBoot 消息队列RabbitMQ 消息确认机制确保消息发送成功和失败 生产者确认
java·javascript·spring boot·后端·rabbitmq·负载均衡·java-rabbitmq
.生产的驴23 分钟前
SpringBoot 消息队列RabbitMQ在代码中声明 交换机 与 队列使用注解创建
java·spring boot·分布式·servlet·kafka·rabbitmq·java-rabbitmq
idealzouhu36 分钟前
Java 并发编程 —— AQS 抽象队列同步器
java·开发语言
听封40 分钟前
Thymeleaf 的创建
java·spring boot·spring·maven
写bug写bug1 小时前
6 种服务限流的实现方式
java·后端·微服务
楠枬1 小时前
双指针算法
java·算法·leetcode