Swoole号称重新定义了PHP,它是一个PHP扩展,使得PHP可以利用异步的办法实行,就像node一样,而且还能利用socket,为PHP供应了一系列异步IO、事宜驱动、并行数据构造功能。 Swoole4支持完全的协程编程模式,可以利用完备同步的代码实现异步程序。PHP代码无需额外增加任何关键词,底层自动进行协程调度,实现异步IO 。 nodejs能实现的swoole险些都能实现,而且性能比nodejs更高,毕竟nodejs是单线程的无法充分发挥cpu性能,swoole是多线程的可以充分发挥cpu的性能。 Swoole高效跟传统的web开拓有什么差异,除了传统的LAMP/LNMP同步开拓模式,swoole的异步开拓模式是若何的,如何保持高效?
二、传统web开拓模式
PHP web开拓采取的办法是LAMP/LNMP架构,即Linux、Nginx,Mysql和PHP。这里以nginx来举例,大致构造为:

当要求进入时,web server将要求转交给PHP-FPM,PHP-FPM是一个进程池架构的FastCGI做事,内置PHP阐明器。FPM卖力阐明实行PHP文件天生相应,终极返回给web server,展现至前端。PHP文件中实现了许多业务逻辑,包括Mysql和Nosql的访问,调用第三方运用等等。 这样的构造php-fpm和nginx的合营已经运行得足够好,但是由于php-fpm本身是同步壅塞进程模型,在要求结束后开释所有的资源(包括框架初始化创建的一系列工具),导致PHP进程“空转”(创建<-->销毁<-->创建)花费大量的CPU资源,从而导致单机的吞吐能力有限。
每次要求处理的过程都意味着一次PHP文件解析,环境设置等不必要的耗时操作PHP进程处理完即销毁,无法在PHP程序中利用连接池等技能实现性能优化。
三、Swoole运行模式
针对传统架构的问题,swoole从PHP扩展出发,办理了上述问题,对付swoole的进程模型,我们已经理解过了。
比较于传统架构,Swoole进程模型最大的特点在于其多线程Reactor模式处理网络要求,使得其能轻松应对大量连接。
除此之外的优点还包括:
全异步非壅塞,占用资源开销小,程序实行效率高
程序运行只解析加载一次PHP文件,避免每次要求的重复加载
进程常驻,使得连接池和要求之间信息通报等的实现成为可能
四、为什么要在 Swoole 上运行 Laravel?
Laravel框架启动的时候须要加载很多文件,再加上其出了名的生态环境好,以是在开拓过程中我们就会创造有非常多的已经造好的轮子,这也就使得Laravel的一次启动的磁盘IO特殊高(便是要加载很多文件嘛) laravel生命周期须要在每次要求的时候都实行一遍。由于单个要求创建的环境在要求实行结束后会立即销毁。 换句话说, 在传统的 PHP 生命周期中, 为了脚本实行而摧残浪费蹂躏了大量的韶光去创建和销毁资源。想象一下像 Laravel 这样的框架, 在每次要求中须要加载多少文件? 同时也摧残浪费蹂躏了大量的 I/O 操作。
因此如果我们利用 Swoole 内置一个运用级别的 Server, 并且所有脚本文件在加载一次之后便可以保存在内存中呢? 这便是为什么我们须要考试测验在 Swoole 上运行 Laravel。 Swoole 可以供应强大性能而 Laravel 则可以供应优雅代码构造利用。这俩儿真是完美组合 !
口试题大全,助力你口试成功,大厂必备五、利用Swoole提升Laravel的性能
在现有的轮子中,觉得下面这两个还是非常不错的,可以自行选择
swooletw/laravel-swoolegarveen/laravoole本人选择了第一个来测试 利用composer安装:
composer require swooletw/laravel-swoole
如果你利用的是laravel,那么在 config/app.php 的 providers 数组中加上
SwooleTW\Http\LaravelServiceProvider::class,
如果你利用的是lumen,那么在 bootstrap/app.php 中加入如下代码
$app->register(SwooleTW\Http\LumenServiceProvider::class);
将配置文件导出到 config 目录下
php artisan vendor:publish --provider="SwooleTW\Http\HttpServiceProvider"
然后可以去 config/swoole_http.php 中配置信息
'server' => [ 'host' => env('SWOOLE_HTTP_HOST', '0.0.0.0'),//监听任意ip 'port' => env('SWOOLE_HTTP_PORT', '1215'), 'options' => [ 'pid_file' => env('SWOOLE_HTTP_PID_FILE', base_path('storage/logs/swoole_http.pid')), 'log_file' => env('SWOOLE_HTTP_LOG_FILE', base_path('storage/logs/swoole_http.log')), 'daemonize' => env('SWOOLE_HTTP_DAEMONIZE', 1),//1-程序将转入后台作为守护进程运行 ],],
swoole_http.php 里还供应配置 providers 数组,
'providers' => [ // App\Providers\AuthServiceProvider::class,]
由于利用swoole作为http后,这些providers会被存到内存中,以是这里配置的是每次要求都想要重新注册和重新启动的providers。
现在,你可以实行以下的命令来启动 Swoole HTTP 做事。
$ php artisan swoole:http start
然后你可以看到以下信息:
Starting swoole http server...Swoole http server started: <http://0.0.0.0:1215>
现在可以通过访问http://127.0.0.1:1215 来进入 Laravel 运用。 把稳:该拓展是不支持热启动的,以是每次有代码更新都要重启做事 php artisan swoole:http restart
六、性能测试 利用Apache的ab测试工具
ab -n 1000 -c 10 http://127.0.0.1:1215/
参数解释:-n 1000个要求 -c 10个并发数
图一是利用swoole作为运用做事器,图二是apache做事器 测试环境在虚拟机中,电脑配置也较差,性能没有完备发挥出来,可以看到apache只完成197次要求就扛不住压力了,swoole HTTP做事 完成了压测,性功完备碾压apache做事器。
七、利用Nginx代理
swoole在官网也提到过:swoole_http_server对Http协议的支持并不完全,建议仅作为运用做事器。并且在前端增加Nginx作为代理。 那么,我们就增加须要配置nginx.conf里的server:
server { listen 80; server_name your.domain.com; root /path/to/laravel/public; index index.php; location = /index.php { # Ensure that there is no such file named "not_exists" # in your "public" directory. try_files /not_exists @swoole; } location / { try_files $uri $uri/ @swoole; } location @swoole { set $suffix ""; if ($uri = /index.php) { set $suffix "/"; } proxy_set_header Host $host; proxy_set_header SERVER_PORT $server_port; proxy_set_header REMOTE_ADDR $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # IF https # proxy_set_header HTTPS "on"; proxy_pass http://127.0.0.1:1215$suffix; }}
配置可参考swoole方文档官 Nginx/Apache配置 至此,大功告成,你可以像平常一样访问你的网站了。
八、利用swoole和传统php开拓的缺陷 本文紧张先容了利用swoole作为laravel的应做事器,末了说下利用swoole和传统php开拓的缺陷。 1、更难上手。这哀求开拓职员对付多进程的运行模式有更清晰的认识 2、更随意马虎内存透露。在处理全局变量,静态变量的时候一定要小心,这种不会被GC清理的变量会存在全体生命周期中,如果没有精确的处理,很随意马虎花费完所有的内存。在php-fpm下,php代码实行完内存就会被完备开释。
以上便是swoole运行模式加速laravel运用的详细先容的详细内容
以上内容希望帮助到大家,很多PHPer在进阶的时候总会碰着一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、做事器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微做事、Nginx等多个知识点高等进阶干货须要的可以免费分享给大家,须要的可以加入我的官方群。