golang rpc demo
RPC工作流程图
- 1.调用客户端句柄;执行传送参数
- 2.调用本地系统内核发送网络消息
- 3.消息传送到远程主机
- 4.服务器句柄得到消息并取得参数
- 5.执行远程过程
- 6.执行的过程将结果返回服务器句柄
- 7.服务器句柄返回结果,调用远程系统内核
- 8.消息传回本地主机
- 9.客户句柄由内核接收消息
- 10.客户接收句柄返回的数据
Go语言提供对RPC的支持:HTTP、TCP、JSPNRPC
,但是在Go
中RPC
是独一无二的,它采用了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, ")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相关推荐
- golang 并发demo 写入 redis
原文链接:golang 并发demo 写入 redis 源代码: package mainimport ("fmt""runtime""strconv ...
- RPC Demo(二) 基于 Zookeeper 的服务发现
RPC Demo(二) 基于 Zookeeper 的服务发现 简介 基于上篇的:RPC Demo(一) Netty RPC Demo 实现 第二部分来实现使用Zookeeper作为服务 ...
- Netty RPC Demo 实现
Netty RPC Demo 实现 简介 一个 RPC 框架 Demo 的简单实现(业务场景中还没用过RPC,但Dome应该还是有那个意思的) 完整的项目工程地址:RPC-Demo 工 ...
- Golang rpc:service/method request ill-formed错误
Golang rpc:service/method request ill-formed错误 在学习golang中rpc的时候遇到了这个错误,无法成功远程调用方法 这里是我想要远程调用的函数的签名部分 ...
- golang grpc demo
1.grpm 安装: git clone https://github.com/grpc/grpc-go.git $GOPATH/src/google.golang.org/grpc 2.proto, ...
- 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 ...
- gslang——原生golang/RPC描述语言简介
gslang背景知识 gslang是采用go语言编写的RPC描述语言,最初它被用来描述gscluster网络服之间的接口调用契约:而gscluster项目本身是我在tap4fun时开发的一个游戏 服务 ...
- ASRT golang SDK demo (golang 语言识别客户端demo)
demo整合了AI柠檬的SDK例程和golang 调用winmm.dll 实现windows系统下录音的例程:该例程提供了windows系统下录音到访问ASRT 服务器实现语音识别的思路. 注:gol ...
- golang mysql demo
Go操作Mysql数据库 使用Go操作MySQL等数据库,一般有两种方式:一是使用database/sql接口,直接在代码里硬编码sql语句:二是使用gorm,即对象关系映射的方式在代码里抽象的操作数 ...
最新文章
- win7 win10 win8系统文件夹重命名要刷新下文件名才会改变,桌面也不会自动刷新...
- module 'yaml' has no attribute 'FullLoader'
- java两个很大的数相加_两个超大数的相加
- React开发(236):dva概念1数据流向
- Docker : 数据卷(创建、挂载、查看、删除)
- MySQL Data Manipulation Statements
- 利用Onionshare 共享匿名文件
- 虚拟机同步器用易语言怎么写_安装虚拟机的好处或用处是什么/如有效地防止病毒...
- Ollydbg 1.10's plugin LsMem2CAry.dll
- 子网掩码及其与IP地址、网关的关系
- 阿拉伯数字转换成大写的数字
- 《 C语言程序设计(第2版)》 读书笔记
- python中的data解释_python中的data解释_python unicodedata用法
- mgre的全连和星型拓扑实验
- unity 下载图片使用并保存在本地
- 美国计算机加音乐专业,史上最全的美国大学音乐学院专业解析
- Python基本手册
- [Oracle] 书写历史的甲骨文――ORACLE公司传奇
- 【解决方案】TSINGSEE青犀视频RTMP推流网关+公有云直播远程监控系统,让“小饭桌”变成“放心桌”
- 人物角色(Persona)
热门文章
- python做游戏代码_利用Python基础代码语句,实现2G时代文字小游戏,世界如此简单!...
- java分别使用for循环语句计算n!_实验三:分别用for、while和do-while循环语句以及递归方法计算n!,并输出算式...
- 计算 java_两种计算Java对象大小的方法(转)
- 黑苹果挂载不了分区_让黑苹果变得更完美——BCM94532HMB无线蓝牙接力完美驱动!...
- python调用java方法_python加载和使用java的类的方法
- 玄元剑仙服务器列表为空,玄元剑仙3月11日维护更新公告
- 【阿里云OSS】访问控制
- WebMvcConfigurer
- excel打开空白_PDF转成Excel后,打开表格却是空白的?
- iphone退款申请教程_如何下载下架的APP?买错应用怎么退款?学会这几招iPhone更好用...