golang实现一个简单的rpc框架

前言

RPC在分布式系统中经常使用,这里写一个简单的demo实践一下。

code

先生成 go.mod 文件

go mod init rpc-try01

定义方法

package model// Args 是 RPC 方法的参数结构体
type Args struct {A, B int
}// Arith 定义了一个简单的算术服务
type Arith struct{}// Multiply 是 Arith 类型的一个方法,实现乘法
func (a *Arith) Multiply(args *Args, reply *int) error {*reply = args.A * args.Breturn nil
}



server.go利用 Go官方提供的一个RPC库: net/rpc 进行实现

package mainimport ("fmt""net""net/rpc""rpc-try01/model"
)func main() {arith := new(model.Arith)rpc.Register(arith) // 注册服务listener, err := net.Listen("tcp", ":1234")if err != nil {fmt.Println("Error starting RPC server:", err)return}defer listener.Close()fmt.Println("RPC server listening on port 1234...")for {conn, err := listener.Accept()if err != nil {fmt.Println("Error accepting connection:", err)continue}go rpc.ServeConn(conn) // 开个协程处理连接}
}



client.go

package mainimport ("fmt""net/rpc""rpc-try01/model"
)func main() {// 连接到 RPC 服务器client, err := rpc.Dial("tcp", "localhost:1234")if err != nil {fmt.Println("Error connecting to RPC server:", err)return}defer client.Close()// 准备参数args := &model.Args{A: 7, B: 8}var reply int// 调用远程方法, 这里将会用到反射err = client.Call("Arith.Multiply", args, &reply)if err != nil {fmt.Println("Error calling RPC method:", err)return}// 输出结果fmt.Printf("Result of %d * %d = %d\n", args.A, args.B, reply)
}

run

开两个终端,一个跑server,一个跑 client


Go 的 RPC 使用 gob 编码进行数据序列化。如果你需要与其他语言互操作,可以考虑使用 JSON 或 Protobuf 等其他编码方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/407253.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

工业4G路由器

设备概述 路由器是基于4G 技术研发的无线路由网关设备,除了具备传统路由器 的 VPN 、防火墙、 NAT 、 PPPoE 、 DHCP 等功能之外,还能支持 4G 无线拨号,提供最高可达 150Mbps 的无线高速带宽。路由器支持四个以太网接口,可更好…

产品需求文档

一、产品需求文档常用形式 RP:主要借助原型绘制工具绘制原型 包括产品简介:版本说明、交互自查表 产品概览:功能清单、项目排期 产品结构:结构图、流程图 产品原型:全局说明、具体原型、功能说明 非功能需求&…

揭秘!挑选随身WiFi的终极攻略:一篇文章教会你怎么挑选随身WiFi,学会对比各项参数,随身WiFi哪个好?

对于不方便拉宽带的大流量使用者,随身WiFi尤为重要。面对市场上琳琅满目的随身WiFi品牌和型号,许多用户感到无从下手。不同随身WiFi在性能、价格、续航等方面各有优势,如何挑选一款适合自己的随身WiFi成为了一大难题。本文将为您详细解析随身…

循环神经网络RNN时间序列预测与MLP比较

1 序列数据 利用CNN构建图像识别模型,对每个样本的假设是独立同分布的,然而,大多数的数据并非如此。例如,文章中的单词是按顺序写的,如果顺序被随机地重排,就很难理解文章原始的意思。同样,视频中的图像帧、对话中的音频信号以及网站上的浏览行为都是有…

VMware Workstation Pro 下载

文章目录 VMware Workstation ProVMware下载与安装 VMware Workstation Pro VMware Workstation Pro 对个人用户已经完全免费! VMware下载与安装 第一步:进入vmware的官网 VMWare已被收购,因此它会跳到, Broadcom 注册页面&…

命令模式:如何利用命令模式实现手游后端架构?

成长路上不孤单😊【14后boy,C爱好者,持续分享所学,如有需要欢迎收藏转发😊😊😊😊😊😊😊!!!接上篇博文&#xf…

【React原理 - 任务调度和时间分片详解】

概述 在React15的时候,React使用的是从根节点往下递归的方式同步创建虚拟Dom,由于递归具有同步不可中断的特性,所以当执行长任务时(通常以60帧为标准,即16.6ms)就会长时间占用主线程长时间无响应,导致页面卡顿&#x…

通过C# 读取PDF页面大小、方向、旋转角度

