Go 中使用 RPC
2017-03-23 11:04
495 查看
做 MIT-6.824 的 Lab 1 MapReduce 任务,Master 和 Worker 之间通信使用 RPC 调用。写一个 Demo 熟悉一下。
2、Go 中的 methods 是一个包含了接受者的函数。
/detail/2573043205.html
https://golang.org/pkg/net/rpc/
示例
package main import "net" import "net/rpc" import "net/http" import "errors" import "log" import "fmt" type Args struct { A, B int } type Qutient struct { Quo, Rem int } // 别名 type Arith int func (t *Arith) Multiply(args *Args, reply *int) error { *reply = args.A * args.B return nil } func (t* Arith) Divide(args *Args, quo *Qutient) error { if args.B == 0 { return errors.New("divide by zero") } quo.Quo = args.A / args.B quo.Rem = args.A % args.B return nil } func main() { arith := new(Arith) rpc.Register(arith) rpc.HandleHTTP() l, e := net.Listen("tcp", ":1234") if e != nil { log.Fatal("listen error:", e) } go http.Serve(l, nil) // 调用 client, err := rpc.DialHTTP("tcp", "127.0.0.1" + ":1234") if err != nil { log.Fatal("dialing:", err) } args := &Args{7,8} var reply int err2 := client.Call("Arith.Multiply", args, &reply) if err2 != nil { log.Fatal("Arith error:", err2) } fmt.Printf("Arith: %d*%d=%d \n", args.A, args.B, reply) }
注意的地方
1、Go 语言里可以使用 type 关键字来把一个类型来转换成另外一个类型而保持数据的本质不变。代码中的 Arith 是另外一种类型,量纲上是数字。2、Go 中的 methods 是一个包含了接受者的函数。
参考
http://nil.csail.mit.edu/6.824/2015/labs/lab-1.html/detail/2573043205.html
https://golang.org/pkg/net/rpc/
相关文章推荐
- Go实战--go中使用rpc(The way to go)
- Go实战--golang中使用gRPC和Protobuf实现高性能api(golang/protobuf、google.golang.org/grpc)
- Go实战--Gorilla web toolkit使用之gorilla/rpc(gorilla/rpc/json)
- go-grpc安装使用
- go grpc安装使用教程
- 使用thrift作为go和C++中间rpc及问题
- go语言net包rpc远程调用的使用
- ATC:go Thrift RPC 使用 (连接池)
- go-grpc 使用
- go语言net包rpc远程调用的使用示例
- Dubbo实现RPC调用使用入门
- 使用GO将SQL语句重复执行多次
- Go语言_RPC_Go语言的RPC
- SQL SERVER GO命令循环使用实例
- go结构体的学习和使用
- 在go modules里使用go get进行包管理
- Go语言 如果查询度量内存和GC使用状况
- Zookeeper Golang客户端:go-zookeeper的基本使用
- 面向开发人员的区块链链代码深入研究:使用 Go 编写智能合约
- java程序员10分钟可上手的golang框架golang实战使用gin+xorm搭建go语言web框架restgo