1.1 同步调用与异步调用

简介: 本文介绍了微服务间的同步与异步调用。同步调用需等待结果返回,顺序执行,适合实时性高、操作简单的场景;异步调用发出请求后可继续执行其他任务,提升效率与资源利用率,适用于耗时操作。通过支付、点餐、挂号等生活实例对比,阐述了二者特点、适用场景及优缺点。

前边我们学习了微服务之间远程调用方式,通常服务端提供HTTP RESTful接口,客户端通过HTTP Client工具进行远程调用,远程调用工具有RestTemplate、OpenFeign、OkHttp等技术,这些技术实现的都是一种类型即同步调用,微服务之间通信还有一种异步调用,什么是同步调用?什么是异步调用?
拿订单支付功能举例,下图表示了同步调用

支付的交互流程如下:

  1. 支付服务调用用户服务扣减余额。
  2. 余额扣减成功后支付服务更新数据库中的交易流水状态为已支付。
  3. 更新成功后支付服务调用交易服务更新订单状态为已支付。
    像这种每一步调用者必须等待被调用方完全执行完毕并返回结果之后才能继续执行后续代码,叫同步调用。
    同步调用就是顺序执行,执行完一步再执行下一步。
    什么是异步调用?
    异步调用是调用者发出调用后无需等待被调用方完成就可以继续执行其他任务。
    举例:

支付的交互流程如下:

  1. 支付服务调用用户服务扣减余额。
  2. 余额扣减成功后支付服务更新数据库中的交易流水状态为已支付。
  3. 更新交易流水成功支付服务向消息中间件发消息(XX订单支付成功),此时支付服务程序执行结束
  4. 由消息中间件去通知交易服务更新订单状态
  5. 由消息中间件去通知短信服务通知用户订单支付成功啦
    上边交互流程中前3步为同步调用,后2步为异步调用。
    支付服务向消息中间件发过消息后不用等继续执行其它操作,这就是异步调用。
    现在生活中异步调用的例子很多:
    餐厅点餐:
    想象一下你去一家餐厅吃饭,你坐下后,服务员过来让你点菜。在这个过程中:
    ● 异步调用:你告诉服务员你想要什么菜品,然后服务员把订单送到厨房。你不需要等待食物准备完成,可以继续聊天或浏览菜单。当食物准备好时,服务员会将食物端到你的桌上。
    ● 同步调用:如果你必须站在厨房门口等着厨师为你准备食物,那么这就是一个同步的过程。你无法做其他事情,直到食物准备完毕。
    医院挂号:
    ● 异步调用:打电话挂号,接通电话你告诉工作人员挂哪个科室,工作人员让你挂断电话稍后通过手机查看挂号结果。
    ● 同步调用:打电话挂号,接通电话你告诉工作人员挂哪个科室,工作人员开始查看该科室是否有号,并进行挂号,挂号结束告诉你几点来看病,最后挂断电话。
    同步调用:
    特点:
    ● 在同步调用中,调用者必须等待被调用方完全执行完毕并返回结果之后才能继续执行后续代码。
    ● 控制流是线性的,即程序按照顺序执行每个操作。
    ● 如果被调用方执行时间较长,那么整个程序会处于等待状态,直到该调用完成。
    适合场景:
    ● 对实时性要求较高的场景,例如用户界面操作。
    ● 调用简单且执行快速的操作。
    优点
    ● 简单直观:代码易于理解和编写,因为它是按顺序执行的。
    ● 易于调试:由于执行顺序明确,调试起来相对容易。
    缺点
    ● 阻塞执行:如果一个操作需要很长时间来完成,那么整个程序会被阻塞,不能执行其他任务。
    ● 资源浪费:在等待长时间操作完成时,CPU和其他资源可能会处于空闲状态。
    异步调用:
    特点:
    ● 在异步调用中,调用者发出调用后无需等待被调用方完成就可以继续执行其他任务。
    ● 被调用方完成操作后,通常会通过回调函数、事件通知或者完成信号等方式告知调用者。
    ● 可以提高程序的并发能力和响应速度。
    适合场景:
    ● 需要处理耗时操作,例如网络请求、文件I/O等。
    ● 多个操作之间不存在严格的依赖关系。
    ● 对系统性能和响应时间有较高要求的应用场景。
    优点
    ● 提高效率:异步调用可以使程序在等待某些耗时操作完成的同时执行其他任务,提高整体执行效率。
    ● 资源利用率高:在等待耗时操作时,可以释放资源给其他任务使用,避免了资源浪费。
    ● 更好的用户体验:在网络应用中,用户不必等待页面加载完成就能进行其他操作,提高了用户体验。
    缺点
    ● 复杂性增加:异步编程通常比同步编程更复杂,因为它涉及更多的控制结构和错误处理逻辑。
    ● 调试困难:由于执行路径不是线性的,调试起来相对困难。