在处理PDF文件时,了解页面的大小、方向和旋转角度等信息对于PDF的显示、打印和布局设计至关重要。本文将介绍如何使用免费.NET 库通过C#来读取PDF页面的这些属性。 文章目录 C# 读取PDF页面大小(宽度、高度)C# 判断PDF页面方向C# 检测PDF页面…

批发部小程序怎么制作 批发配送系统开发方法

很多领导想要做一个自己公司的批发部小程序系统,但是不知道该怎么做,本次瀚林就为大家详细介绍一下各种批发部小程序系统的开发制作方法为大家做参考。 目前市面上的批发部有很多类型例如常见的:食品、鲜花、零售批发商、冻品、百货、批发城、…

实现BeanPostProcessor

文章目录 1.实现初始化方法1.目录2.InitializingBean.java3.MonsterService.java 实现初始化接口4.SunSpringApplicationContext.java 调用初始化方法5.测试 2.实现后置处理器1.目录2.BeanPostProcessor.java 后置处理器接口3.SunBeanProcessor.java 自定义后置处理器4.SunSpri…

【Python】函数的定义和调用、形参和实参、函数的返回值、多元赋值、全局和局部变量

文章目录 函数的定义函数的调用形参和实参函数的返回值一个 return多个 return多元赋值 变量作用域函数内的变量全局变量和局部变量修改全局变量 函数的定义 函数的定义:分配任务 def 函数名(形参列表):函数体return 返回值def:define,定义…

AI革新下的社交媒体:揭秘Facebook如何利用智能算法

在社交媒体领域,Facebook一直走在技术创新的前沿。随着人工智能(AI)的飞速发展,Facebook通过智能算法不断革新用户体验、提升平台效率,并推动社交互动的新形式。本文将详细探讨Facebook如何利用AI技术,从个…

ElasticSearch IK分词器的MySQL热部署字典(Docker)

1.下载插件源码 找到自己对应ES版本的下载 Releases infinilabs/analysis-ik GitHub 2.添加mysql驱动依赖 <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.16</version><…

C++模拟实现priority_queue(优先级队列)

一、priority_queue的函数接口 从上图我们可以看出&#xff0c; priority_queue也是一个容器适配器&#xff0c;我们使用vector容器来模拟实现priority_queue。 namespace bit{#include<vector>#include<functional>template <class T, class Container vector…

【数据结构】动态顺序表的实现

1.什么是数据结构 数据结构就是把数据元素按照一定的关系组织起来的集合&#xff0c;用来组织和存储数据。通过数据结构&#xff0c;能够有效的将数据组织和管理在一起&#xff0c;按照我们的方式任意对数据进行增删查改等操作。 2.数据结构的分类 数据结构大概可分为逻辑结构…

Selenium + Python 自动化测试19(补充-读取各种文件数据操作)

我们的目标是&#xff1a;按照这一套资料学习下来&#xff0c;大家可以独立完成自动化测试的任务。 上一篇我们讨论了数据驱动测试中如何完成重复的测试实例&#xff0c;今天我们补充一些读取各种文件的方法。 本篇文章我们讨论一下如何使用读取txt、CSV、Excel文件&#xff0…

14-17岁未成年如何办理能一直用的手机卡?

14-17岁未成年如何办理能一直用的手机卡&#xff1f; 有些姐妹要去外面上学&#xff0c;都想要一张属于自己的手机卡。 但是因为反诈的原因&#xff0c;对于手机卡的申领特别严格。 很多不满18岁的人能申领的卡&#xff0c;都是物联卡或者纯流量卡&#xff0c;只能上网&#x…

如何评估Redis的性能

如果系统中出现了大 key、热 key 等&#xff0c;往往会导致 Redis 变慢&#xff0c;但是这个慢该如何界定&#xff1f;多久算慢&#xff1f;1秒还是3秒&#xff1f; 这个肯定是没有标准答案&#xff0c;因为这个和你的硬件设备有关。 硬件差一些&#xff0c;平时响应时间都是…

css 宫格样式内容上下结构

结构 <div class"sc-content-group"><div class"sc-content-item"><div class"sc-item-img"><el-image :src"src" :preview-src-list"[src]"></el-image></div><div class"s…

前程无忧搜索接口 JS 逆向:阿里系acw_sc__v2和Sign加密

&#x1f4ca; 前程无忧搜索接口 JS 逆向&#xff1a;阿里系acw_sc__v2和Sign加密 &#x1f50d; 观察网页加密规律&#xff1a;阿里系acw_sc__v2 在分析前程无忧的搜索接口时&#xff0c;我们首先需要关注网页的加密规律。特别是阿里系的 acw_sc__v2 加密机制。这个加密机制通…