全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

如何使用Golang实现RPC序列化与反序列化_Golang RPC数据编码与解码方法

net/rpc 默认用 gob,不支持跨语言;换 JSON 需用 jsonrpc 包并调用 jsonrpc.ServeConn;换 protobuf 应直接用 gRPC;自定义 ServerCodec 必须处理分帧、Header 解析和错误传播。

Go 标准库的 net/rpc 默认使用 gob 编码,不支持跨语言、不兼容 JSON 或 Protocol Buffers——如果你需要自定义序列化(比如用 jsonprotobuf),必须绕过默认机制,自己接管编解码流程。

为什么不能直接替换 rpc.Server 的编解码器?

标准 rpc.Serverrpc.Client 将编码/解码深度耦合在 rpc.Server.ServeCodecrpc.NewClientWithCodec 中,底层依赖 rpc.ServerCodec 接口。它要求你同时实现 ReadRequestHeader/ReadRequestBodyWriteResponse 等方法,不能只换一个序列化格式。

常见错误是试图“简单替换 gobjson”,结果发现请求头读不出来、响应乱序、或连接直接断开——因为 json 没有 gob 那样的类型元信息和流式分帧能力。

  • gob 自带类型描述、支持指针/接口/循环引用,且天然适配 Go 运行时;json 是纯文本、无类型、需显式结构体标签
  • RPC 协议不是“发一串 JSON 就完事”,它需要严格区分 header(含方法名、序列号)和 body(参数),而 json 不提供内置分界机制
  • 标准 rpc/jsonrpc 包只是对 gob 编解码逻辑的重写,并非“用 encoding/json 替代 gob”——它仍遵循 RPC 帧格式约定

如何用 json 实现兼容标准 rpc.Client 的服务端?

使用 net/rpc/jsonrpc 是最轻量、最兼容的方式:它复用了标准 rpc 的注册与调用逻辑,仅替换底层编解码器。客户端无需改代码,只要把 rpc.NewClient 换成 jsonrpc.NewClient 即可。

服务端启动示例:

package main

import ( "net" "net/rpc" "net/rpc/jsonrpc" )

type Args struct{ A, B int } type Quotient struct{ Quo, Rem int }

type Arith int

func (t Arith) Multiply(args Args, reply int) error { reply = args.A * args.B return nil }

