博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
appnet中使用apcu实现进程间共享数据
阅读量:6257 次
发布时间:2019-06-22

本文共 1289 字,大约阅读时间需要 4 分钟。

  hot3.png

在使用appnet时,如果只开一个worker进程可以使用静态变量来存储全局数据,但若在开启多个woker进程的情况下,静态变量作用域是在当前进程中,每个进程只能读写当前进程的数据,进程与进程间的数据是隔离的。就无法实现共享。这种情况下可以使用APCU扩展来实现进程间数据共享。

apcu前身是apc,大家知道apc缓存分为系统缓存和用户缓存,他们的区别是什么呢?

1、系统缓存是指php执行时增加缓存,减少php文件的反复检查和编译,从而达到系统加速的效果。

2、用户缓存是指,php代码中将数据写入缓存,是用户写入的数据,通过key和value的键值方式插入和读取。这种数据叫做用户缓存。

php5.5以后,opcache将代替apc做为php加速的位置,也就是代替其系统缓存的位置。并将用户缓存功能独立出来,开启新的组件,这个组件名称叫做apcu。

apcu下载地址:http://pecl.php.net/package/APCu

php.ini配置:
apc.enabled=1
apc.shm_size=32M
apc.enable_cli=1

以appnet webchat为例来介绍apcu的用法:

   define( "WORKER_NUM" , 1 );

    private static function setConnlist( $fd , $conn )
    {
        if( WORKER_NUM > 1 )
        {
            $list = apcu_fetch( "webchat_conn_list"  );
            $list[$fd] = $conn;
            apcu_store( "webchat_conn_list" ,  $list );
        }
        else
        {
            self::$connections[$fd] = $conn;
        }
    }
    private static function getConnlist()
    {
        if(  WORKER_NUM > 1 )
        {
            $list = apcu_fetch( "webchat_conn_list"  );
            return $list;
        }
        return self::$connections;
    }

这是webchat中设置或获取连接列表的方法,当用户在聊天室中发送一条消息时,当前用户所在的worker进程需要向所有进程的连接广播消息。所以需要获取全局的连接列表。

程序中对worker数量进行了判断,如果是单进程只需要使用静态变量self::$connections即可。

完整示例见:https://github.com/lchb369/appnet_php7/blob/master/example/server.php

其它可选方案:

redis/memcache:如果要做分布式存储可以使用,否则不推荐,因为redis/memcache需要tcp通信,即便是本地也需要unix domain socket通信,其效率远不如其于共享内存的apcu

转载于:https://my.oschina.net/appnet/blog/689097

你可能感兴趣的文章
我的友情链接
查看>>
公有云中的网络(一)
查看>>
小小自励
查看>>
分布式消息队列中间件系列研究之阿堂教程(进阶篇)
查看>>
一个优秀的系统集成工程师应具备的技能
查看>>
unison双向同步
查看>>
SQL群集实验(一)
查看>>
CCNA笔记之第九节:静态路由
查看>>
读书笔记1
查看>>
利用dispatch_once创建单例
查看>>
Linux常用命令(仅考虑个人情况)
查看>>
synchronized判断锁使用==还是equals?
查看>>
如何在华为交换机上配置基于VLANIF接口地址池的DHCP服务器
查看>>
PCWorld测评的2012版世界级杀毒软件
查看>>
Nexus Repository 安装及使用
查看>>
不做传统OTA要做内容电商,蚂蜂窝缘何推未知旅行?
查看>>
Java集合类说明及区别
查看>>
蚂蚁金服金融级容器引擎实践之路
查看>>
我的友情链接
查看>>
十周三次课(5月29日)
查看>>