轻量级通信协议 JSON-RPC 2.0 详解

目录

JSON-RPC 2.0 简介

请求对象

响应对象

通知

批量请求

错误码

使用场景

文档和版本控制

社区和支持

小结

参考资料


JSON-RPC 2.0 简介

JSON-RPC (JavaScript Object Notation - Remote Procedure Call) 是一种轻量级的远程过程调用协议,使用 JSON(JavaScript 对象表示法)作为数据格式。JSON-RPC 2.0 是该协议的最新版本,在 1.0 版本的基础上增加了一些特性,如错误代码标准化、批量请求支持和无响应的通知。

JSON-RPC 的设计原则是简单性和互操作性,旨在为不同编程语言之间提供一种方便的方法来执行远程过程调用。通过定义一组简单的规则,任何能够解析 JSON 的语言或平台都可以实现 JSON-RPC 客户端或服务器。

接下来看下 JSON-RPC 2.0 协议的规范。

请求对象

一个 JSON-RPC 2.0 请求数据是一个单一的 JSON 对象,可以包含以下成员:

  • jsonrpc:字符串,指定 JSON-RPC 的版本号,对于 2.0 规范来说,这个值必须是 2.0。
  • method:字符串,指定要调用的远程方法的名称。
  • params:结构化值,可以是数组或者对象,传递给远程方法的参数。如果方法不需要参数可以省略。
  • id:唯一标识符,可以是字符串或数字,用于关联请求和响应,服务端必须返回相同的值。如果请求是一个通知类型,则此参数可以被省略。

一个标准的 JSON-RPC 2.0 请求示例如下:

{"jsonrpc": "2.0","method": "subtract","params": [42, 23],"id": 1
}

响应对象

一个 JSON-RPC 2.0 响应数据也是一个单一的 JSON 对象,可以包含以下成员:

  • jsonrpc:字符串,指定 JSON-RPC 的版本号,对于 2.0 规范来说,这个值必须是2.0。
  • result:当请求成功时,包含由远程方法返回的结果。如果请求失败,则不包含此成员。
  • error:当请求失败时,包含一个错误对象。如果请求成功,则不包含此成员。
  • id:与请求中的 id 相同,用于识别哪个请求对应的响应。

错误对象包括以下成员:

  • code:整数,用于说明错误类型。JSON-RPC 2.0 定义了一组标准的错误码。
  • message:字符串,提供关于错误的简短描述。
  • data:可选,可以包含额外的错误信息,比如堆栈信息等。

一个成功的响应示例如下:

{"jsonrpc": "2.0","result": 19,"id": 1
}

而一个异常响应示例如下:

{"jsonrpc": "2.0","error": {"code": -32601,"message": "Method not found"},"id": 1
}

通知

通知是一种特殊类型的请求,没有 id 成员,因此不会得到响应。这样客户端可以向服务器发送事件或命令而无需等待回复。一个通知示例如下:

{"jsonrpc": "2.0","method": "updateStatus","params": ["online"]
}

批量请求

JSON-RPC 2.0 支持批量请求,即可以在单个请求中发送多个 JSON-RPC 调用。每个调用都是独立的 JSON-RPC 请求对象,被放在一个数组中。服务器处理这些请求后返回一个数组,其中每个元素对应于一个调用。需要注意的是,如果其中一个调用是通知,则不会有对应的响应项。

[{"jsonrpc": "2.0","method": "sum","params": [1, 3, 5, 7, 9],"id": "1"},{"jsonrpc": "2.0","method": "notify_hello","params": ["Alice"]},{"jsonrpc": "2.0","method": "subtract","params": [42, 23],"id": "2"}
]

错误码

JSON-RPC 2.0 规范中定义了标准的错误码,但开发者也可以根据自己的业务逻辑添加自定义的错误码。这些自定义错误代码应该在-32000到-32099之间,以避免与标准错误码冲突。通过使用自定义错误码,可以为客户端提供更加具体的错误信息。

假如这样一个场景,应用程序需要处理用户认证失败的情况,可以定义一个特定的错误码,比如 -32001,并为这个错误码配一个说明,如 Authentication failed。示例如下:

{"jsonrpc": "2.0","error": {"code": -32001,"message": "Authentication failed"},"id": "1"
}

此外,还可以在  error 的 data 参数中包含更多的错误细节,比如错误发生的具体位置或建议的解决方法。

JSON-RPC 2.0 定义的标准错误码如下(自定义错误吗不要使用如下几个):

  • -32700: 解析错误,服务器收到无效的 JSON。
  • -32600: 无效请求,发送的 JSON 不是有效的请求对象。
  • -32601: 方法未找到,方法不存在或无效。
  • -32602: 无效参数,提供的参数无效。
  • -32603: 内部错误,JSON-RPC 内部错误。

使用场景

