skynet中使用云风的pbc
来源:互联网 发布:淘宝钻号出售 编辑:程序博客网 时间:2024/05/16 06:52
引言:
假如我们要建立的skynet服务器与客户端的连接方式为长连接,且选择了Google的Protobuf来定制我们的网络协议,那么,接下来我们要解决的问题就是:如何在skynet框架中使用socket+protobuf。
protobuf在skynet中使用:
由于protobuf的lua版本的支持存在着部分缺陷,为了避免踩坑,这里我们直接使用云风博客中推荐的pbc
动态proto解析库。
资源下载:
下载pbc
:跟下载skynet源码一样,通过git
将pbc
的源码克隆到本地:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
编译并合入项目:
项目编译:
可以在pbc根目录下运行make指令编译项目:- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
假如编译结果报错了:
- 1
- 2
这是因为当前环境还没安装
`protobuf
,安装步骤如下:指令安装:
- 1
查询版本验证完成:
- 1
- 2
工具编译:
用终端进入pbc项目pbc/binding/lua
目录下面编译出protobuf.so:- 1
- 2
编译成功的话,将
protobuf.so
放在config文件中lua_cpath
项配置的目录下面,同时将protobuf.lua
放在config文件lua_path
配置的目录下,就可以调用protobuf中的库方法。我当前项目这两项的配置如下:- 1
- 2
则移动文件命令可以如下:
- 1
- 2
编译报错:
在
pbc/binding/lua
目录下编译,出现以下错误:- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
报错原因:这里因为没有安装
lua5.3(或者lua.h的路径不对,Makefile中辨认lua.h在/usr/local/include路径下)
,不能是lua5.2
或是lua5.1
等低版本,否则会报错。因为pbc用到了lua_rotate
这是lua5.3
新增的类型。
解决方案:安装一下lua5.3
即可解决,步骤如下:到lua官网下载lua5.3的安装包:
lua-5.3.0.tar.gz
也可以使用命令行下载工具axel
:- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
使用压缩包进行解压和安装:
先将下载好的文件拷贝到usr/local/src
目录下- 1
依次执行以下指令:
- 1
- 2
- 3
创建软链接,是lua可以在当前环境下随处可用:
- 1
测试一下软连接是否成功:
- 1
- 2
- 3
- 4
- 5
- 6
我也出现过这个问题,最后查到原因是因为添加软链接时第一个地址(lua的安装地址)
/usr/local/src/lua-5.3.0/src/lua
被我写成了/usr/local/src/lua5.3.0/src/lua
,解决问题和可以看到:- 1
- 2
- 3
修改
pbc/binding/lua/Makefile
中lua库的地址配置信息LUADIR
为当前lua安装的地址:- 1
再次运行编译指令,并查询当前目录下文件的变化:
- 1
- 2
- 3
- 4
可以看到多出了一个
protobuf.so
输出文件。
测试:
先在项目根目录下创建一个
protos
文件夹,用来存放协议文件,创建一个Person.proto
协议文件,内容如下:- 1
- 2
- 3
协议文件的内容如下:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
将协议文件到处为
.pb
格式:- 1
- 2
- 3
目录下多出了一个对应的
.pb
文件。
在lua中注册对应的协议文件:
引入
protobuf.lua
:- 1
注册.proto协议文件所对应的
.pb
文件,注册方法有两种:方法一:直接注册文件:
- 1
方法二:通过io读取文件,然后再获取文本内容进行注册:
- 1
- 2
- 3
- 4
通过
encode
和decode
两个接口来实现编码和解码,完整测试脚本:- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
运行正确的结果:
- 1
- 2
除外,云风还自定义了一套协议格式sproto
,据说比protobuf
还要简单。
参考:
- cocos2dx和skynet通信
- lua-protobuf 使用说明
- lua pbc
- pbc/binding/lua/README.md
- skyne use pbc protobuf
- skynet中使用云风的pbc
- Skynet服务器框架(五) 使用pbc(protobuf)
- pbc 的使用
- 在Quick-cocos2dx中使用云风pbc解析Protocol Buffers,支持win、mac、ios、android
- 在Quick-cocos2dx中使用云风pbc解析ProtocolBuffers,支持win、mac、ios、android
- 在Quick-cocos2dx中使用云风pbc解析Protocol Buffers,支持win、mac、ios、android
- 在Quick-cocos2dx中使用云风pbc解析Protocol Buffers,支持win、mac、ios、android
- 在Quick-cocos2dx中使用云风pbc解析Protocol Buffers,支持win、mac、ios、android
- pbc的使用(Windows)
- 使用pbc
- 使用 pbc
- 在golang中使用PBC密码库
- skynet中如何使用redis
- skynet中使用websocket和wss
- 在Quick-cocos2dx中运用云风pbc解析Protocol Buffers,支持win、mac、ios、android
- 云风的 blog 上关于 skynet 的分类
- lua pbc 使用
- 研究下skynet,云风大神的开源框架
- 个人总结37
- 51Nod 1001
- CCF-训练50题-NO.21-部分A+B
- Spring单例与线程安全小结
- 图论1
- skynet中使用云风的pbc
- mark
- nodeJs与grunt安装与配置
- 数据结构与算法分析(Java语言描述)(25)—— 邻接表表示稀疏图
- requests
- Authentication method password not supported by the server at this stage
- Linux命令(18)——screen命令
- openstack keystone整体架构与功能
- python3.6+pyqt5+pycharm5界面编程实例