首页
/ BERTRPC 技术文档

BERTRPC 技术文档

2024-12-23 15:25:08作者:姚月梅Lane

1. 安装指南

在开始使用BERTRPC之前,需要先进行安装。安装非常简单,只需使用以下命令安装Ruby的BERTRPC客户端库:

$ gem install bertrpc

确保你的系统中已经安装了Ruby和gem包管理器。

2. 项目的使用说明

BERTRPC是一个Ruby客户端库,它使得与BERT-RPC服务器的交互变得极其简单。BERTRPC目前支持BERT-RPC规范中的以下特性:

  • call 请求:用于从服务器请求响应的操作。
  • cast 请求:用于向服务器发送消息但不期待响应的操作。

BERTRPC已经被GitHub用于生产环境,并且每天执行数百万个RPC请求,其稳定性和性能都非常好。

创建服务

使用以下代码创建一个新的BERTRPC服务:

require 'bertrpc'
svc = BERTRPC::Service.new('localhost', 9999)

您还可以指定一个读取超时:

# 10秒的socket读取超时,如果超时会抛出 BERTRPC::ReadTimeoutError
svc = BERTRPC::Service.new('localhost', 9999, 10)

调用操作

以下是一个调用操作的示例,该操作将调用名为calc的服务中的add方法,并传递两个参数12

svc.call.calc.add(1, 2)
# 返回 3

底层BERT-RPC事务如下:

-> {call, calc, add, [1, 2]}
<- {reply, 3}

广播操作

以下是一个广播操作的示例,该操作将向名为stats的服务发送incr消息,不期待返回值:

svc.cast.stats.incr
# 返回 nil

底层BERT-RPC事务如下:

-> {cast, stats, incr, []}
<- {noreply}

3. 项目API使用文档

本项目提供的API接口非常简单,主要包括以下类和方法:

  • BERTRPC::Service.new(host, port, [timeout]): 创建一个新的BERTRPC服务实例。
  • #call(service_name, method_name, *args): 发送一个BERT-RPC call 请求到服务器。
  • #cast(service_name, method_name, *args): 发送一个BERT-RPC cast 请求到服务器。

4. 项目安装方式

本项目的安装方式已在安装指南部分详细介绍,概括来说,就是通过gem命令安装BERTRPC Ruby库。

确保您的系统中已经安装了Ruby环境以及gem工具。使用以下命令安装:

$ gem install bertrpc

以上就是关于BERTRPC项目的详细技术文档。希望对您使用本项目有所帮助。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
7
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
309
2.71 K
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
362
2.92 K
flutter_flutterflutter_flutter
暂无简介
Dart
600
135
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.07 K
616
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
637
235
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
774
74
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
cangjie_toolscangjie_tools
仓颉编程语言命令行工具,包括仓颉包管理工具、仓颉格式化工具、仓颉多语言桥接工具及仓颉语言服务。
C++
55
823
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.03 K
464