最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

swoole是多进程还是多线程

来源:动视网 责编:小采 时间:2020-11-03 18:23:40
文档

swoole是多进程还是多线程

swoole是多进程还是多线程:由于PHP语言不支持多线程,因此Swoole使用多进程模式。在多进程模式下存在进程内存隔离,在工作进程内修改global全局变量和超全局变量时,在其他进程是无效的。 (推荐学习: swoole视频教程)设置worker_num=1时,不存在进程隔离,可以使用全局变量保存数据
推荐度:
导读swoole是多进程还是多线程:由于PHP语言不支持多线程,因此Swoole使用多进程模式。在多进程模式下存在进程内存隔离,在工作进程内修改global全局变量和超全局变量时,在其他进程是无效的。 (推荐学习: swoole视频教程)设置worker_num=1时,不存在进程隔离,可以使用全局变量保存数据


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

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

进程隔离

$fds = array();
$server->on('connect', function ($server, $fd){
 echo "connection open: {$fd}
";
 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是多进程还是多线程:由于PHP语言不支持多线程,因此Swoole使用多进程模式。在多进程模式下存在进程内存隔离,在工作进程内修改global全局变量和超全局变量时,在其他进程是无效的。 (推荐学习: swoole视频教程)设置worker_num=1时,不存在进程隔离,可以使用全局变量保存数据
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top