swoole是使用多进程模式吗

这篇文章给大家分享的是有关swoole是使用多进程模式吗的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

创新互联公司2013年成立,先为阜城等服务建站,阜城等地企业,进行企业商务咨询服务。为阜城企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

由于PHP语言不支持多线程,因此Swoole使用多进程模式。在多进程模式下存在进程内存隔离,在工作进程内修改global全局变量和超全局变量时,在其他进程是无效的。           

设置worker_num=1时,不存在进程隔离,可以使用全局变量保存数据

进程隔离

$fds = array();
$server->on('connect', function ($server, $fd){
    echo "connection open: {$fd}\n";
    global $fds;
    $fds[] = $fd;
    var_dump($fds);
});

$fds 虽然是全局变量,但只在当前的进程内有效。Swoole服务器底层会创建多个Worker进程,在var_dump($fds)打印出来的值,只有部分连接的fd。

对应的解决方案就是使用外部存储服务:

数据库,如:MySQL、MongoDB
缓存服务器,如:redis、Memcache
磁盘文件,多进程并发读写时需要加锁

普通的数据库和磁盘文件操作,存在较多IO等待时间。因此推荐使用:

Redis 内存数据库,读写速度非常快
/dev/shm 内存文件系统,读写操作全部在内存中完成,无IO消耗,性能极高
除了使用存储之外,还可以使用共享内存来保存数据

感谢各位的阅读!关于“swoole是使用多进程模式吗”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


文章题目:swoole是使用多进程模式吗
当前URL:http://bzwzjz.com/article/iesiis.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站建设 网站建设开发 成都网站建设 成都模版网站建设 网站建设改版 网站建设方案 成都网站制作 成都响应式网站建设 网站建设 高端网站设计 成都营销网站制作 移动网站建设 手机网站制作 上市集团网站建设 手机网站建设 定制网站设计 重庆企业网站建设 重庆外贸网站建设 成都网站设计 成都网站建设推广 泸州网站建设 商城网站建设