FFrpc python客户端lib
摘要:
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 {
: string data
} struct echo_thrift_out_t {
: 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 的实现介绍参见上一篇:http://www.cnblogs.com/zhiranok/p/ffrpc_client_server.html
更多精彩文章 http://h2cloud.org
FFrpc python客户端lib的更多相关文章
- ffrpc的php客户端lib
摘要: ffrpc 是c++异步通讯库,使用ffrpc可以非常容易的构建服务器程序.为了使用方便,ffrpc提供了python.php的客户端lib,这样使用php于c++构建的server也是顺手拈 ...
- zookeeper的python客户端安装
项目中使用了python,需要使用到zookeeper的功能,这里记录一下安装过程. 内核版本:2.6.32 发行版:CentOs-6.6 64bit 1.由于python客户端依赖c的客户端所以要先 ...
- Redis的Python客户端redis-py的初步使用
1. Redis的安装 sudo pip install redis sudo pip install hiredis Parser可以控制如何解析redis响应的内容.redis-py包含两个Par ...
- thrift例子:python客户端/java服务端
java服务端的代码请看上文. 1.说明: 这两篇文章其实解决的问题是,当使用python去访问大数据线上集群的时候,遇到两个问题: 1)python-hadoop和python-hive相关包链接不 ...
- python安装lib库
time:2015/11/11 双十一 一.初衷 看到一篇帖子[1],里面有python代码,就想实现一下,代码如下: import cv2 as cv import numpy as np from ...
- 配置百度云盘python客户端bypy上传备份文件
要求:安装python2.7,安装git 1.git clone https://github.com/houtianze/bypy.git 2.cd bypy 3.sudo python setup ...
- redis 概述及部署 安装php和python客户端
概述 Redis是一个基于key-value键值对的持久化数据库存储系统.redis支持的数据存储类型比memcached更丰富,包括strings(字符串),lists(列表),sets(集合)和s ...
- Rest Post示例(java服务端、python客户端)
前提:服务端是现成的,java.springMVC.resttemplate.jboss等:突然有个需要,要在windows上开发一个客户端,作用是定期向服务端上传文件.想了想,如果客户端写一个jav ...
- python客户端编程
上一篇说了最为底层的用来网络通讯的套接字.有很多基于套接字的一些协议,这些协议构成了当今互联网大多数客户服务器应用的核心 其实这些协议时在套接字上面的进一层封装用来完成特定的应用,这些应用主要包括: ...
随机推荐
- azure之MSSQL服务性能测试
azure给我们提供非常多的服务而这些服务可以让企业轻而易举地在上构建一个健壮的服务体系.但在使用azure的相关产品服务时还是应该对相关的服务有一些简单的性能了解才能更好的让企业购买适合自己的服务产 ...
- IIS负载均衡
工具下载链接 http://www.iis.net/downloads/microsoft/application-request-routing#additionalDownloads
- Kotlin & Vertx 构建web服务
感想 Kotlin 是一门好语言,值得大家了解一下. Vertx 是一个好框架,也值得大家了解一下. Kotlin 写过js,也写过一点点go,主力一直是java.用了kotlin,貌似找到了常用语言 ...
- C语言 队列 链式结构 实现
一个C语言链式结构实现的队列 mQueue (GCC编译). /** * @brief C语言实现的链式队列 * @author wid * @date 2013-10-31 * * @note 若代 ...
- missing locales
原文地址:http://codewut.de/content/missing-locales-under-debian This drives me crazy! Every time I deboo ...
- 在Android中进行单元测试遇到的问题
问题1.Cannot connect to VM socket closed 在使用JUnit进行测试的时候,遇到这个问题.网上的解释是:使用Eclipse对Java代码进行调试,无论是远程JVM还 ...
- SQL Server 2012 列存储索引分析(翻译)
一.概述 列存储索引是SQL Server 2012中为提高数据查询的性能而引入的一个新特性,顾名思义,数据以列的方式存储在页中,不同于聚集索引.非聚集索引及堆表等以行为单位的方式存储.因为它并不要求 ...
- ActiveMQ第三弹:在Spring中使用内置的Message Broker
在上个例子中我们演示了如何使用Spring JMS来向ActiveMQ发送消息和接收消息.但是这个例子需要先从控制台使用ActiveMQ提供的命令行功能启动一个Message Broker,然后才能运 ...
- Facebook网络模拟测试工具ATC使用
Facebook在其工程博客(原文)上宣布开源移动网络测试工具Augmented Traffic Control(ATC),我迅速试用了一番,非常不错,对手游或者其他APP的调试和测试都非常有帮助,介 ...
- Javascript中prototype属性的详解
原文链接:http://www.cnblogs.com/Uncle-Keith/p/5834289.html 在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象 ...