func main() { rpc.Register(new(Arith)) listener, := net.Listen("tcp", ":1234") for { conn, := listener.Accept() go jsonrpc.ServeConn(conn) // ← 关键:用 jsonrpc.ServeConn 替代 rpc.ServeConn } }

注意点:

  • 必须用 jsonrpc.ServeConn 启动连接,不能用 rpc.ServeConn
  • 客户端必须用 jsonrpc.NewClientjsonrpc.Dial,否则会因帧格式不匹配而报 invalid character 错误
  • 结构体字段必须首字母大写(导出),且建议加 json: 标签以控制 key 名

如何用 protobuf + gRPC 替代原生 net/rpc

如果你真正想要的是高性能、跨语言、带 IDL 的 RPC,不要硬改 net/rpc,直接用 gRPC-Go。它本质是基于 HTTP/2 的二进制 RPC 框架,protobuf 是其默认序列化协议,天然支持 streaming、拦截器、超时、认证等。

关键区别:

  • net/rpc 是 TCP + 自定义二进制帧(gob)或 JSON 帧;gRPC 是 HTTP/2 + protobuf + gRPC-encoding(length-delimited)
  • gRPC 要求先写 .proto 文件生成 Go 代码;net/rpc 直接注册结构体和方法
  • 没有 gRPC 服务端,protobuf 只是序列化工具——你仍需自己设计传输层(比如用 net.Conn + 自定义分帧),这极易出错

所以,除非你有强约束(如必须复用现有 net/rpc 客户端、不能引入新协议栈),否则别尝试“给 net/rpc 换 protobuf 底层”。真要这么做,得完整实现 rpc.ServerCodec,包括:ReadRequestHeader 解析 method/service/seq,ReadRequestBodyproto.Unmarshal,还要处理 length-prefix framing——这已接近重写整个 RPC 栈。

自定义编解码器时最容易忽略的细节

当你实现自己的 rpc.ServerCodec,以下三点几乎必踩坑:

  • TCP 是字节流,没有消息边界——必须自己加长度前缀(如 4 字节 uint32 表示后续 payload 长度),否则 ReadRequestBody 会阻塞或读错数据
  • ReadRequestHeader 必须严格按 RPC 协议解析出 ServiceMethod 字符串(格式为 "Service.Method")和 Seq(请求序号),漏掉任一字段会导致客户端永远收不到响应
  • WriteResponseerr 参数不能忽略:如果业务逻辑返回 error,必须写入 response body 并设置 ErrorResponse 标志,否则客户端 Call 会卡死或 panic

真正稳定的自定义方案,往往不是从零写 ServerCodec,而是基于 gRPCCodec 接口或 go-microcodec 插件机制——它们已封装好分帧、上下文、错误传播等细节。


# js  # json  # go  # golang  # 编码  # 字节  # 工具  #   # ai  # stream  # 区别  # 标准库  # 为什么  # 封装  # Error  # 字符串  # 结构体  # 无类型  # 循环  # 指针  # 接口  # Length  # http  # rpc  # 自定义  # 客户端  # 如果你  # 序列化  # 服务端  # 重写  # 不支持  # 编解码器  # 如何用  # 如用 


相关文章: 如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  子杰智能建站系统|零代码开发与AI生成SEO优化指南  XML的“混合内容”是什么 怎么用DTD或XSD定义  ,巨量百应是干嘛的?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  如何彻底删除建站之星生成的Banner?  北京专业网站制作设计师招聘,北京白云观官方网站?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  宝塔新建站点为何无法访问?如何排查?  建站之星2.7模板:企业网站建设与h5定制设计专题  广州美橙建站如何快速搭建多端合一网站?  为什么Go需要go mod文件_Go go mod文件作用说明  招商网站制作流程,网站招商广告语?  制作电商网页,电商供应链怎么做?  ui设计制作网站有哪些,手机UI设计网址吗?  建站主机服务器选购指南:轻量应用与VPS配置解析  建站DNS解析失败?如何正确配置域名服务器?  *服务器网站为何频现安全漏洞?  如何通过远程VPS快速搭建个人网站?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  建设网站制作价格,怎样建立自己的公司网站?  C#怎么创建控制台应用 C# Console App项目创建方法  相册网站制作软件,图片上的网址怎么复制?  大连网站制作公司哪家好一点,大连买房网站哪个好?  h5在线制作网站电脑版下载,h5网页制作软件?  如何自定义建站之星模板颜色并下载新样式?  建站上市公司网站建设方案与SEO优化服务定制指南  如何在香港服务器上快速搭建免备案网站?  Python路径拼接规范_跨平台处理说明【指导】  如何做网站制作流程,*游戏网站怎么搭建?  Python如何创建带属性的XML节点  如何选择高效可靠的多用户建站源码资源?  建站之星CMS五站合一模板配置与SEO优化指南  网站微信制作软件,如何制作微信链接?  小建面朝正北,A点实际方位是否存在偏差?  英语简历制作免费网站推荐,如何将简历翻译成英文?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  制作国外网站的软件,国外有哪些比较优质的网站推荐?  ,交易猫的商品怎么发布到网站上去?  如何快速搭建FTP站点实现文件共享?  如何在万网ECS上快速搭建专属网站?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  全景视频制作网站有哪些,全景图怎么做成网页?  如何自定义建站之星网站的导航菜单样式?  宝塔Windows建站如何避免显示默认IIS页面?  如何在VPS电脑上快速搭建网站?  如何通过建站之星自助学习解决操作问题?  宿州网站制作公司兴策,安徽省低保查询网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。