相关文章
|
运维 监控 网络协议
什么是运营商级 NAT (CGNAT)?
【4月更文挑战第16天】
7275 10
什么是运营商级 NAT (CGNAT)?
|
3月前
|
JavaScript 数据可视化 Java
开源医院随访系统:基于Spring Boot、Vue前后端分离的源码解决方案
医院随访系统是连接院内HIS/EMR的智能平台,支持电话、短信、微信等多渠道随访,涵盖关怀与管理两类场景。采用Java+Spring Boot+Vue技术栈,具备模板灵活配置、智能提醒、满意度闭环、数据报表等功能,延伸医疗服务链,提升康复质量与管理决策水平。
216 0
|
4月前
|
关系型数据库 应用服务中间件 nginx
容器化部署引擎Docker
Docker是一种轻量级容器化技术,通过镜像打包应用及依赖,实现跨环境一致部署。它利用沙箱机制隔离容器,解决开发、测试、生产环境差异与组件兼容性问题,相比虚拟机更高效便捷,提升应用交付效率。
容器化部署引擎Docker
|
4月前
|
JSON 安全 JavaScript
HTTPS 原理
HTTPS是HTTP与SSL/TLS的结合,通过数字证书验证身份,利用非对称加密安全交换会话密钥,再以对称加密高效传输数据。它确保了通信的机密性、完整性和服务器真实性,在互联网上构建安全加密通道。
|
6月前
|
机器学习/深度学习 数据采集 人工智能
35_BERT与RoBERTa:优化编码器模型
2018年,Google发布的BERT(Bidirectional Encoder Representations from Transformers)模型彻底改变了自然语言处理领域的格局。作为第一个真正意义上的双向预训练语言模型,BERT通过创新的掩码语言模型(Masked Language Model, MLM)预训练策略,使模型能够同时从左右两侧的上下文信息中学习语言表示,从而在多项NLP任务上取得了突破性进展。
653 0
|
机器学习/深度学习 人工智能 算法
现身说法,AI小白的大模型学习路径
写这篇文章的初衷:作为一个AI小白,把我自己学习大模型的学习路径还原出来,包括理解的逻辑、看到的比较好的学习材料,通过一篇文章给串起来,对大模型建立起一个相对体系化的认知,才能够在扑面而来的大模型时代,看出点门道。
1563 79
|
数据采集 缓存
访问网站的速度变慢的原因有什么,有哪些解决方法?
随着互联网技术和科技的发展,在上网的时候使用代理ip的使用人数也越来越多,因为业务的需求需要使用http动态代理ip的应用范围越来越多,那么访问网站的速度变慢的原因有什么,有哪些解决方法? 接下来小编就给大家介绍一下
1176 2
|
存储 Java 开发者
Java性能优化(一):Java基础-ArrayList和LinkedList
前面我们已经从源码的实现角度深入了解了ArrayList和LinkedList的实现原理以及各自的特点。如果你能充分理解这些内容,很多实际应用中的相关性能问题也就迎刃而解了。就像如果现在还有人跟你说,“ArrayList和LinkedList在新增、删除元素时,LinkedList的效率要高于ArrayList,而在遍历的时候,ArrayList的效率要高于LinkedList”,你还会表示赞同吗?现在我们不妨通过几组测试来验证一下。
217 1