Go的RPC实现基于net/rpc包,需定义导出方法,如Add接收Args结构并返回int指针和error;服务端注册Calculator实例并监听TCP端口;客户端通过Dial连接后调用Calculator.Add方法传参获取结果。

在Golang中实现RPC(远程过程调用)客户端和服务端非常简单,标准库net/rpc提供了完整的支持。下面以一个基础示例说明如何使用Go的RPC机制进行通信。
RPC通信需要双方约定好方法签名和参数结构。我们先定义一个简单的服务,用于计算两个数的和。
创建一个公共的数据结构和方法定义,通常放在独立的包中,但为了演示方便,这里直接在主包中定义:
注意:RPC方法必须满足以下条件:例如:
立即学习“go语言免费学习笔记(深入)”;
<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>服务端注册服务并监听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>客户端连接服务端并调用远程方法。
<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>分别运行服务端和客户端:
go run server.go
go run client.go
确保服务端已在运行,且网络可通。如果跨机器,需调整IP地址。
基本上就这些。Go的net/rpc设计简洁,适合内部服务通信。但要注意它默认使用Go特有的编码(gob),不支持跨语言。如需JSON或HTTP支持,可考虑net/rpc/jsonrpc或gRPC。不过对于纯Go环境,标准RPC足够高效实用。
以上就是如何在Golang中实现RPC客户端和服务端的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号