RPC工作流程图

  • 1.调用客户端句柄;执行传送参数
  • 2.调用本地系统内核发送网络消息
  • 3.消息传送到远程主机
  • 4.服务器句柄得到消息并取得参数
  • 5.执行远程过程
  • 6.执行的过程将结果返回服务器句柄
  • 7.服务器句柄返回结果,调用远程系统内核
  • 8.消息传回本地主机
  • 9.客户句柄由内核接收消息
  • 10.客户接收句柄返回的数据

Go语言提供对RPC的支持:HTTP、TCP、JSPNRPC,但是在GoRPC是独一无二的,它采用了GoLang Gob编码,只能支持Go语言!

  • GoLang Gob:是Golang包自带的一个数据结构序列化的编码/解码工具。编码使用Encoder,解码使用Decoder。一种典型的应用场景就是RPC(remote procedure calls)。

HTTP RPC Demo

  • 服务端的代码

    package mainimport ("errors""fmt""net/http""net/rpc"
    )type Arith int func rpcDemo() {arith := new(Arith)fmt.Println("arith===", arith)rpc.Register(arith)//HandleHTTP将RPC消息的HTTP处理程序注册到Debug服务器//DEFAUTUPCPATH和Debug调试路径上的调试处理程序。//仍然需要调用http.Services(),通常是在GO语句中。
        rpc.HandleHTTP()err := http.ListenAndServe(":1234", nil)if err != nil {fmt.Println("err=====", err.Error())}
    }type Args struct {A, B int
    }type Quotient struct {Quo, Rem int
    }//函数必须是导出的(首字母大写)
    //必须有两个导出类型的参数,
    //第一个参数是接收的参数,第二个参数是返回给客户端的参数,第二个参数必须是指针类型的
    //函数还要有一个返回值error
    func (t *Arith) Multiply(args *Args, reply *int) error {*reply = args.A * args.Bfmt.Println("这个方法执行了啊---嘿嘿--- Multiply ", reply)return nil
    }func (t *Arith) Divide(args *Args, quo *Quotient) error {if args.B == 0 {return errors.New("divide by zero")}quo.Quo = args.A / args.Bquo.Rem = args.A % args.Bfmt.Println("这个方法执行了啊---嘿嘿--- Divide quo==", quo)return nil
    }func main() {rpcDemo()
    }

    服务端运行:go run server.go

  • 客户端的代码
    package mainimport ("flag""fmt""log""net/rpc""strconv"
    )type ArgsTwo struct {A, B int
    }type QuotientTwo struct {Quo, Rem int
    }type Conf struct {serverAddress stringi1            stringi2            string
    }var conf = Conf{}func SetConfiguration() {flag.StringVar(&conf.serverAddress, "address", "127.0.0.1:1234", "The address of the rpc")flag.StringVar(&conf.i1, "i1", "100", "100")flag.StringVar(&conf.i2, "i2", "2", "2")
    }func main() {SetConfiguration()flag.Parse()fmt.Println("severAddress = ", conf.serverAddress)// DelayHTTP在指定的网络地址连接到HTTP RPC服务器// 在默认HTTP RPC路径上监听。client, err := rpc.DialHTTP("tcp", conf.serverAddress)if err != nil {log.Fatal("发生错误了 在这里地方  DialHTTP", err)}i1_, _ := strconv.Atoi(conf.i1)i2_, _ := strconv.Atoi(conf.i2)args := ArgsTwo{A: i1_, B: i2_}var reply int//调用调用命名函数,等待它完成,并返回其错误状态。err = client.Call("Arith.Multiply", args, &reply)if err != nil {log.Fatal("Call Multiply  发生错误了哦   arith error:", err)}fmt.Printf("Arith 乘法: %d*%d=%d\n", args.A, args.B, reply)var quot QuotientTwo//调用调用命名函数,等待它完成,并返回其错误状态。err = client.Call("Arith.Divide", args, &quot)if err != nil {log.Fatal("arith error:", err)}fmt.Printf("Arith 除法取整数: %d/%d=%d 余数 %d\n", args.A, args.B, quot.Quo, quot.Rem)
    }

    客户端编译:go build client.go
    客户端运行:

  • [root@wangjq rpc]# ./client
    severAddress =  127.0.0.1:1234
    Arith 乘法: 100*2=200
    Arith 除法取整数: 100/2=50 余数 0
    [root@wangjq rpc]#
    [root@wangjq rpc]# ./client --address 127.0.0.1:1234 -i1 200 -i2 5
    severAddress =  127.0.0.1:1234
    Arith 乘法: 200*5=1000
    Arith 除法取整数: 200/5=40 余数 0

