您的位置 首页 技术

swoole支持多线程吗?

Reactor线程 Swoole\Server的主进程是一个多线程的程序。其中有一组很重要的线程,称之为Reactor线程。它就是真正处理TCP连接,收发数据的线程。 Swoole…

Reactor线程

Swoole\Server的主进程是一个多线程的程序。其中有一组很重要的线程,称之为Reactor线程。它就是真正处理TCP连接,收发数据的线程。

Swoole的主线程在Accept新的连接后,会将这个连接分配给一个固定的Reactor线程,并由这个线程负责监听此socket。在socket可读时读取数据,并进行协议解析,将请求投递到Worker进程。在socket可写时将数据发送给TCP客户端。

分配的计算方式是fd % serv->reactor_num

由于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支持多线程吗?的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/23648.html

为您推荐

返回顶部