JSON-RPC 2.0 的使用场景包括但不限于如下几个:

  • Web 应用程序,客户端与服务器之间的异步通信,例如浏览器与后端服务交互。
  • 微服务之间的通信,通过 JSON-RPC 调用其他微服务的接口。
  • 物联网设备,设备与服务器之间的通信,由于 JSON-RPC 的轻量级特性,非常适合资源受限的设备。
  • 移动应用,移动客户端与服务器之间的交互,减少数据传输量,提高响应速度。
  • 区块链和加密货币,节点之间的通信或客户端与节点的交互,许多区块链系统(如以太坊)使用 JSON-RPC 进行接口调用。
  • 远程过程调用(RPC)服务,替代传统的 SOAP 或 XML-RPC,提供简单的接口调用机制。

文档和版本控制

良好的文档对于任何 API 都至关重要,尤其是像 JSON-RPC 2.0 这样依赖于明确的请求和响应格式的协议。

  • 编写清晰的 API 文档:详细描述每个方法的用途、参数、返回值和可能的错误情况。可以使用工具如 Swagger 或 Postman 来生成交互式的 API 文档。
  • 保持文档更新:随着 API 的发展,确保文档始终保持最新状态,反映最新的变更和改进。
  • 版本控制:为 API 引入版本控制,以便在不影响现有用户的情况下进行更新。可以在 URL 中或通过请求头指定 API 版本。

社区和支持

JSON-RPC 2.0 是一个开放的标准,拥有活跃的社区和丰富的资源。参与社区讨论、阅读官方文档和技术博客、关注相关论坛和社交媒体,都可以帮助更快地解决问题,并获取最新的最佳实践。

此外,很多流行的编程语言和框架都有现成的 JSON-RPC 库,可以大大简化开发过程。选择一个成熟且维护良好的库,不仅可以节省时间,还能减少出错的可能性。

小结

JSON-RPC 2.0作为一种轻量级的 RPC 协议,提供了如标准化的错误处理、批量请求支持和通知机制等功能,具有简单、易用、跨语言等优点,适用于多种分布式系统场景。

参考资料

  • https://www.jsonrpc.org/specification

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

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

相关文章

【JVM】总结篇-类的加载篇之 类的加载器 和ClassLoader分析

文章目录 类的加载器ClassLoader自定义类加载器双亲委派机制概念源码分析优势劣势如何打破Tomcat 沙箱安全机制JDK9 双亲委派机制变化 类的加载器 获得当前类的ClassLoader clazz.getClassLoader() 获得当前线程上下文的ClassLoader Thread.currentThread().getContextClassLoa…

nginx学习之路-nginx配置https服务器

文章目录 1. 生成证书2. 配置证书1. 拷贝证书文件2. 修改conf/nginx.conf文件内容 3. 查看效果1. 重载配置2. 访问 1. 生成证书 在linux系统下执行,使用openssl命令。(windows环境也可以使用cmder) # 1. 生成私钥 server2025.key(无密码保护…

鸿蒙应用开发搬砖经验之—使用DevTools工具调试前端页面

