php-thrift-server source code
The code is directly cloned from apache’s thrift project and hosted on github:
http://github.com/volca/thrift
The newly added or changed codes are as follows:
lib/php/
`-- src
|-- server
| |-- TNonblockingServer.php
| `-- TServer.php
`-- transport
🎜>|-- TestNonblockingServer.php
Usage example
Obtain the source code of thrift and compile the thrift tool. Please search for the compilation process
git clone git://github.com/volca/thrift.git to install php, apc, and libevent extensions:
pecl install apc#You need to first install libevent-devel and other packages pecl install libevent to run the php socket server. I directly modified an independently running php server from the thrift test code, see thrift/test/php/ TestNonblockingServer.php, which also contains an implementation of test business code.
cd thrift/test/php#Use thrift command line tool to generate php test library make#Start the thrift service, which will listen to the local port 9090 php TestNonblockingServer.php client code is also provided, for various data Types such as int, float, string, list, etc. are tested.
php TestClient.php performance test
apache + php test resultsTestvoid () = Voidtestring ("Test") = "Test" Testbyte (1) = 1Testi32 (-1) = -1Testi64 (-34359738368) = -34359738368Testdouble (-852342342344424 ) = -852.234234234testruct ({"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 test results
Testvoid () = Voidtestring ("Test") = "Test" Testbyte (1) = 1Testi32 (-1) = -1Testi64 (-34359738368) = -34359738368Testdouble (-852342342344424 ) = -852.234234234testruct ({"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 In this test, there are no long-time requests, and the processing logic is complete Similarly, php socket server takes only one-fifth of apache + php.
What is thrift?
Thrift consists of a software library and a series of code generation tools, developed by Facebook. The purpose is to speed up software development and enable efficient and scalable backend services. The main goal is to achieve efficient and reliable communication between different programming languages, which requires abstracting a common layer between different languages, and then implementing this common layer in different languages. It should be noted here that Thrift allows developers to define data types and service interfaces (defined in a neutral language file), and use this file to generate the code required to build RPC clients and servers.
A brief analysis of its mechanism shows that Thrift implements the C/S mode and generates server-side and client-side code (can be in different languages) from the interface definition file through a code generation tool, thereby achieving cross-language support for the server and client.
Thrift can be divided into transport layer and protocol layer:
The transport layer defines the data transmission method, which can be in the form of TCP/IP transmission, memory sharing or file sharing;
The protocol layer defines the data transmission format, which can be in the form of binary stream or XML.When the server uses the socket protocol, it can be run in simple|thread-pool|threaded|nonblocking to obtain better performance.