常见关于swoole的⾯试题
⽂章⽬录
⼀、为什么你要⽤swoole,能解决你项⽬中的哪些痛点?
swoole是⼀个⽹络通讯和异步IO的引擎,⼀个基础库;
swoole相⽐于apache/fpm,主要节省了PHP框架和全局对象每次创建销毁带来的性能开销,是进程常驻内存型。
⼆、你是如何通过swoole提升性能的,怎么做的?
1. 进程常驻内存:
swoole本⾝是进程常驻内存,在进程启动的时候就将PHP框架等代码读取并编译完成,不需要每次启动的时候都执⾏编译步骤,⼤⼤降低了脚本的运⾏时间;
2. 连接池
php-fpm的模式php因为每次请求结束时都会销毁所有资源,因此⽆法使⽤连接池;⽽基于swoole的进程
常驻内存模式,可以通过连接池的⽅式来加速程序,
使⽤连接池既可以降低程序的响应时间,⼜可以有效保护后端资源。
3. 可以使⽤协程处理异步IO
当开发中需要去请求多处的数据,⽽每⼀块的数据单独请求都要花较长时间,常规的php-fpm是阻塞式运⾏,⽆法对这类型的数据处理进⾏加速;⽽基于swoole的程序,可以将这类的业务并⾏化处理,并⾏去请求后端的数据源,能够⼤⼤优化了此类业务的运⾏时间。
三、swoole⾥的协程是什么,怎么⽤?为什么协程可以提⾼并发?
协程是通过协作⽽不是抢占的⽅式来进⾏切换,它创建和切换对内存等资源⽐线程⼩的多(可以理解为更⼩的线程);
协程的使⽤是通过Swoole\Coroutine或者Co\命名空间短命名简化类名来创建;
协程可以异步处理任务,⽀持并发,并且资源消耗⼩。
四、⽤了swoole以后,会不会发⽣内存泄漏?如果发⽣了怎么解决?
swoole由于是常驻内存,⼀旦资源加载进⼊后,会⼀直存在于内存中。对于局部变量,swoole会在回调函数结束后⾃动释放;对于全局变量(lobal声明的变量,
static声明的对象属性或者函数内的静态变量和超全局变量),swoole不会⾃动释放;因此操作不好会发⽣内存泄漏。php如何运行代码
解决:
在onClose回调内清理变量;
swoole提供了max_request和max_task_request机制:进程完成指定数量的任务后,会⾃动退出,达到释放资源和内存的⽬的;⽽后manager进程会重新拉起新worker/task进程来继续处理任务。
使⽤限制:
max_request只能⽤于同步阻塞、⽆状态的请求响应式服务器程序;
纯异步的Server不应当设置max_request
使⽤Base模式时max_request是⽆效的
五、swoole和php-fpm的区别
PHP-FPM:
早期版本的 PHP 并没有内置的 WEB 服务器,⽽是提供了 SAPI(Server API)给第三⽅做对接。现在⾮常流⾏的 php-fpm 就是通过FastCGI 协议来处理 PHP 与第三⽅ WEB 服务器之间的通信。⽐如 Nginx + php-fpm 的组合,这种⽅式运⾏的 fpm 是
Master/Worker 模式,启动⼀个 Master 进程监听来⾃ Nginx 的请求,再 fork 多个 Worker 进程处理请求。每个 Worker 进程只能处理⼀个请求,单⼀进程的⽣命周期⼤体如下:
1. 初始化模块。
2. 初始化请求。此处请求是请求 PHP 执⾏代码的意思,并⾮ HTTP 的请求。
3. 执⾏ PHP 脚本。
4. 结束请求。
5. 关闭模块。
多进程模型是依赖进程数来解决并发问题,⼀个进程只能处理⼀个连接,当启动⼤量进程,进程调度消耗可能占 CPU 的百分之⼏⼗甚⾄100%,⽐如 C10K 问题,多进程模型就⼒不从⼼了。
Swoole:
Swoole 采⽤的也是 Master/Worker 模式,不同的是 Master 进程有多个 Reactor 线程,Master 只是⼀个事件发⽣器,负责监听Socket 句柄的事件变化。Worker 以多进程的⽅式运⾏,接收来⾃ Reactor 线程的请求,并执⾏回调函数(PHP 编写的)。启动 Master 进程的流程⼤致是:
1. 初始化模块。
2. 初始化请求。因为 swoole 需要通过 cli 的⽅式运⾏,所以初始化请求时,不会初始化 PHP 的全局变量,如 $_SERVER, $_POST,
$_GET 等。
3. 执⾏ PHP 脚本。包括词法、语法分析,变量、函数、类的初始化等,Master 进⼊监听状态,并不会结束进程。
Swoole 加速的原理
由 Reactor(epoll 的 IO 复⽤⽅式)负责监听 Socket 句柄的事件变化,解决⾼并发问题。
通过内存常驻的⽅式节省 PHP 代码初始化的时间,在使⽤笨重的框架时,⽤ swoole 加速效果是⾮常明显的。
对⽐不同
PHP-FPM
Master 主进程 / Worker 多进程模式。
启动 Master,通过 FastCGI 协议监听来⾃ Nginx 传输的请求。
每个 Worker 进程只对应⼀个连接,⽤于执⾏完整的 PHP 代码。
PHP 代码执⾏完毕,占⽤的内存会全部销毁,下⼀次请求需要重新再进⾏初始化等各种繁琐的操作。
只⽤于 HTTP Server。
Swoole
Master 主进程(由多个 Reactor 线程组成)/ Worker 多进程(或多线程)模式
启动 Master,初始化 PHP 代码,由 Reactor 监听 Socket 句柄的事件变化。
Reactor 主线程负责⼦多线程的均衡问题,Manager 进程管理 Worker 多进程,包括 TaskWorker 的进程。每个 Worker 接受来⾃ Reactor 的请求,只需要执⾏回调函数部分的 PHP 代码。
只在 Master 启动时执⾏⼀遍 PHP 初始化代码,Master 进⼊监听状态,并不会结束进程。
不仅可以⽤于 HTTP Server,还可以建⽴ TCP 连接、WebSocket 连接。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论