转载于:https://www.cnblogs.com/wangjq19920210/p/11571591.html

golang rpc demo相关推荐

  1. golang 并发demo 写入 redis

    原文链接:golang 并发demo 写入 redis 源代码: package mainimport ("fmt""runtime""strconv ...

  2. RPC Demo(二) 基于 Zookeeper 的服务发现

    RPC Demo(二) 基于 Zookeeper 的服务发现 简介     基于上篇的:RPC Demo(一) Netty RPC Demo 实现     第二部分来实现使用Zookeeper作为服务 ...

  3. Netty RPC Demo 实现

    Netty RPC Demo 实现 简介     一个 RPC 框架 Demo 的简单实现(业务场景中还没用过RPC,但Dome应该还是有那个意思的)     完整的项目工程地址:RPC-Demo 工 ...

  4. Golang rpc:service/method request ill-formed错误

    Golang rpc:service/method request ill-formed错误 在学习golang中rpc的时候遇到了这个错误,无法成功远程调用方法 这里是我想要远程调用的函数的签名部分 ...

  5. golang grpc demo

    1.grpm 安装: git clone https://github.com/grpc/grpc-go.git $GOPATH/src/google.golang.org/grpc 2.proto, ...

  6. golang rpc的两种调用方法

    golang的rpc有两种方法进行调用,一种是rpc例子中给的: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 2 ...

  7. gslang——原生golang/RPC描述语言简介

    gslang背景知识 gslang是采用go语言编写的RPC描述语言,最初它被用来描述gscluster网络服之间的接口调用契约:而gscluster项目本身是我在tap4fun时开发的一个游戏 服务 ...

  8. ASRT golang SDK demo (golang 语言识别客户端demo)

    demo整合了AI柠檬的SDK例程和golang 调用winmm.dll 实现windows系统下录音的例程:该例程提供了windows系统下录音到访问ASRT 服务器实现语音识别的思路. 注:gol ...

  9. golang mysql demo

    Go操作Mysql数据库 使用Go操作MySQL等数据库,一般有两种方式:一是使用database/sql接口,直接在代码里硬编码sql语句:二是使用gorm,即对象关系映射的方式在代码里抽象的操作数 ...

最新文章

  1. win7 win10 win8系统文件夹重命名要刷新下文件名才会改变,桌面也不会自动刷新...
  2. module 'yaml' has no attribute 'FullLoader'
  3. java两个很大的数相加_两个超大数的相加
  4. React开发(236):dva概念1数据流向
  5. Docker : 数据卷(创建、挂载、查看、删除)
  6. MySQL Data Manipulation Statements
  7. 利用Onionshare 共享匿名文件
  8. 虚拟机同步器用易语言怎么写_安装虚拟机的好处或用处是什么/如有效地防止病毒...
  9. Ollydbg 1.10's plugin LsMem2CAry.dll
  10. 子网掩码及其与IP地址、网关的关系
  11. 阿拉伯数字转换成大写的数字
  12. 《 C语言程序设计(第2版)》 读书笔记
  13. python中的data解释_python中的data解释_python unicodedata用法
  14. mgre的全连和星型拓扑实验
  15. unity 下载图片使用并保存在本地
  16. 美国计算机加音乐专业,史上最全的美国大学音乐学院专业解析
  17. Python基本手册
  18. [Oracle] 书写历史的甲骨文――ORACLE公司传奇
  19. 【解决方案】TSINGSEE青犀视频RTMP推流网关+公有云直播远程监控系统,让“小饭桌”变成“放心桌”
  20. 人物角色(Persona)

热门文章

  1. python做游戏代码_利用Python基础代码语句,实现2G时代文字小游戏,世界如此简单!...
  2. java分别使用for循环语句计算n!_实验三:分别用for、while和do-while循环语句以及递归方法计算n!,并输出算式...
  3. 计算 java_两种计算Java对象大小的方法(转)
  4. 黑苹果挂载不了分区_让黑苹果变得更完美——BCM94532HMB无线蓝牙接力完美驱动!...
  5. python调用java方法_python加载和使用java的类的方法
  6. 玄元剑仙服务器列表为空,玄元剑仙3月11日维护更新公告
  7. 【阿里云OSS】访问控制
  8. WebMvcConfigurer
  9. excel打开空白_PDF转成Excel后,打开表格却是空白的?
  10. iphone退款申请教程_如何下载下架的APP?买错应用怎么退款?学会这几招iPhone更好用...