首页 > 后端开发 > Golang > 正文

Golang RPC多服务间通信示例

P粉602998670
发布: 2025-10-03 14:15:02
原创
618人浏览过
先定义共享结构体,再分别实现UserService和OrderService的RPC通信。UserService监听8081提供用户查询,OrderService监听8082并调用UserService获取用户信息,客户端通过调用OrderService完成订单与用户数据聚合。

golang rpc多服务间通信示例

在Golang中实现多个服务间的RPC通信,可以通过标准库net/rpc轻松完成。下面是一个清晰的多服务间RPC通信示例,包含两个独立的服务(UserService和OrderService),它们通过RPC进行解耦通信。

1. 定义共享的数据结构与接口

为了支持跨服务调用,先定义共用的请求和响应结构体。这些结构可以放在一个独立的包中(如common),或直接复制到各服务中。

// common/types.go
package common

type User struct {
    ID   int
    Name string
}

type Order struct {
    ID       int
    UserID   int
    Product  string
}
登录后复制

2. UserService 提供用户查询功能

UserService对外暴露一个RPC方法GetUser,根据ID返回用户信息。

// user_service/server.go
package main

import (
    "common"
    "log"
    "net"
    "net/rpc"
)

type UserService struct{}

func (s *UserService) GetUser(uid int, user *common.User) error {
    // 模拟数据库查找
    userData := map[int]common.User{
        1: {ID: 1, Name: "Alice"},
        2: {ID: 2, Name: "Bob"},
    }
    *user = userData[uid]
    return nil
}

func main() {
    rpc.Register(new(UserService))
    listener, err := net.Listen("tcp", ":8081")
    if err != nil {
        log.Fatal("Listen error:", err)
    }
    defer listener.Close()
    log.Println("UserService 启动在 :8081")
    for {
        conn, _ := listener.Accept()
        go rpc.ServeConn(conn)
    }
}
登录后复制

3. OrderService 调用 UserService 获取用户信息

OrderService在返回订单详情时,需要通过RPC向UserService查询关联的用户信息。

立即学习go语言免费学习笔记(深入)”;

美间AI
美间AI

美间AI:让设计更简单

美间AI 45
查看详情 美间AI
// order_service/server.go
package main

import (
    "common"
    "log"
    "net"
    "net/rpc"
)

type OrderService struct{}

func (s *OrderService) GetOrder(oid int, reply *common.Order) error {
    // 模拟订单数据
    orderData := map[int]common.Order{
        101: {ID: 101, UserID: 1, Product: "Laptop"},
        102: {ID: 102, UserID: 2, Product: "Phone"},
    }
    *reply = orderData[oid]

    // 调用 UserService 获取用户信息
    client, err := rpc.Dial("tcp", "127.0.0.1:8081")
    if err != nil {
        log.Printf("无法连接 UserService: %v", err)
        return nil
    }
    defer client.Close()

    var user common.User
    err = client.Call("UserService.GetUser", reply.UserID, &user)
    if err != nil {
        log.Printf("调用 GetUser 失败: %v", err)
    } else {
        log.Printf("订单 %d 关联用户: %s", reply.ID, user.Name)
    }

    return nil
}

func main() {
    rpc.Register(new(OrderService))
    listener, err := net.Listen("tcp", ":8082")
    if err != nil {
        log.Fatal("Listen error:", err)
    }
    defer listener.Close()
    log.Println("OrderService 启动在 :8082")
    for {
        conn, _ := listener.Accept()
        go rpc.ServeConn(conn)
    }
}
登录后复制

4. 客户端调用 OrderService

客户端只需访问OrderService,它会自动联动UserService完成数据聚合。

// client/main.go
package main

import (
    "common"
    "log"
    "net/rpc"
)

func main() {
    client, err := rpc.Dial("tcp", "127.0.0.1:8082")
    if err != nil {
        log.Fatal("Dial error:", err)
    }
    defer client.Close()

    var order common.Order
    err = client.Call("OrderService.GetOrder", 101, &order)
    if err != nil {
        log.Fatal("Call error:", err)
    }

    log.Printf("获取订单: %+v", order)
}
登录后复制

运行顺序:

  • 先启动user_service(监听8081)
  • 再启动order_service(监听8082)
  • 最后运行client发起请求

输出示例:

OrderService 日志: 订单 101 关联用户: Alice
Client 日志: 获取订单: {ID:101 UserID:1 Product:Laptop}

基本上就这些。这种方式实现了服务间的低耦合通信,适合小型系统或学习用途。生产环境建议结合gRPC、服务注册发现等机制提升健壮性。不复杂但容易忽略细节,比如连接超时和错误处理。

以上就是Golang RPC多服务间通信示例的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号