Go微服务: 基于net/rpc/jsonrpc模块实现微服务跨语言调用
概述
- Golang 提供
net/rpc/jsonrpc库来实现rpc方法 - 采用 json 方式进行数据编解码,支持跨语言调用
这里实现跨语言示例
1 )go 服务端
package main import ( "log" "net" "net/rpc" "net/rpc/jsonrpc"
) // 定义服务接口
type Arith int // 定义接口方法,参数和返回值都应该是指针类型
func (t *Arith) Multiply(args *Args, reply *int) error {*reply = args.A * args.Blog.Print("参数", args)return nil
} // Args 是传递给服务的参数结构
type Args struct { A, B int
} func main() { arith := new(Arith) rpc.Register(arith) l, err := net.Listen("tcp", ":1234") if err != nil { log.Fatal("listen error:", err) } defer l.Close() for { conn, err := l.Accept() if err != nil { log.Print("accept error:", err) continue } // 使用 jsonrpc 包处理连接 go func() { jsonrpc.ServeConn(conn) conn.Close() }() }
}
2 )nodejs 客户端1
const net = require('net');
const readline = require('readline'); // 创建一个 TCP 客户端
const client = new net.Socket(); // 连接到服务器
client.connect(1234, 'localhost', () => { console.log('Connected to server!'); // 发送请求到服务器 const request = JSON.stringify({ jsonrpc: "2.0", method: "Arith.Multiply", params: [{ A: 7, B: 8 }], id: 1 }); client.write(request + '\n');
}); // 处理从服务器返回的数据
const rl = readline.createInterface({ input: client, output: process.stdout, terminal: false
}); rl.on('line', (line) => { const response = JSON.parse(line); console.log('Server response:', response.result); client.end();
}); client.on('error', (err) => { console.error('Socket error:', err);
}); client.on('close', () => { console.log('Connection closed');
});
3 )nodejs 客户端2
const jayson = require('jayson');
const client = jayson.client.tcp({ port: 1234, host: 'localhost'
}); // 定义要调用的方法以及参数
const request = { jsonrpc: "2.0", method: "Arith.Multiply", params: [{ A: 7, B: 8 }], id: 1
}; // 发送请求并处理响应
client.request(request, function(err, response) { if (err) { console.error('请求出错:', err); return; } console.log('服务器响应:', response.result); // 输出乘法的结果
});
4 )go 客户端3
package mainimport ("fmt""net""net/rpc""net/rpc/jsonrpc"
)type Args struct { A int `json:"A"` B int `json:"B"`
} func main() {// 1. 用 net.Dial和rpc微服务端建立连接conn, err1 := net.Dial("tcp", "127.0.0.1:1234")if err1 != nil {fmt.Println(err1)}// 2. 当客户端退出的时候关闭连接defer conn.Close()// 3、建立基于json编解码的rpc服务client := rpc.NewClientWithCodec(jsonrpc.NewClientCodec(conn))// 4. 调用远程函数var reply interr2 := client.Call("Arith.Multiply", Args{A: 7, B: 8}, &reply)if err2 != nil {fmt.Println(err2)}// 5. 获取微服务返回的数据fmt.Println(reply)
}
总结
- 这里演示了,基于go语言为服务端,nodejs 和 golang 为客户端的3种示范
- 注意,上面 nodejs版本中的 params 的格式与 golang 中的区别
- 标准库的RPC默认采用Go语言特有的gob编码,没法实现跨语言调用
- golang官方还提供了 net/rpc/jsonrpc 库实现RPC方法
- JSON RPC采用JSON进行数据编解码,因而支持跨语言调用
- 但目前的jsonrpc库是基于tcp协议实现的,暂时不支持使用http进行数据传输
- 另外,Mac环境,在没有服务端服务时,可用 nc 工具调试客户端
- $
nc -l 127.0.0.1 1234
- $
- linux下需要安装, $
yum install -y nc - nc是netcat的简写,是一个功能强大的网络工具,有着网络界的瑞士军刀美誉
- nc命令的主要作用如下:
- 实现任意TCP/UDP端口的侦听,nc可以作为server以TCP或UDP方式侦听指定端口
- 端口的扫描,nc可以作为client发起TCP或UDP连接
- 机器之间传输文件
- 机器之间网络测速
相关文章:
Go微服务: 基于net/rpc/jsonrpc模块实现微服务跨语言调用
概述 Golang 提供 net/rpc/jsonrpc 库来实现rpc方法采用 json 方式进行数据编解码,支持跨语言调用 这里实现跨语言示例 1 )go 服务端 package main import ( "log" "net" "net/rpc" "net/rpc/jsonrpc" )…...
Guitar Pro 8.1中文版永久许可证激活2024最新24位注册激活码生成器
Guitar Pro是一款非常受欢迎的音乐制作软件,它可以帮助用户创建和编辑各种音乐曲谱。从其诞生以来就送专门为了编写吉他谱而研发迭代的。 尽管这款产品可能已经成为全球最受欢迎的吉他打谱软件,在编写吉他六线谱和乐队总谱中始终处于行业领先地位&#…...
自然语言处理(NLP)练习题
问题:什么是自然语言处理(NLP)? 答案:自然语言处理(NLP)是一种人工智能技术,旨在让计算机理解和处理人类语言。NLP涉及语言学、计算机科学和人工智能等多个领域,旨在开发…...
P2386 放苹果
题目传送门 题目描述 把 m 个同样的苹果放在n 个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法。(5,1,15,1,1 和 1,1,51,1,5 是同一种方法) 输入格式 第一行是测试数据的数目 t,以下每行均包括二个整…...
TI IWR6843ISK ROS驱动程序搭建
1、设备准备 1.1 硬件设备 1)TI IWR 6843 ISK 1块 2)Micro USB 数据线 1条 1.2 系统环境 1)VMware Workstation 15 Player 虚拟机 2)Ubuntu18.04 并安装有 ROS1 系统 如若没有安装 ROS 系统,可通过如下指令进行…...
【Godot4自学手册】第二十节增加游戏的打击感,镜头震颤、冻结帧和死亡特效
这节我主要学习增加游戏的打击感。我们通过镜头震颤、冻结帧、增加攻击点特效,增加死亡。开始了。 一、添加攻击点特效 增加攻击点特效就是,在攻击敌人时,会在敌人受击点显示一个受击动画。 1.添加动画。 第一步先做个受击点动画。切换到…...
[论文笔记] Open-Sora 1、sora复现方案概览
GitHub - hpcaitech/Open-Sora: Unofficial implementation of OpenAIs Sora Open-Sora已涵盖: 提供完整的Sora复现架构方案,包含从数据处理到训练推理全流程。 支持动态分辨率,训练时可直接训练任意分辨率的视频,无需进行缩放。 支持多种模型结构。由于Sora实际模型结构未…...
持续更新 | 与您分享 Flutter 2024 年路线图
作者 / Michael Thomsen Flutter 是一个拥有繁荣社区的开源项目,我们致力于确保我们的计划公开透明,并将毫无隐瞒地分享从问题到设计规范的所有内容。我们了解到许多开发者对 Flutter 的功能路线图很感兴趣。我们往往会在一年中不断更改并调整这些计划&a…...
Go语言数据结构(二)堆/优先队列
文章目录 1. container中定义的heap2. heap的使用示例3. 刷lc应用堆的示例 更多内容以及其他Go常用数据结构的实现在这里,感谢Star:https://github.com/acezsq/Data_Structure_Golang 1. container中定义的heap 在golang中的"container/heap"…...
NERF论文笔记(1/2)
NeRF:Representing Scene as Neural Radiance Fields for View Synthesis 笔记 摘要 实现了一个任意视角视图生成算法:输入稀疏的场景图像,通过优化连续的Volumetric场景函数实现;用全连接深度网络表达场景,输入是一个连续的5维…...
深入理解nginx一致性哈希负载均衡模块[上]
1. 引言 在现代的网络应用中,负载均衡是一个至关重要的组件。它能够分配流量到多个服务器上,实现高可用性和性能扩展。Nginx是一个广泛使用的高性能Web服务器和反向代理服务器,其负载均衡模块提供了多种算法来实现流量的分发。其中࿰…...
【Linux】Docker安装
卸载旧版Docker 新版docker无法覆盖旧版的,所以需要先卸载原来的旧版本 yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-selinux \docker-engine-selinux \docker-eng…...
动态SLAM论文阅读笔记
近期阅读了许多动态SLAM相关的论文,它们基本都是基于ORB-SLAM算法,下面简单记录一下它们的主要特点: 1.DynaSLAM 采用CNN网络进行分割多视图几何辅助的方式来判断动态点,并进行了背景修复工作。 2.Detect-SLAM 实时性问题&…...
数据挖掘:航空公司的客户价值分析
需求分析 理解并掌握聚类分析方法,掌握数据的标准化,掌握寻找最佳聚类数,掌握聚类的绘图,掌握聚类分析的应用场景。 系统实现 实验流程分析 借助航空公司数据,对客户进行分类对不同类别的客户进行特征分析…...
GIS之深度学习08:安装GPU环境下的pytorch
环境: cuda:12.1.1 cudnn:12.x pytorch:2.2.0 torchvision:0.17.0 Python:3.8 操作系统:win (本文安装一半才发现pytorch与cuda未对应,重新安装了cuda后才开始的&a…...
防患未然,OceanBase巡检工具应用实践——《OceanBase诊断系列》之五
1. OceanBase为什么要做巡检功能 尽管OceanBase拥有很好的MySQL兼容性,但在长期的生产环境中,部署不符合标准规范、硬件支持异常,或配置项错误等问题,这些短期不会出现的问题,仍会对数据库集群构成潜在的巨大风险。为…...
数据结构从入门到精通——队列
队列 前言一、队列1.1队列的概念及结构1.2队列的实现1.3队列的实现1.4扩展 二、队列面试题三、队列的具体实现代码Queue.hQueue.ctest.c队列的初始化队列的销毁入队列出队列返回队头元素返回队尾元素检测队列是否为空检测元素个数 前言 队列是一种特殊的线性数据结构ÿ…...
深度学习相关概念及术语总结
目录 1.CNN2.RNN3.LSTM4.NLP5.CV6.正向传播7.反向传播8.sigmoid 函数9.ReLU函数10.假设函数11.损失函数12.代价函数 1.CNN CNN 是卷积神经网络(Convolutional Neural Network)的缩写。卷积神经网络是一种深度学习模型,专门用于处理具有网格状…...
uniapp发行H5获取当前页面query
阅读uni的文档大致可得通过 onLoad与 onShow()的形参都能获取页面传递的参数,例如在开发时鼠标移动到方法上可以看到此方法的简短介绍 实际这里说的是打开当前页面的参数,在小程序端的时候测试并无问题,但是发行到H5时首页加载会造成参数获取…...
Flutter中动画的实现
动画三要素 控制动画的三要素:Animation、Tween、和AnmaitionController Animation: 产生的值的序列,有CurveAnimation等子类,, 可以将值赋值给Widget的宽高或其他属性,进而控制widget发生变化 Tween&#…...
3分钟搞定Android Studio中文界面:告别英文困扰的终极配置指南
3分钟搞定Android Studio中文界面:告别英文困扰的终极配置指南 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack 还在为…...
STM32 IAP升级避坑指南:Ymodem协议实战中那些容易忽略的细节(附代码)
STM32 IAP升级避坑指南:Ymodem协议实战中那些容易忽略的细节(附代码) 在嵌入式开发领域,IAP(In-Application Programming)技术为产品固件升级提供了极大便利,而Ymodem协议因其高效可靠的特点成为…...
PIE Engine数据管理避坑指南:从Shapefile上传到哨兵2号影像导出的完整流程
PIE Engine数据管理避坑指南:从Shapefile上传到哨兵2号影像导出的完整流程 第一次接触PIE Engine时,我花了整整三天时间才成功导出一张完整的哨兵2号影像。期间经历了Shapefile压缩包反复上传失败、云盘导出后找不到文件、波段组合显示异常等各种问题。如…...
如何用Mac Mouse Fix让你的普通鼠标超越苹果触控板 - 终极配置指南
如何用Mac Mouse Fix让你的普通鼠标超越苹果触控板 - 终极配置指南 【免费下载链接】mac-mouse-fix Mac Mouse Fix - Make Your $10 Mouse Better Than an Apple Trackpad! 项目地址: https://gitcode.com/GitHub_Trending/ma/mac-mouse-fix Mac Mouse Fix是一款专为mac…...
ComfyUI-AnimateDiff-Evolved深度解析:专业动画生成进阶实践指南
ComfyUI-AnimateDiff-Evolved深度解析:专业动画生成进阶实践指南 【免费下载链接】ComfyUI-AnimateDiff-Evolved Improved AnimateDiff for ComfyUI and Advanced Sampling Support 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-AnimateDiff-Evolved …...
终极指南:Fiji图像分析工具快速入门与高效使用秘籍 [特殊字符]
终极指南:Fiji图像分析工具快速入门与高效使用秘籍 🚀 【免费下载链接】fiji A "batteries-included" distribution of ImageJ :battery: 项目地址: https://gitcode.com/gh_mirrors/fi/fiji Fiji作为一款功能强大的科学图像分析工具&a…...
保姆级教程:在NRF52840上实现USB虚拟串口,并每秒发送数据到PC和安卓手机
从零构建NRF52840 USB虚拟串口通信系统:跨平台数据收发实战指南 在嵌入式开发中,稳定可靠的通信接口是连接物理设备与数字世界的桥梁。NRF52840作为Nordic Semiconductor旗舰级蓝牙SoC,其内置的USB 2.0全速控制器为开发者提供了除蓝牙之外的…...
SOONet惊艳效果集:8个高难度查询(含否定、时序逻辑、多对象交互)结果展示
SOONet惊艳效果集:8个高难度查询(含否定、时序逻辑、多对象交互)结果展示 1. 项目简介 SOONet是一个基于自然语言输入的长视频时序片段定位系统,它能够通过一次网络前向计算就精确定位视频中的相关片段。这个技术最大的亮点在于…...
通义千问3-Reranker-0.6B在电商搜索中的应用:商品相关性排序
通义千问3-Reranker-0.6B在电商搜索中的应用:商品相关性排序 1. 引言 你有没有遇到过这样的情况:在电商平台搜索"轻薄笔记本电脑",结果却给你推荐了厚重的游戏本?或者搜索"夏季连衣裙",却看到一…...
PyTorch 2.6镜像保姆级教程:3步完成GPU加速环境配置
PyTorch 2.6镜像保姆级教程:3步完成GPU加速环境配置 你是不是刚拿到一台新服务器,想快速搭建一个能跑深度学习的GPU环境,结果被各种驱动、CUDA版本、环境依赖搞得头大?或者你只是想快速验证一个PyTorch模型,却花了大半…...
