FFrpc python客户端lib使用解析


Posted in Python onAugust 24, 2019

摘要:

Ffrpc可以很方便的构建c++ server, 在网游服务器程序开发中,进程间通讯非常的重要,比如gateserver和gameserver或dbserver之间的通信。而ffrpc可以使得进程间通信非常简单,是由于ffrpc的broker模式封装了位置无关性,使得如gate调用gameserver的接口只需要知道对方的服务名,从而使得程序中各个节点的关系与系统的拓扑关系是完美吻合的。这也使得系统的架构更加清晰,系统的实现更健壮和易维护。

之前ffrpc只提供了c++ server/client的实现,在网游服务器程序开发中经常有些需求是需要其他语言和C++server通信的,比如一些工具程序,一些web配置、管理后台登通常用脚本语言实现更加敏捷。比如开发一个gm后台,就可以使用python开发一个web页面实现,而gm后台指令需要发给c++ server去执行。所以,脚本语言对于C++ server的的接口调用的需求是确实存在的。所以ffrpc中提供python的客户端礼库ffrpc-py。

特性

  • C++ server 通常是使用二进制协议传输数据的,但是如果手动用python组二进制包则非常的困难,好在有google protobuf和thrift两大神器,而google protobuf在服务器程序开发领域已经被广泛接受。所以由于C++ server定义接口时使用了protobuf(或者像我一样偏爱thrift),那么与脚本通讯就变得小轻松了。
  • 对于C++ server 来讲,通信时异步的,这是由于C++ server一般是逻辑层单线程,为了保持高并发能力,io操作异步化是必然选择。但是对于脚本如python这种,一般而言还是使用同步调用模型,而刚好ffrpc的通信模式要求所有的接口都是req<->ret一一对应的,ffrpc-py调用c++ server的接口,只需要制定输入消息,然后调用接口,接收返回消息,像调用本地函数一样直接,这也是rpc lib的存在意义。
  • Ffrpc-py 支持protobuf和thrift,当然必须和c++ server采用的通信协议一致。

示例

本例采用c++ sever thrift作为示例。由于ffrpc example目录的tutorial已经实现了一个c++ echo server,本例就利用ffrpc-py调用echo接口。

其中thrift的定义文件为:

struct echo_thrift_in_t {   
 1: string data
}

struct echo_thrift_out_t {   
 1: string data
}

使用ffrpc-py调用echo接口:

HOST = '127.0.0.1'
  PORT = 10246
  ffc = ffclient_t(HOST, PORT, 1.5) # 1.5 sec为调用超时时间
  req = ttypes.echo_thrift_in_t('ohNice')
  ret = ttypes.echo_thrift_out_t()
  ffc.call('echo', req, ret, 'ff')
  print('error_info = %s' %(ffc.error_msg()), ret)

ffrpc接口的参数的解释:

  • ffclient_t(HOST, PORT, 1.5) 构造函数的参数为broker的监听地址和端口。Ffrpc-py只需要知道broker的位置,至于调用的是哪个服务器的接口,这个由broker确定,至于目标服务器是跟broker在同一个进程,还是通过网络连接,ffrpc-py无需知道细节。
  • call 接口调用远程的服务器接口,参数一为c++server接口注册的服务名,ffrpc-py只需要知道服务名就可以定位目标服务器的位置
  • call第二个参数为请求参数
  • call第三个参数为c++ server返回的消息类型,如果call返回true,那么该消息会被自动赋上值
  • 第四个参数为消息的命名空间,比如定义thrift的文件的时候定义了命名空间,那么需要第四个参数填入命名空间,这里跟C++ server的注册的消息一致即可,如果C++ server也没有消息的命名空间,那么省略这个参数即可
  • Call接口成功返回True,失败为false,同时error_msg接口可以输出错误原因

总结

Ffrpc提供了python lib,可以实现py与c++ server的通信,这样利用python编写工具、后台都更加方便了。

同时ffrpc将会对于php进行支持,相应的client lib 不久就会开放出来。

Github:  https://github.com/fanchy/FFRPC

