快速了解Go+rpc

更多个人笔记:(仅供参考,非盈利)

gitee: https://gitee.com/harryhack/it_note

github: https://github.com/ZHLOVEYY/IT_note

文章目录

rpc基础概念

电商系统迅速发展后,有很多服务需要拆分,比如用户服务,商品服务,支付服务,订单服务,售后服务等 这些服务之间的相互调用就需要使用rpc

rpc框架:

服务注册中心:负责本地服务发布为远程服务,管理提供给消费者

消费者:通过远程代理对象调用远程服务

服务提供者:提供接口和相关服务

rpc框架可以跨语言,协议私密,传输效率也很高

GO的rpc应用

官方的net/rpc包对于方法有定义要求符合:

GO 复制代码
func (t *T) MethodName (argType T1, replyType *T2) error

其中T,T1,T2需要被encoding/gob包序列化(就是说不同编码器都需要适用)

第一个参数是调用者需要传递的参数

第二个是会以字符串方式返回的结果

简单编写

服务端: go run server.go运行就行

Go 复制代码
package main

import (
	"fmt"
	"net/http"
	"net/rpc"
)

type Args struct { //定义传入参数结构
	X, Y int
}

type Algorithm int //就是一个辅助的定义

func (t *Algorithm) Sum(args *Args, reply *int) error { //定义方法
	*reply = args.X + args.Y
	fmt.Println("Exec Sum ", reply)
	return nil
}

func main() {
	algorithm := new(Algorithm) //分配内存空间指针同时分配内存初始化为0值
	fmt.Println("algorithm start", algorithm)
	//注册服务
	rpc.Register(algorithm)
	rpc.HandleHTTP() //将 RPC 服务挂载到 HTTP 服务器
	err := http.ListenAndServe(":8081", nil)
	if err != nil {
		fmt.Println("err=====", err.Error())
	}
}
  • 定义传入的结构体参数
  • 为了调用方法,定义相关结构体承载
  • 实例化对应的承载结构体
  • 注册服务,并注册到HTTP上
  • 启动端口监听

客户端: 终端开启运行 go run xxx.go 1 2 (后面的1和2是制定的参数传入)

go 复制代码
package main

import (
	"fmt"
	"log"
	"net/rpc"
	"os"
	"strconv"
)

type Args struct { //定义传入参数结构
	X, Y int
}

type Algorithm int  //就是一个辅助的定义

func (t *Algorithm) Sum(args *Args, reply *int) error {
	*reply = args.X + args.Y
	fmt.Println("Exec Sum ", reply)
	return nil
}


func main() {
	//连接服务器
	client, err := rpc.DialHTTP("tcp", "127.0.0.1:8081")
	if err != nil {
		log.Fatal("dailHTTP发生错误", err)
	}
	//获取第一个输入
	i1, _ := strconv.Atoi(os.Args[1])
	//获取第二个输入
	i2, _ := strconv.Atoi(os.Args[2])
	args := Args{i1, i2}
	var reply int
	//调用远程方法
	err = client.Call("Algorithm.Sum", args, &reply) //调用对应的方法
	if err!= nil {
		log.Fatal("调用远程方法发生错误", err)
	}
	fmt.Printf("Arith: %d+%d=%d\n", args.X, args.Y, reply)
}
  • 连接对应的服务
  • 输入,组成结构体
  • 通过Call 调用对应的方法并进行传递

json编写rpc

  • 标准 RPC:主要用于 Go 程序之间通信,用Gob进行二进制编码
  • JSON-RPC:适合跨语言通信(因为 JSON 是通用格式),用json进行编码
    jsonrpc更加通用,,二者的实际使用其实就是启动方式时函数调用上的区别,先不重复展开
相关推荐
码途漫谈7 小时前
Easy-Vibe开发篇阅读笔记(四)——前端开发之结合 Agent Skills 美化界面
人工智能·笔记·ai·开源·ai编程
九转成圣7 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
SmartRadio7 小时前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信
开发语言·网络·智能手机·esp32·长距离wifi
laowangpython8 小时前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫8 小时前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
_.Switch8 小时前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI8 小时前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
Brendan_0018 小时前
JavaScript的Stomp.over
开发语言·javascript·ecmascript
念2348 小时前
f5 shape分析
开发语言·javascript·ecmascript
苍穹之跃8 小时前
某量JS逆向
开发语言·javascript·ecmascript