设为首页 收藏本站
查看: 412|回复: 0

[经验分享] [转]php实现的thrift socket server

[复制链接]

尚未签到

发表于 2017-3-28 14:12:04 | 显示全部楼层 |阅读模式
  作者:Volcano
  来源:http://www.ooso.net/archives/537
  
这些天用php写了个thrift的socket server,因为原来thrift的源码里php部分只有基于apache的服务器端代码,再加上前些日子看到php也能直接使用libevent构建web服务器,所以才会想到写这个玩玩。

php-thrift-server源码

代码直接从apache的thrift项目clone过来,托管在github上:
http://github.com/volca/thrift
新增或改动的代码如下:


    lib/php/
    `-- src
    |-- server
    |   |-- TNonblockingServer.php
    |   `-- TServer.php
    `-- transport
    |-- TNonblockingServerSocket.php
    |-- TNonblockingSocket.php
    |-- TServerSocket.php
    |-- TServerTransport.php
    test/php
    |-- TestClient.php
    |-- TestNonblockingServer.php


使用示例

获取thrift的源码,并编译出thrift工具,编译过程请搜索

git clone git://github.com/volca/thrift.git
安装php,以及apc, libevent扩展:

pecl install apc
#需要先libevent-devel之类的包包
pecl install libevent

运行php的socket服务器,我直接从thrift的test代码中修改了一个独立运行的php server,见thrift/test/php/TestNonblockingServer.php,这里也包含一个测试业务代码的实现。

cd thrift/test/php
#用thrift命令行工具生成php的测试类库
make
#启动thrift服务,会监听本机的9090端口
php
TestNonblockingServer.php
客户端的代码也一并提供,对各种数据类型比如int, float, string, list等等进行测试。

php TestClient.php
性能测试

apache + php的测试结果

testVoid() = void
testString
("Test") = "Test"
testByte
(1) = 1
testI32
(-1) = -1
testI64
(-34359738368) = -34359738368
testDouble
(-852.234234234) = -852.234234234
testStruct
({"Zero", 1, -3, -5}) = {"Zero", 1, -3, -5}
testNest
({1, {"Zero", 1, -3, -5}), 5} = {1, {"Zero", 1, -3, -5}, 5}
testMap
({0 => -10, 1 => -9, 2 => -8, 3 => -7, 4 => -6}) = {0 => -10, 1 => -9, 2 => -8, 3 => -7, 4 => -6}
testSet
({-2, -1, 0, 1, 2}) = {1, 1, 1, 1, 1}
testList
({-2, -1, 0, 1, 2}) = {-2, -1, 0, 1, 2}
testEnum
(ONE) = 1
testEnum
(TWO) = 2
testEnum
(THREE) = 3
testEnum
(FIVE) = 5
testEnum
(EIGHT) = 8
testTypedef
(309858235082523) = 309858235082523
Total time: 41 ms
php + libevent的socket server测试结果

testVoid() = void
testString
("Test") = "Test"
testByte
(1) = 1
testI32
(-1) = -1
testI64
(-34359738368) = -34359738368
testDouble
(-852.234234234) = -852.234234234
testStruct
({"Zero", 1, -3, -5}) = {"Zero", 1, -3, -5}
testNest
({1, {"Zero", 1, -3, -5}), 5} = {1, {"Zero", 1, -3, -5}, 5}
testMap
({0 => -10, 1 => -9, 2 => -8, 3 => -7, 4 => -6}) = {0 => -10, 1 => -9, 2 => -8, 3 => -7, 4 => -6}
testSet
({-2, -1, 0, 1, 2}) = {1, 1, 1, 1, 1}
testList
({-2, -1, 0, 1, 2}) = {-2, -1, 0, 1, 2}
testEnum
(ONE) = 1
testEnum
(TWO) = 2
testEnum
(THREE) = 3
testEnum
(FIVE) = 5
testEnum
(EIGHT) = 8
testTypedef
(309858235082523) = 309858235082523
Total time: 8 ms
这个测试中,没有耗时很长的请求,处理逻辑完全一样,php socket server耗时仅为apache + php的五分之一。

thrift是什么?

thrift流传的似乎不是太广泛,而且有被别的技术替代的趋势,所以下面还是引用一下别的文章的介绍:


Thrift由一个软件库和一系列的代码生成工具组成,由 Facebook开发。目的是为了加快软件开发和实现高效和可扩展的后台服务。主要目标是不同程序开语言之间实现高效和可靠的通信,这需要将不同语言之间抽象出一个通用层,然后由不同语言来实现这个通用层。在这里要特别指出的是,Thrift允许开发人员定义数据类型和服务接口(定义在一个中性语言文件里),并通过这个文件生成构建RPC客户端和服务端所需的代码。
简单分析其机理,Thrift就是实现C/S模式,通过代码生成工具将接口定义文件生成服务器端和客户端代码(可以为不同语言),从而实现服务端和客户端跨语言的支持。
Thrift可以分为传输层和协议层:
传输层定义了数据的传输方式,可以为TCP/IP传输,内存共享或者文件共享等形式;
协议层定义了数据的传输格式,可以为二进制流或者XML等形式。
当服务器端使用socket协议时,可以用simple|thread-pool|threaded|nonblocking等方式运行,从而获得更好的性能。




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-356595-1-1.html 上篇帖子: PHP页面3中跳转方法 下篇帖子: 背包问题的PHP算法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表