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 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, ")
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的更多相关文章
- win7环境下,golang thrift demo代码编译不通过
用官方的教程代码:http://thrift.apache.org/tutorial/go 用网友提供的代码:Golang RPC 之 Thrift 都出现如下情况 状况1: 编辑器中就会提醒 Can ...
- Windows RPC Demo实现
Windows RPC Demo实现 本文参考并整理以下相关文章 1. <远程过程调用> -百度百科 2. <RPC 编程> -http://www.ibm.com/devel ...
- Golang RPC 性能测试
Golang RPC 性能测试 | KDF5000 http://kdf5000.com/2017/03/28/Golang-RPC-性能测试/
- golang RPC通信读写超时设置
golang RPC通信中,有时候就怕读写hang住. 那是否可以设置读写超时呢? 1.方案一: 设置连接的读写超时 1.1 client RPC通信基于底层网络通信,可以通过设置connection ...
- golang 并发demo 写入 redis
原文链接:golang 并发demo 写入 redis 源代码: package main import ( "fmt" "runtime" "str ...
- golang grpc demo
1.grpm 安装: git clone https://github.com/grpc/grpc-go.git $GOPATH/src/google.golang.org/grpc 2.proto, ...
- golang rpc 简单范例
RPC(Remote Procedure Call Protocol)--远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议. 它的工作流程如下图: go ...
- golang rpc介绍
rpc包提供了通过网络或其他I/O连接对一个对象的导出方法的访问.服务端注册一个对象,使它作为一个服务被暴露,服务的名字是该对象的类型名.注册之后,对象的导出方法就可以被远程访问.服务端可以注册多个不 ...
- golang ctrie demo
下载ctrie: go get -t github.com/Workiva/go-datastructures/trie/ctrie 测试demo1: package main import ( &q ...
随机推荐
- 手写IOC容器
IOC(控制翻转)是程序设计的一种思想,其本质就是上端对象不能直接依赖于下端对象,要是依赖的话就要通过抽象来依赖.这是什么意思呢?意思就是上端对象如BLL层中,需要调用下端对象的DAL层时不能直接调用 ...
- Raid0,1,5,10,50
raid0 就是把多个硬盘合并成1个逻辑盘使用,数据读写时对各硬盘同时操作,不同硬盘写入不同数据,速度快. **最少需要2块硬盘 raid1 同时对2个硬盘读写(同样的数据).强调数据的安全性.损坏一 ...
- JWT生成Token做登录校验
一.JWT的优点 1.服务端不需要保存传统会话信息,没有跨域传输问题,减小服务器开销. 2.jwt构成简单,占用很少的字节,便于传输. 3.json格式通用,不同语言之间都可以使用. 二.使用JWT进 ...
- Biopython 第三方库示例
Biopython 第三方库示例 https://biopython-cn.readthedocs.io/zh_CN/latest/
- PHP curl_share_close函数
(PHP 5 >= 5.5.0) curl_share_close — 关闭 cURL 共享句柄 说明 void curl_share_close ( resource $sh ) 关闭 cUR ...
- Oracle数据库迁移至PostgreSQL数据库问题及解决
Oracle数据库迁移PostgreSQL数据库问题及解决 目录 如何计划迁移数据库(现状及问题分析) 统计系统表及表功能 解耦公共表 建立数据库 迁移表结构 导入表数据 改SQL语法 保证数据时效性 ...
- Java线程池的了解使用—筑基篇
前言 Java中的线程池是一个很重要的概念,它的应用场景十分广泛,可以被广泛的用于高并发的处理场景.J.U.C提供的线程池:ThreadPoolExecutor类,可以帮助我们管理线程并方便地并行执行 ...
- XSSFWorkbook
支持2007以后的 此类与HSSFWorkbook(支持2007之前) 类似,读取文件时把全部的内容都存放到内存中,关闭输入流后. 内存与硬盘完全是毫无关系的两份数据,所有的操作都是对内存的操作,最后 ...
- MySQL-安装配置篇
一.MySQL二进制安装包安装 1.环境初始化 1)创建目录mkdir /app/database --安装路径 mkdir /data/3306 --存放数据路径 mkdir /binlog/330 ...
- 没用过消息队列?一文带你体验RabbitMQ收发消息
人生终将是场单人旅途,孤独之前是迷茫,孤独过后是成长. 楔子 先给大家说声抱歉,最近一周都没有发文,有一些比较要紧重要的事需要处理. 今天正好得空,本来说准备写SpringIOC相关的东西,但是发现想 ...