Swoole提供了完善的进程管理机制,当Worker进程异常退出,如发生PHP的致命错误、被其他程序误杀,或达到max_request次数之后正常退出。 (推荐学习: swoole视频教程)
主进程会重新拉起新的Worker进程。 Worker进程内可以像普通的apache+php或者php-fpm中写代码。
swoole_server线程模式
这个就是多线程Worker模式,Reactor线程来处理网络事件轮询,读取数据。得到的请求交给Worker线程去处理。
Swoole提供了可配置的参数,以实现m/n的参数调整。
在这种模式下onReceive可以有适度的阻塞操作。多线程模式比进程模式轻量一些,而且线程之间可以共享堆栈和资源。
访问共享内存时会有同步问题,需要使用Swoole提供的锁机制来保护数据。
目前已经提供了Mutex、读写锁、文件锁、信号量、自旋锁一共5种锁的实现。
多线程的优点:
对象和变量是共享的,可直接进行操作
文件描述符是共享的,不同的线程可以对同一个资源直接进行操作
多线程的缺点:
操作非局部变量时需要加锁,编程难度高
一个线程发生内存错误,整个进程会全部结束
由于PHP的ZendVM在多线程模式存在内存错误,多线程模式在v1.6.0版本后已关闭
Atas ialah kandungan terperinci swoole worker有事件轮询吗. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!