微服务之间相互调用的三种最常见方式(含源码)

本文介绍了微服务架构中常见的三种服务间调用方式:1) 使用RestTemplate,虽然方便但存在硬编码和服务治理问题;2) 引入Nacos注册中心解决服务发现与治理;3) 利用Feign实现声明式调用,结合Nacos实现负载均衡。详细步骤涵盖依赖引入、配置设置和代码实现。
摘要由CSDN通过智能技术生成

相信大家平时开发的时候没少碰见,在微服务架构中需要调用很多服务才能完成一项功能。这时候,如何互相调用就变成微服务架构中的一个关键问题。在这里我介绍三个常用的方法

一、RestTemplate方式

@Bean
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }

服务的消费者(order)调用服务的提供者(Goods)

@Autowired
    private RestTemplate restTemplate;

    @GetMapping("/createOrder/{gid}/{number}")
    public Order order(@PathVariable("gid") Integer id,@PathVariable("number") Integer number){
        log.info("用户开始下单,调用商品系统,查询{}号商品信息",id);
        Goods goods = restTemplate.getForObject("http://localhost:9002/goods/getGoods/" + id, Goods.class);
        log.info("商品信息查询完毕:"+ JSON.toJSONString(goods));

        log.info("开始下单:");
        Order order = new Order();
        order.setUid(1);
        order.setUname(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值