Golang 语言使用标准库 net/rpc/jsonrpc 包跨语言远程调用

简介: Golang 语言使用标准库 net/rpc/jsonrpc 包跨语言远程调用

01

介绍


Go 语言标准库 net/rpc 默认采用 encoding/gob 包编解码传输数据,gob 编解码方式仅适用于 Go 应用,如果需要跨语言远程调用,可以指定支持跨语言的其他编解码方式,比如 protobuf,或使用 net/rpc 的子包 net/rpc/jsonrpc,它支持JSON-RPC 1.0,通过 json 格式传输数据。


02

Go 语言 net/rpc/jsonrpc 标准库


jsonrpc 是基于 TCP 协议,不支持 HTTP 协议。jsonrpc 采用 JSON 编解码传输数据,而不是采用 gob 编解码方式。其他方面和 net/rpc 一样,可以通过阅读「Go 使用标准库 net/rpc 包」了解相关内容。


03

net/rpc/jsonrpc 怎么使用?


通过一个简单的示例,我们演示 Go 语言标准库 net/rpc/jsonrpc 的使用方法。


RPC 方法:

服务提供方定义一个可导出的 User 对象和一个符合 RPC 方法定义规则的 Register 方法。


640.png

服务提供方:

服务提供方注册 user 对象,创建基于 TCP 协议的运行在单个连接上的 JOSN-RPC 服务器。


640.png


服务调用方:

服务提供方注册 user 对象后,服务调用方就可以调用 user 对象的 user.Register 方法。调用方法之前,先连接一个指定网络协议和地址的 JSON-RPC 服务,返回一个新创建的客户端。然后,使用客户端调用 user.Register 方法,传递参数,等待返回结果。


640.png


04

总结


本文先介绍了 Go 语言标准库 net/rpc/jsonrpc 的编解码方式和功能。即使用 json 编解码传输数据,提供跨语言远程调用的功能。然后,通过一个简单示例来演示了 net/rpc/jsonrpc 的使用方法。





目录
相关文章
|
5月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
321 2
|
Go
Golang语言之gRPC程序设计示例
这篇文章是关于Golang语言使用gRPC进行程序设计的详细教程,涵盖了RPC协议的介绍、gRPC环境的搭建、Protocol Buffers的使用、gRPC服务的编写和通信示例。
637 3
Golang语言之gRPC程序设计示例
|
开发框架 .NET 测试技术
了解 .NET 9 中的新 Microsoft.AspNetCore.OpenApi 包,并将其与 NSwag 和 Swashbuckle.AspNetCore 进行比较。
本文介绍了 `.NET 9` 中新推出的 `Microsoft.AspNetCore.OpenApi` 包,该包旨在为 `ASP.NET Core` 应用程序生成 `OpenAPI` 文档。文章对比了 `NSwag` 和 `Swashbuckle.AspNetCore` 两大现有库,探讨了新包的优势和不足,特别是在性能和功能方面。尽管新包在某些方面尚不及成熟库完善,但其对原生 `AoT` 编译的支持和未来的扩展潜力使其成为一个值得考虑的选择。文章还提供了详细的性能测试数据和优化建议,适合对 `OpenAPI` 文档生成感兴趣的开发者阅读。
867 4
了解 .NET 9 中的新 Microsoft.AspNetCore.OpenApi 包,并将其与 NSwag 和 Swashbuckle.AspNetCore 进行比较。
|
Prometheus Cloud Native Go
Golang语言之Prometheus的日志模块使用案例
这篇文章是关于如何在Golang语言项目中使用Prometheus的日志模块的案例,包括源代码编写、编译和测试步骤。
327 4
Golang语言之Prometheus的日志模块使用案例
|
前端开发 中间件 Go
实践Golang语言N层应用架构
【10月更文挑战第2天】本文介绍了如何在Go语言中使用Gin框架实现N层体系结构,借鉴了J2EE平台的多层分布式应用程序模型。文章首先概述了N层体系结构的基本概念,接着详细列出了Go语言中对应的构件名称,包括前端框架(如Vue.js、React)、Gin的处理函数和中间件、依赖注入和配置管理、会话管理和ORM库(如gorm或ent)。最后,提供了具体的代码示例,展示了如何实现HTTP请求处理、会话管理和数据库操作。
304 1
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
564 5
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
610 0
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
331 7
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
335 0
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
288 0

推荐镜像

更多