【通讯协议】gRPC和Webhook

RPC(Remote procedure Call)之所以被称为“远程”,是因为在微服务架构下,当服务部署到不同的服务器上时,它可以实现远程服务之间的通信。从用户的角度来看,它的作用就像本地函数调用。

下图说明了gRPC的整体数据流。

步骤 1:从客户端发出 REST 调用。请求正文通常为 JSON 格式。

步骤 2 - 4:订单服务(gRPC 客户端)接收 REST 调用,对其进行转换,并对支付服务进行 RPC 调用。gRPC 将客户端存根编码为二进制格式并将其发送到低级传输层。

步骤 5:gRPC 通过 HTTP2 通过网络发送数据包。由于二进制编码和网络优化,gRPC 据说比 JSON 快 5 倍。

步骤 6 - 8:支付服务(gRPC 服务器)从网络接收数据包,对其进行解码,然后调用服务器应用程序。

步骤 9 - 11:结果从服务器应用程序返回,经过编码后发送到传输层。

步骤 12 - 14:订单服务接收数据包,对其进行解码,并将结果发送到客户端应用程序。

什么又是网络钩子呢? 

下图显示了轮询和 Webhook 之间的比较。 

假设我们运营一个电子商务网站。客户端通过API网关向订单服务发送订单,订单服务再到支付服务进行支付交易。然后,支付服务与外部支付服务提供商 (PSP) 对话以完成交易。 

有两种方法可以处理与外部 PSP 的通信。 

假设我们运营一个电子商务网站。客户端通过API网关向订单服务发送订单,订单服务再到支付服务进行支付交易。然后,支付服务与外部支付服务提供商 (PSP) 对话以完成交易。 

有两种方法可以处理与外部 PSP 的通信。 

1. 短轮询 

支付服务向PSP发送支​​付请求后,不断向PSP询问支付状态。经过几轮之后,PSP终于返回状态。 

短轮询有两个缺点: 

  • 持续轮询状态需要支付服务的资源。 
  • 外部服务直接与支付服务通信,从而产生安全漏洞。 

2. 网络钩子 

我们可以向外部服务注册一个 webhook。这意味着:当您有请求更新时,通过某个 URL 给我回电。当 PSP 完成处理后,它将调用 HTTP 请求来更新支付状态。

这样就改变了编程范式,支付服务不再需要浪费资源来轮询支付状态。

如果 PSP 不回电怎么办?我们可以设置一个内务工作来每小时检查付款状态。

Webhooks 通常称为反向 API 或推送 API,因为服务器向客户端发送 HTTP 请求。使用webhook时我们需要注意3件事:

  1. 我们需要设计一个合适的API供外部服务调用。
  2. 出于安全原因,我们需要在 API 网关中设置适当的规则。
  3. 我们需要在外部服务中注册正确的 URL。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/218876.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CodeTON Round 7(D、E)

D - Ones and Twos 题意:给你一个长度为 n 的 数组 a ,其中每个元素都是 1 或 2。请处理以下两种类型的询问 "1 s":检查是否存在 a的子数组 ,其总和等于 s。 "2 i v":将 ai改为v。 如果数组 …

【开源】基于微信小程序的智慧家政系统

项目编号: S 063 ,文末获取源码。 \color{red}{项目编号:S063,文末获取源码。} 项目编号:S063,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块三、系统展示四、核心代码4.1 查询家政服…

Keil5个性化设置及常用快捷键

Keil5个性化设置及常用快捷键 1.概述 这篇文章是Keil工具介绍的第三篇文章,主要介绍下Keil5优化配置,以及工作中常用的快捷键提高开发效率。 第一篇:《安装嵌入式单片机开发环境Keil5MDK以及整合C51开发环境》https://blog.csdn.net/m0_380…

Linux常用命令——bg命令

在线Linux命令查询工具 bg 用于将作业放到后台运行 补充说明 bg命令用于将作业放到后台运行,使前台可以执行其他任务。该命令的运行效果与在指令后面添加符号&的效果是相同的,都是将其放到系统后台执行。 在Linux系统中执行某些操作时候&…

drool 7 multiThread 测试

基本信息 通过option ,使用如下代码进行设置 //线程数量10MaxThreadsOption optionMaxThreadsOption.get(10);kieBaseConf.setOption(option);kieBaseConf.setOption(MultithreadEvaluationOption.YES);并发是以CompositeDefaultAgenda/Rule为颗粒度来的&#xff0…

虚拟机可ping树莓派树莓派无法ping虚拟机 的解决办法

问题描述 在学习交叉编译的过程中,发现了树莓派无法ping通虚拟机的问题。所以我尝试了各种ping,发现: 虚拟机可以ping通树莓派和主机树莓派可以ping通主机主机可以ping通树莓派和虚拟机唯独树莓派没法ping通虚拟机 尝试各种方法后找到一种…

香港站群服务器中1C/2C/4C/8C 的概念及区别

​  在选择香港站群服务器时,经常会看到1C、2C、4C和8C等不同的IP段。这些IP段代表了不同的子网掩码长度,也反映了服务器的IP地址数量和丰富性。 让我们来了解一下什么是IP段。IP段是指一组连续的IP地址,其中每个地址的前三个数字相同&…

计算机网络常考计算题之循环冗余校验(宝典教学)

文章目录 奇偶效验循环冗余校验例题四步走另一种题型 本文讲述了计算机考研中易出现的循环冗余校验,点赞关注收藏不迷路哦 我是一名双非计算机本科生,希望我的文章可以帮助到你。 奇偶效验 奇偶校验:也可以检测数据在传输过程中是否出现错误…

【算法挨揍日记】day33——1027. 最长等差数列、446. 等差数列划分 II - 子序列

1027. 最长等差数列 1027. 最长等差数列 题目描述&#xff1a; 给你一个整数数组 nums&#xff0c;返回 nums 中最长等差子序列的长度。 回想一下&#xff0c;nums 的子序列是一个列表 nums[i1], nums[i2], ..., nums[ik] &#xff0c;且 0 < i1 < i2 < ... < …

机器学习-线性模型·

线性模型是一类用于建模输入特征与输出之间线性关系的统计模型。这类模型的基本形式可以表示为&#xff1a; 其中&#xff1a; 是模型的输出&#xff08;目标变量&#xff09;。 是截距&#xff08;常数项&#xff0c;表示在所有输入特征都为零时的输出值&#xff09;。 是权重…

在项目中集成marsUI

拷贝文件夹到目标项目 集成 安装相关依赖 npm i --save ant-design-vue4.x npm i less npm i nprogress npm i consola npm i echarts npm i vue-color-kit npm i icon-park/svg npm i vite-plugin-style-import 配置Vite文件 使用 效果

C#,《小白学程序》第二十七课:大数四则运算之“运算符重载”的算法及源程序

1 文本格式 using System; using System.Text; using System.Collections; using System.Collections.Generic; /// <summary> /// 大数的四则&#xff08;加减乘除&#xff09;运算 /// 及其运算符重载&#xff08;取余数&#xff09; /// </summary> public cl…