Golang实现RPC客户端与服务端详解
时间:2025-11-09 23:01:38 171浏览 收藏
本文详细介绍了如何使用 Golang 的 `net/rpc` 包实现 RPC(远程过程调用)客户端和服务端。通过定义满足特定条件(导出、两个参数、返回值 error)的服务接口和数据结构,例如 `Add` 方法接收 `Args` 结构体并返回 `int` 指针和 `error`,即可搭建 RPC 服务。服务端需注册服务实例(如 `Calculator`)并监听 TCP 端口,而客户端则通过 `Dial` 函数连接服务端,并使用 `Call` 方法传递参数并获取远程方法的执行结果。文章提供完整的代码示例,包括服务端监听、客户端连接与调用,以及详细的运行步骤,帮助开发者快速掌握 Golang RPC 的使用,适用于纯 Go 环境下的高效服务通信。
Go的RPC实现基于net/rpc包,需定义导出方法,如Add接收Args结构并返回int指针和error;服务端注册Calculator实例并监听TCP端口;客户端通过Dial连接后调用Calculator.Add方法传参获取结果。

在Golang中实现RPC(远程过程调用)客户端和服务端非常简单,标准库net/rpc提供了完整的支持。下面以一个基础示例说明如何使用Go的RPC机制进行通信。
1. 定义服务接口和数据结构
RPC通信需要双方约定好方法签名和参数结构。我们先定义一个简单的服务,用于计算两个数的和。
创建一个公共的数据结构和方法定义,通常放在独立的包中,但为了演示方便,这里直接在主包中定义:
注意:RPC方法必须满足以下条件:- 方法是导出的(大写字母开头)
- 有两个参数,第一个是接收参数,第二个是返回结果(都是导出类型)
- 第二个参数是指针类型
- 返回值是error类型
例如:
<strong>type Args struct {
A, B int
}
type Calculator int
func (c *Calculator) Add(args Args, result *int) error {
*result = args.A + args.B
return nil
}</strong>
2. 启动RPC服务端
服务端注册服务并监听TCP端口。
<strong>package main
import (
"log"
"net"
"net/rpc"
)
func main() {
// 注册服务实例
calc := new(Calculator)
rpc.Register(calc)
// 监听端口
listener, err := net.Listen("tcp", ":1234")
if err != nil {
log.Fatal("监听端口失败:", err)
}
defer listener.Close()
log.Println("RPC服务已启动,监听端口: 1234")
for {
conn, err := listener.Accept()
if err != nil {
continue
}
go rpc.ServeConn(conn)
}
}</strong>
3. 编写RPC客户端
客户端连接服务端并调用远程方法。
<strong>package main
import (
"fmt"
"log"
"net/rpc"
)
func main() {
// 连接服务端
client, err := rpc.Dial("tcp", "localhost:1234")
if err != nil {
log.Fatal("连接失败:", err)
}
defer client.Close()
// 准备参数和接收结果
args := Args{A: 5, B: 10}
var reply int
// 调用远程方法
err = client.Call("Calculator.Add", args, &reply)
if err != nil {
log.Fatal("调用失败:", err)
}
fmt.Printf("结果: %d\n", reply) // 输出: 结果: 15
}</strong>
4. 运行步骤
分别运行服务端和客户端:
- 先启动服务端程序:
go run server.go - 再运行客户端程序:
go run client.go - 客户端将输出计算结果
确保服务端已在运行,且网络可通。如果跨机器,需调整IP地址。
基本上就这些。Go的net/rpc设计简洁,适合内部服务通信。但要注意它默认使用Go特有的编码(gob),不支持跨语言。如需JSON或HTTP支持,可考虑net/rpc/jsonrpc或gRPC。不过对于纯Go环境,标准RPC足够高效实用。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Golang实现RPC客户端与服务端详解》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
-
128 收藏
-
252 收藏
-
184 收藏
-
299 收藏
-
213 收藏
-
236 收藏
-
146 收藏
-
359 收藏
-
230 收藏
-
158 收藏
-
215 收藏
-
275 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习