# RPC
## 简介
远程过程调用(Remote Procedure Call,RPC)是一个计算机通信协议;
该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而程序员无需额外为这个交互作用编程;
如果涉及的软件采用面向对象编程,那么远程过程调用亦可成为远程调用或远程方法调用
## Golang中实现RPC
Golang中实现RPC非常简单,官方提供了封装好的库,还有一些第三方的库,官方的net/rpc库使用encoding/gob进行编码,所以Golang的RPC只支持Golang开发的服务器和客户端之间交互。
官方还提供了net/rpc/jsonrpc库来实现RPC方法,jsonrpc采用了JSON进行数据编码解码,因而支持跨语言调用,目前jsonrpc库是基于tcp协议实现的,暂不支持http传输方式。
Golang的RPC必须符合四个条件才可以:
结构体首字母必须大写,要跨域访问,所以大写
函数名首字母必须大写
函数第一个参数是接收参数,第二个参数是返回个客户端的参数,必须是指针类型
函数有一个返回值error
## 示例
#### 服务器
实现求矩形面积和周长
```go
package main
import (
"fmt"
"net/http"
"net/rpc"
)
type Rect struct {
}
type Params struct {
Width int
Height int
}
// 求面积
func (r *Rect)Area(p Params, ret *int) error {
*ret = p.Width * p.Height
return nil
}
// 求周长
func (r *Rect)Perimeter(p Params, ret *int) error {
*ret = (p.Width + p.Height) * 2
return nil
}
func main() {
rect := new(Rect)
rpc.Register(rect)
rpc.HandleHTTP()
if err := http.ListenAndServe(":8080", nil); err != nil {
fmt.Println(err)
}
}
```
### 客户端
```go
package main
import (
"fmt"
"log"
"net/rpc"
)
type Params struct {
Width int
Height int
}
func main() {
client, err := rpc.DialHTTP("tcp", "127.0.0.1:8080")
if err != nil {
fmt.Println(err)
return
}
var ret int
if err = client.Call("Rect.Area", Params{Width: 4, Height: 5}, &ret); err != nil {
log.Fatal(err)
}
fmt.Println("area:", ret)
if err = client.Call("Rect.Perimeter", Params{Width: 4, Height: 5}, &ret); err != nil {
log.Fatal(err)
}
fmt.Println("Perimeter:", ret)
}
```
## 运行结果
分别运行服务器和客户端
```
area: 20
Perimeter: 18
```
- 空白目录
- 算法
- 排序
- 冒泡排序
- 选择排序
- 插入排序
- 归并排序
- 快速排序
- 计数排序
- 桶排序
- 基数排序
- 希尔排序
- 堆排序
- 二分查找
- 最小堆
- 最小索引堆
- 平衡二叉树(AVL tree)
- bitmap位图
- 布隆过滤器
- hashmap
- topK
- 跳表
- LRU Cache
- kmp
- 最小堆和堆排序
- 最短路径
- C++
- 运行时类型判断RTTI
- C++反射
- 手动实现智能指针
- 序列化实现
- rpc实现
- std::forward
- 函数指针的妙用
- C/C++
- std::function
- 同步队列
- 线程池实现
- std::promise
- 深入理解虚函数
- extern "C" 关键字讲解
- 大端小端的区别
- 简历
- 简历1
- redis
- 数据结构和对象
- sds
- list
- zskiplist
- 腾讯云redis面试题总结
- redis集群部署
- LeetCode
- 目标
- go基础
- 算法快速入门
- 数据结构篇
- 二叉树
- 链表
- 栈和队列
- 二进制
- 基础算法篇
- 二分搜索
- 排序算法
- 动态规划
- 算法思维
- 递归思维
- 滑动窗口思想
- 二叉搜索树
- 回溯法
- 其他
- 剑指offer
- 笔记
- git代理加速
- Linux
- vim大法
- vscode远程不能跳转
- cmake
- 设计模式
- 单例模式
- 简单工厂模式
- 外观模式
- 适配器模式
- 工厂方法模式
- 抽象工厂模式
- 生成器模式
- 原型模式
- 中介者模式
- 观察者模式
- 访问者模式
- 命令模式
- 网络编程
- epoll reactor模式
- linux timerfd系列函数总结
- IO
- mapreduce
- 反射器
- leo通信库
- Mutex
- Condition
- thread
- raft
- 协程
- hook
- 定时器
- 别人的面试经验
- 面试题
- vector崩溃问题
- JAVA
- Linux java环境配置
- ucore
- lab1
- FreeNOS
- leveldb
- 刷题笔记
- 回文串
- 前缀树
- 字符串查找
- 查找两个字符串a,b中的最长公共子串
- 动态规划
- golang
- 顺序循环打印实现
- 数据结构
- rpc运用
- python
- 单例
- 深拷贝浅拷贝
- 链表
- python基础题
- mysql
- 事务
- Linux
- 共享内存
- 刷题记录
- 贪心算法
- 动态规划
- 面试
- 腾讯C++面试
- 微众面试JD
- 迅雷网络面试
- 学习网址
- rabbitMq
