Home  >  Article  >  Backend Development  >  thrift socket server_PHP tutorial implemented in php

thrift socket server_PHP tutorial implemented in php

WBOY
WBOYOriginal
2016-07-13 17:43:27986browse

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 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: 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 does not seem to be widely spread, and there is a tendency to be replaced by other technologies, so I will quote the introduction from other articles below:

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.

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/478823.htmlTechArticlephp-thrift-server source code is directly cloned from apache’s thrift project and hosted on github: http:/ /github.com/volca/thrift The newly added or changed code is as follows: lib/php/ `-- src |--...
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn