PHP 很多项目随着业务规模的增长(尤其是终端众多的情况下)逐渐向服务化演变,常见的一种架构模型是将相对独立或者比较耗时的业务抽象为单独的服 务(如用户模块)使用c/c++、golang等更高效的语言处理,具体的业务层(如:网页端、移动端)来调用各个服务,这种架构大大降低了各业务之间的 耦合度,同时最大限度的提高了模块的重用性。
业务层与后端的服务之间的通信协议中,http并不是一种高效的rpc协议。事实上php中有众多的扩展可以为我们提供很好的范例,如:mysql、memcached等等都是最常见不过的"服务"了,我们完全可以采用它们的客户端处理方式。
mysql、memcached这些扩展都是采用TCP与服务端进行通信,你肯定记得他们都有长连接的连接方式,有兴趣的同学可以去翻一下它们的源码。
如果像mysql、memcached那样将协议的处理也封装在php扩展中,那么意味着每增加一个服务我们都需要安装一个扩展,这样将很不利于维护,同时也会降低开发效率。
foolsock对socket进行了一层简单的封装,将连接放在persistent_list哈希表中,每个fastcgi进程连接后不会被释放,下次请求时直接使用。目前最大的连接数等于fastcgi进程数,当然你也可以自行修改下实现连接池的效果。
使用foolsock可以将协议相关的逻辑也使用php实现,可以大大降低开发成本,foolsock/example/memcache_client.php提供了一个简单的memcache客户端的示例。
example/memcache_client.php提供了一个简单的memcache客户端的例子(使用memcache二进制协议),实现memcache两个基本操作:Add/Get,经过测试处理效率与使用memcache扩展相当
转自 http://www.oschina.net/p/foolsock
版权声明 Copyright 2015-2017 by 南京微云信息科技有限公司 All rights reserved 苏ICP备11018666号-8 本站尊重原创,转载请注明出处并附链接