c++ server 的实现介绍参见:https://3water.com/article/168369.htm

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python迭代器的使用方法实例
Nov 21 Python
Python使用稀疏矩阵节省内存实例
Jun 27 Python
python计算auc指标实例
Jul 13 Python
Numpy中stack(),hstack(),vstack()函数用法介绍及实例
Jan 09 Python
Python中sort和sorted函数代码解析
Jan 25 Python
详解Django rest_framework实现RESTful API
May 24 Python
计算机二级python学习教程(2) python语言基本语法元素
May 16 Python
python实现发送form-data数据的方法详解
Sep 27 Python
Python %r和%s区别代码实例解析
Apr 03 Python
python Matplotlib数据可视化(2):详解三大容器对象与常用设置
Sep 30 Python
Python爬虫实现selenium处理iframe作用域问题
Jan 27 Python
Pytorch 统计模型参数量的操作 param.numel()
May 13 Python
用Python将Excel数据导入到SQL Server的例子
Aug 24 #Python
python 根据网易云歌曲的ID 直接下载歌曲的实例
Aug 24 #Python
用Python爬取QQ音乐评论并制成词云图的实例
Aug 24 #Python
python解释器spython使用及原理解析
Aug 24 #Python
python爬虫之爬取百度音乐的实现方法
Aug 24 #Python
python3 实现爬取TOP500的音乐信息并存储到mongoDB数据库中
Aug 24 #Python
python处理自动化任务之同时批量修改word里面的内容的方法
Aug 23 #Python
You might like
PHP制作图型计数器的例子
2006/10/09 PHP
php array_multisort 对数组进行排序详解及实例代码
2016/10/27 PHP
ThinkPHP5.0多个文件上传后找不到临时文件的修改方法
2018/07/30 PHP
javascript 限制输入脚本大全
2009/11/03 Javascript
javascript 事件绑定问题
2011/01/01 Javascript
基于jquery的防止大图片撑破页面的实现代码(立即缩放)
2011/10/24 Javascript
Knockout text绑定DOM的使用方法
2013/11/15 Javascript
window.location 对象所包含的属性
2014/10/10 Javascript
javascript实现粘贴qq截图功能(clipboardData)
2016/05/29 Javascript
纯js实现手风琴效果代码
2020/04/17 Javascript
jQuery常见的选择器及用法介绍
2016/12/20 Javascript
浅谈原型对象的常用开发模式
2017/07/22 Javascript
详解vue-cli 3.0 build包太大导致首屏过长的解决方案
2018/11/10 Javascript
js中call()和apply()改变指针问题的讲解
2019/01/17 Javascript
基于node.js实现爬虫的讲解
2019/02/18 Javascript
spring+angular实现导出excel的实现代码
2019/02/27 Javascript
在SSM框架下用laypage和ajax实现分页和数据交互的方法
2019/09/27 Javascript
nodeJs的安装与npm全局环境变量的配置详解
2020/01/06 NodeJs
基于node+vue实现简单的WebSocket聊天功能
2020/02/01 Javascript
[01:52]2020年DOTA2 TI10夏季活动预告片
2020/07/15 DOTA
vc6编写python扩展的方法分享
2014/01/17 Python
python操作mysql中文显示乱码的解决方法
2014/10/11 Python
Python+request+unittest实现接口测试框架集成实例
2018/03/16 Python
浅谈python中字典append 到list 后值的改变问题
2018/05/04 Python
Python实用技巧之利用元组代替字典并为元组元素命名
2018/07/11 Python
简单了解Java Netty Reactor三种线程模型
2020/04/26 Python
HTML5+CSS3实现拖放(Drag and Drop)示例
2014/07/07 HTML / CSS
土木工程建筑专业毕业生求职信
2013/10/21 职场文书
中药专业大学生医药工作求职信
2013/10/25 职场文书
公证委托书大全
2014/04/04 职场文书
国际会计专业求职信
2014/08/04 职场文书
2014年图书室工作总结
2014/12/09 职场文书
《学会生存》读后感3篇
2019/12/09 职场文书
Java数据结构之链表相关知识总结
2021/06/18 Java/Android
vue使用echarts实现折线图
2022/03/21 Vue.js
Redis过期数据是否会被立马删除
2022/07/23 Redis