php实现的thriftsocketserver_PHP教程
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php实现的thriftsocketserver_PHP教程,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3589字,纯文字阅读大概需要6分钟。
内容图文
![php实现的thriftsocketserver_PHP教程](/upload/InfoBanner/zyjiaocheng/176/15a2f55466494acfb38d44a76a707527.jpg)
代码直接从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() = voidtestString("Test") = "Test"testByte(1) = 1testI32(-1) = -1testI64(-34359738368) = -34359738368testDouble(-852.234234234) = -852.234234234testStruct({"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) = 1testEnum(TWO) = 2testEnum(THREE) = 3testEnum(FIVE) = 5testEnum(EIGHT) = 8testTypedef(309858235082523) = 309858235082523Total time: 41 msphp + libevent的socket server测试结果
testVoid() = voidtestString("Test") = "Test"testByte(1) = 1testI32(-1) = -1testI64(-34359738368) = -34359738368testDouble(-852.234234234) = -852.234234234testStruct({"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) = 1testEnum(TWO) = 2testEnum(THREE) = 3testEnum(FIVE) = 5testEnum(EIGHT) = 8testTypedef(309858235082523) = 309858235082523Total 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等方式运行,从而获得更好的性能。
http://www.bkjia.com/PHPjc/478823.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/478823.htmlTechArticlephp-thrift-server源码 代码直接从apache的thrift项目clone过来,托管在github上: http://github.com/volca/thrift 新增或改动的代码如下:lib/php/ `-- src |--...
内容总结
以上是互联网集市为您收集整理的php实现的thriftsocketserver_PHP教程全部内容,希望文章能够帮你解决php实现的thriftsocketserver_PHP教程所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。