php thrift 扩展使用,GitHub - wfxiang08/smthrift: thrift的php扩展,将socket, 数据序列化全部封装在C++扩展中,支持长连接和unix domai...

随着业务规模增长,PHP项目常转向服务化架构,将部分业务用高效语言实现为独立服务。然而HTTP并非高效RPC协议。smthrift是一个PHP扩展,为TCP长连接提供便利。它封装socket,使每个fastcgi进程保持连接,减少维护和开发成本。通过示例代码展示了如何使用smthrift与ThriftRPC服务进行交互。
摘要由CSDN通过智能技术生成

smthrift

smthrift是为了实现RPC通信中TCP长连接而开发的PHP扩展

简介

PHP很多项目随着业务规模的增长(尤其是终端众多的情况下)逐渐向服务化演变,常见的一种架构模型是将相对独立或者比较耗时的业务抽象为单独的服务(如用户模块)使用c/c++、golang等更高效的语言处理,具体的业务层(如:网页端、移动端)来调用各个服务,这种架构大大降低了各业务之间的耦合度,同时最大限度的提高了模块的重用性。

业务层与后端的服务之间的通信协议中,http并不是一种高效的rpc协议。事实上php中有众多的扩展可以为我们提供很好的范例,如:mysql、memcached等等都是最常见不过的"服务"了,我们完全可以采用它们的客户端处理方式。

mysql、memcached这些扩展都是采用TCP与服务端进行通信,你肯定记得他们都有长连接的连接方式,有兴趣的同学可以去翻一下它们的源码。

如果像mysql、memcached那样将协议的处理也封装在php扩展中,那么意味着每增加一个服务我们都需要安装一个扩展,这样将很不利于维护,同时也会降低开发效率。

smthrift对socket进行了一层简单的封装,将连接放在persistent_list哈希表中,每个fastcgi进程连接后不会被释放,下次请求时直接使用。目前最大的连接数等于fastcgi进程数,当然你也可以自行修改下实现连接池的效果。

使用smthrift可以将协议相关的逻辑也使用php实现,可以大大降低开发成本,smthrift/example/memcache_client.php提供了一个简单的memcache客户端的示例。

安装

从github下载源码后解压

cd smthrift

For Mac OS

/usr/local/Cellar/php71/7.1.5_17/bin/phpize

./configure --with-php-config=/usr/local/Cellar/php71/7.1.5_17/bin/php-config --enable-debug

For linux:

/usr/local/php7/bin/phpize

./configure --with-php-config=/usr/local/php7/bin/php-config

剩余步骤:

./configure

make -j 3 && make install

最后将extension=smthrift.so加入php.ini,重启php-fpm或者其他fastcgi

php --info | grep ini 可以找到php.ini的位置

使用

$sock = new SmSocket(string $host, string $port, bool $strict_write, bool $strict_read);

//connect

$r = $sock->pconnect([ int $timeoutms ]); //超时时间,单位:毫秒

if(false === $r){

exit();

}

//write

$sock->write(string $msg);//返回false时可以调用$sock->pclose()关闭再重连$sock->pconnect()

//read

$msg = $sock->read(int $len);//返回false时可以调用$sock->pclose()关闭再重连$sock->pconnect()

// 配合Thrift RPC服务:

$sock = new SmSocket('127.0.0.1', 5563, true, true);

$sock->pconnect(200);

$client = new GeoIpServiceClient($sock);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值