环境说明: 系统环境:Mac mini M2 14.5 (23F79) 开发IDE:DevEco Studio 5.0.1 Release 配置步骤: 按着官方的指引来慢慢一步一步来,但前提是要配置好SDK的路径(没有配置的话,可能先看下面的配…

【NLP高频面题 - 分布式训练篇】ZeRO主要为了解决什么问题?

【NLP高频面题 - 分布式训练篇】ZeRO主要为了解决什么问题? 重要性:★★ 零冗余优化器技术由 DeepSpeed 代码库提出,主要用于解决数据并行中的模型冗余问题,即每张 GPU 均需要复制一份模型参数。 ZeRO的全称是Zero Redundancy …

《探秘计算机视觉与深度学习:开启智能视觉新时代》

《探秘计算机视觉与深度学习:开启智能视觉新时代》 一、追溯起源:从萌芽到崭露头角二、核心技术:解锁智能视觉的密码(一)卷积神经网络(CNN):图像识别的利器(二&#xff0…

[paddle] 非线性拟合问题的训练

利用paddlepaddle建立神经网络,模拟有限个数据的非线性拟合 本文仍然考虑 f ( x ) sin ⁡ ( x ) x f(x)\frac{\sin(x)}{x} f(x)xsin(x)​ 函数在区间 [-10,10] 上固定数据的拟合。 import paddle import paddle.nn as nn import numpy as np import matplotlib.…

详解GPT-信息抽取任务 (GPT-3 FAMILY LARGE LANGUAGE MODELS)

GPT-3 FAMILY LARGE LANGUAGE MODELS Information Extraction 自然语言处理信息提取任务(NLP-IE):从非结构化文本数据中提取结构化数据,例如提取实体、关系和事件 [164]。将非结构化文本数据转换为结构化数据可以实现高效的数据处…

逆向入门(2)C篇-基础知识

C基础 1、在C中,函数的变量是从右往左传递的,也就是test(x,y),先传入y,再传x。 2、变量的分类: (1)全局变量。在编译的时候就已经确定了内存地址和宽度,变量名就是内存地址的别名…

服务器数据恢复—离线盘数超过热备盘数导致raidz阵列崩溃的数据恢复

服务器数据恢复环境&故障: 一台配有32块硬盘的服务器在运行过程中突然崩溃不可用。经过初步检测,基本上确定服务器硬件不存在物理故障。管理员重启服务器后问题依旧。需要恢复该服务器中的数据。 服务器数据恢复环境: 1、将服务器中硬盘…

Echart实现3D饼图示例

在可视化项目中,很多地方会遇见图表;echart是最常见的;这个示例就是用Echart, echart-gl实现3D饼图效果,复制即可用 //需要安装,再引用依赖import * as echarts from "echarts"; import echar…

PostgreSQL学习笔记(一):PostgreSQL介绍和安装

目录 概念 PostgreSQL简介 PostgreSQL的关键特性 1. 标准兼容性 2. 扩展性 3. 数据完整性和可靠性 4. 丰富的数据类型 5. 查询能力 6. 事务和并发控制 7. 扩展和插件 8. 跨平台和多语言支持 9. 高可用性和扩展性 常用场景 安装 Linux apt安装 下载安装包安装 客…

Linux之信号量

目录 信号量 信号量相关接口 创建信号量 初始化信号量 等待信号量,P操作 发布信号量,V操作 销毁信号量 基于信号量的环形队列下的生产者和消费者模型 环形队列 代码实现 上期我们学习了线程同步的概念,掌握了基于阻塞队列的生产…

Redis--高可用(主从复制、哨兵模式、分片集群)

高可用(主从复制、哨兵模式、分片集群) 高可用性Redis如何实现高可用架构?主从复制原理1. 全量同步2. 命令传播3. 增量同步 Redis Sentinel(哨兵模式)为什么要有哨兵模式?哨兵机制是如何工作的?…

常用的数据结构API概览

List ArrayList 1、在初始化一个ArrayList的时候&#xff0c;如果我想同时set一些值 比如存放int[ ] List<int[]> list new ArrayList(Arrays.asList(new int[]{intervals[0][0],intervals[0][1]}));//或者int[] temp new int[]{intervals[0][0],intervals[0][1]}…

wordpress右侧浮动咨询台插件

简洁实用&#xff0c;操作方便&#xff0c;没有复杂的设置。 下载、安装、启用&#xff0c;即可使用。 wordpress在线客服插件-CS4&#xff0c;该插件适用于简站主题与精智主题。 下载 https://www.jianzhanpress.com/?p4622

Spring MVC实战指南:构建高效Web应用的架构与技巧(三)

响应数据和结果视图(7种) 返回值分类 创建web.xml&#xff08;spring、过滤器解决乱码、配置控制器dispatcherServlet、加载springmvc.xml文件、配置启动加载&#xff09;创建springmvc.xml文件 <!--配置了内容&#xff0c;启动Tomcat服务器的时候&#xff0c;就会被加载--…

使用LINUX的dd命令制作自己的img镜像

为了避免重复安装同一镜像&#xff0c;配置环境&#xff0c;首先我准备一个正常使用的完整系统。 使用Gparted软件先将母盘&#xff08;如U盘&#xff0c;TF卡&#xff09;分区调整为只有数据的大小。如&#xff1a;60G的TF卡&#xff0c;只用了3.5G&#xff0c;将未使用的空间…

doris:基于 Arrow Flight SQL 的高速数据传输链路

Doris 基于 Arrow Flight SQL 协议实现了高速数据链路&#xff0c;支持多种语言使用 SQL 从 Doris 高速读取大批量数据。 用途​ 从 Doris 加载大批量数据到其他组件&#xff0c;如 Python/Java/Spark/Flink&#xff0c;可以使用基于 Arrow Flight SQL 的 ADBC/JDBC 替代过去…

Gitee图形界面上传(详细步骤)

目录 1.软件安装 2.安装顺序 3.创建仓库 4.克隆远程仓库到本地电脑 提交代码的三板斧 1.软件安装 Git - Downloads (git-scm.com) Download – TortoiseGit – Windows Shell Interface to Git 2.安装顺序 1. 首先安装git-2.33.1-64-bit.exe&#xff0c;顺序不能搞错2. …

用公网服务代理到本地电脑笔记

参考&#xff1a; 利用frp 穿透到内网的http/https网站&#xff0c;实现对外开放&#xff08;这篇博客有点老&#xff0c;需要改动&#xff0c;不能照抄&#xff09;&#xff1a;https://www.cnblogs.com/hahaha111122222/p/8509150.html frp内网穿透(windows和服务器)&#xf…