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

您所在的位置:网站首页 小程序调用方法有几种 微服务之间相互调用的三种最常见方式(含源码)

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

2024-07-18 03:15:49| 来源: 网络整理| 查看: 265

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

一、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("测试用户"); order.setGid(goods.getId()); order.setGname(goods.getGoodsName()); order.setNumber(number); orderService.createOrder(order); log.info("下单成功"); return order; }

通过上面的方式我们解决了微服务之间的相互调用,但是存在硬编码的问题,如果服务提供者的地址发生变化,就需要手工修改代码;如果有多个服务提供者,无法实现服务的负载均衡;如果服务增多,人工调用会变得更加的复杂。

这个时候就会需要服务治理,服务治理是微服务架构最核心的问题,用于实现各个微服务的自动化注册与发现。在这里选择Nacos。

二、引入Nacos注册中心

1.在服务的提供者与消费者的pom文件中引入依赖

com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery

2.在application.yml中添加配置

spring: cloud: nacos: discovery: server-addr: 192.168.206.151:8848

3.在对应的微服务上添加

@EnableDiscoveryClient

4.代码

@Autowired private RestTemplate restTemplate; @Autowired private DiscoveryClient discoveryClient; @GetMapping("/createOrder2/{gid}/{number}") public Order order2(@PathVariable("gid") Integer id,@PathVariable("number") Integer number){ log.info("用户开始下单,调用商品系统,查询{}号商品信息",id); //从nacos中获取服务地址 ServiceInstance service = discoveryClient.getInstances("goods-service").get(0); String url = service.getHost() + ":" + service.getPort(); //通过restTemplate调用 Goods goods = restTemplate.getForObject("http://"+url+"/goods/getGoods/" + id, Goods.class); log.info("商品信息查询完毕:"+ JSON.toJSONString(goods)); log.info("开始下单:"); Order order = new Order(); order.setUid(1); order.setUname("测试用户"); order.setGid(goods.getId()); order.setGname(goods.getGoodsName()); order.setNumber(number); orderService.createOrder(order); log.info("下单成功"); return order; }

注:DiscoveryClient是专门负责服务注册和发现的,我们可以通过它获取到注册到注册中心的所有服务

三、Fegin实现服务调用

Feign是Spring Cloud提供的一个声明式的伪Http客户端, 它使得调用远程服务就像调用本地服务一样简单, 只需要创建一个接口并添加一个注解即可。

Nacos很好的兼容了Feign, Feign默认集成了 Ribbon, 所以在Nacos下使用Fegin默认就实现了负载均衡的效果。

在服务消费者上进行以下操作:

1.添加依赖

org.springframework.cloud spring-cloud-starter-openfeign

2.在启动类上添加注解

@EnableFeignClients

3.新建client包,并创建接口(把服务提供者controller对应的方法名复制过来,注意路径要完整。

@FeignClient("goods-service") public interface GoodsService { @RequestMapping("/goods/getGoods/{id}") public Goods goods(@PathVariable("id") Integer id); }

4.代码

@Autowired private GoodsService goodsService; @GetMapping("/createOrder3/{gid}/{number}") public Order order3(@PathVariable("gid") Integer id,@PathVariable("number") Integer number){ log.info("用户开始下单,调用商品系统,查询{}号商品信息",id); //通过feign调用商品微服务 Goods goods = goodsService.goods(id); log.info("商品信息查询完毕:"+ JSON.toJSONString(goods)); log.info("开始下单:"); Order order = new Order(); order.setUid(1); order.setUname("测试用户"); order.setGid(goods.getId()); order.setGname(goods.getGoodsName()); order.setNumber(number); orderService.createOrder(order); log.info("下单成功"); return order; }

好了,先介绍到这里,想要以上demo的可以加微信领取,另外还有一份《Java最新2022版面试题及解答-阿里内部资料(266页)》可以免费送给大家。



【本文地址】

公司简介

联系我们

今日新闻


点击排行

实验室常用的仪器、试剂和
说到实验室常用到的东西,主要就分为仪器、试剂和耗
不用再找了,全球10大实验
01、赛默飞世尔科技(热电)Thermo Fisher Scientif
三代水柜的量产巅峰T-72坦
作者:寞寒最近,西边闹腾挺大,本来小寞以为忙完这
通风柜跟实验室通风系统有
说到通风柜跟实验室通风,不少人都纠结二者到底是不
集消毒杀菌、烘干收纳为一
厨房是家里细菌较多的地方,潮湿的环境、没有完全密
实验室设备之全钢实验台如
全钢实验台是实验室家具中较为重要的家具之一,很多

推荐新闻


    图片新闻

    实验室药品柜的特性有哪些
    实验室药品柜是实验室家具的重要组成部分之一,主要
    小学科学实验中有哪些教学
    计算机 计算器 一般 打孔器 打气筒 仪器车 显微镜
    实验室各种仪器原理动图讲
    1.紫外分光光谱UV分析原理:吸收紫外光能量,引起分
    高中化学常见仪器及实验装
    1、可加热仪器:2、计量仪器:(1)仪器A的名称:量
    微生物操作主要设备和器具
    今天盘点一下微生物操作主要设备和器具,别嫌我啰嗦
    浅谈通风柜使用基本常识
     众所周知,通风柜功能中最主要的就是排气功能。在

    专题文章

      CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