微服务之间相互调用的三种最常见方式(含源码)
2023-04-18 16:25:40 时间
相信大家平时开发的时候没少碰见,在微服务架构中需要调用很多服务才能完成一项功能。这时候,如何互相调用就变成微服务架构中的一个关键问题。在这里我介绍三个常用的方法
一、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文件中引入依赖
<!--nacos客户端-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
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.添加依赖
<!--fegin组件-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
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页)》可以免费送给大家。
相关文章
- 从托管到原生,MPP架构数据仓库的云原生实践
- 快速上手 Serverless|入门第一课
- 部署混合云面临的挑战以及应对它们的方法
- 创建云迁移测试策略指南
- 五分钟带你了解 HTTP 代理
- 2022年针对云计算基础设施的网络犯罪威胁将不断上升
- 三大核心优势,亚马逊云科技助力跨国企业植根中国
- NASA认为月球很快将拥有自己的互联网
- 16项不可抗拒的云创新
- 打造未来医院 Aruba 助力美国阿拉巴马州儿童医院数字化转型
- 开放包容·协同创新——网络前沿技术分论坛在京举办
- 云计算 「半步巅峰」
- 2022年云计算行业的五大发展趋势
- EDA 事件驱动架构与 EventBridge 二三事
- 云计算越发成熟它将带动哪些行业发展?
- Podman是什么?和Docker有啥区别?
- HTTPS 协议到底比 HTTP 协议多些什么?
- 割接失败,导致3/4/5G全网通信故障
- 亚马逊云科技修复了 AWS Glue 服务中的安全漏洞
- 割接失败导致重大通信故障