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 main
    
    import (
    "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.B
    fmt.Println("这个方法执行了啊---嘿嘿--- Multiply ", reply) return nil
    } func (t *Arith) Divide(args *Args, quo *Quotient) error {
    if args.B == {
    return errors.New("divide by zero")
    } quo.Quo = args.A / args.B
    quo.Rem = args.A % args.B
    fmt.Println("这个方法执行了啊---嘿嘿--- Divide quo==", quo) return nil
    } func main() {
    rpcDemo()
    }

    服务端运行:go run server.go

  • 客户端的代码
    package main
    
    import (
    "flag"
    "fmt"
    "log"
    "net/rpc"
    "strconv"
    ) type ArgsTwo struct {
    A, B int
    } type QuotientTwo struct {
    Quo, Rem int
    } type Conf struct {
    serverAddress string
    i1 string
    i2 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", "", "")
    flag.StringVar(&conf.i2, "i2", "", "")
    } 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:
    Arith 乘法: *=
    Arith 除法取整数: /= 余数
    [root@wangjq rpc]#
    [root@wangjq rpc]# ./client --address 127.0.0.1: -i1 -i2
    severAddress = 127.0.0.1:
    Arith 乘法: *=
    Arith 除法取整数: /= 余数

golang rpc demo的更多相关文章

  1. win7环境下,golang thrift demo代码编译不通过

    用官方的教程代码:http://thrift.apache.org/tutorial/go 用网友提供的代码:Golang RPC 之 Thrift 都出现如下情况 状况1: 编辑器中就会提醒 Can ...

  2. Windows RPC Demo实现

    Windows RPC Demo实现 本文参考并整理以下相关文章 1. <远程过程调用> -百度百科 2. <RPC 编程> -http://www.ibm.com/devel ...

  3. Golang RPC 性能测试

    Golang RPC 性能测试 | KDF5000 http://kdf5000.com/2017/03/28/Golang-RPC-性能测试/

  4. golang RPC通信读写超时设置

    golang RPC通信中,有时候就怕读写hang住. 那是否可以设置读写超时呢? 1.方案一: 设置连接的读写超时 1.1 client RPC通信基于底层网络通信,可以通过设置connection ...

  5. golang 并发demo 写入 redis

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

  6. golang grpc demo

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

  7. golang rpc 简单范例

    RPC(Remote Procedure Call Protocol)--远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议. 它的工作流程如下图:   go ...

  8. golang rpc介绍

    rpc包提供了通过网络或其他I/O连接对一个对象的导出方法的访问.服务端注册一个对象,使它作为一个服务被暴露,服务的名字是该对象的类型名.注册之后,对象的导出方法就可以被远程访问.服务端可以注册多个不 ...

  9. golang ctrie demo

    下载ctrie: go get -t github.com/Workiva/go-datastructures/trie/ctrie 测试demo1: package main import ( &q ...

随机推荐

  1. 《Head First 设计模式》:抽象工厂模式

    正文 一.定义 抽象工厂模式提供一个接口,用于创建相关或依赖对象的家族,而不需要明确指定具体类. 要点: 抽象工厂允许客户使用抽象的接口来创建一组相关的产品,而不需要知道实际产品的具体产品是什么.这样 ...

  2. 从0到1:开启CAN通信学习(一)

    1  初识CAN通信 说起CAN通信,可能很多人都比较陌生,但实际上我们却一直在和它打交道.随着家用汽车的普及,我们开车过程中的每次刹车.每次踩油门,甚至每次的开车门.开车窗,其实都是CAN通信的应用 ...

  3. PHP uasort() 函数

    ------------恢复内容开始------------ 实例 使用用户自定义的比较函数对数组 $arr 中的元素按键值进行排序: <?phpfunction my_sort($a,$b){ ...

  4. windows:shellcode 远程线程hook/注入(四)

    https://www.cnblogs.com/theseventhson/p/13236421.html  这里介绍了利用回调函数执行shellcode的基本原理:这里介绍另外一种利用回调执行she ...

  5. 基于IDEA 代码提交Git

    基于IDEA 代码提交Git 步骤 1 创建一个项目 2 点击 VCS --> Import init Version Control --> Create Git Repository ...

  6. ios 继承UITableViewController,更改tableview样式

    // 继承UITableViewController,更改tableview样式 - (instancetype)initWithStyle:(UITableViewStyle)style { ret ...

  7. cryptopp使用Qt mingw编译,以及海思平台交叉编译

    编译工程生成,使用qmake生成qt工程文件(海思平台时,要用海思平台的qmake),将 TEMPLATE = app 修改为: TEMPLATE = lib 添加如下: win32:LIBS += ...

  8. 001_解析go语言中的闭包

    go语言中的闭包,是大家学习go语言的一个大难点,笔者在学习时候也是痛苦不堪,在来回对比了其它语言的用法,并且查阅了很多网上的文章,终于对闭包有了一个较为清晰的认识,以下就是关于闭包的解析 首先看一个 ...

  9. Window Server2012 修改远程桌面端口号

    Win + R 输入 regedit 打开注册表编辑器 在注册表编辑器中找到 PortNumber 双击 PortNumber,选择10进制,修改想要的端口号 把修改的端口添加为入站规则 重启 Rem ...

  10. Kubernetes 使用arthas进行调试

    环境 因为k8s中是最基本的jre,网上说缺少tools.jar,但是补充了以后还是不行,最后还是将整个jdk给移到容器中的. jre中执行: /home # /opt/jre/bin/java -j ...