下图展示了 PHP 的生命周期。正如你所看到的那样,当你每次运行 PHP 脚本的时候,PHP 都需要初始化模块并为你的运行环境启动 Zend 引擎。并且将 PHP 脚本编译为 OpCodes 以便 Zend 引擎执行。
但是, 这样的生命周期需要在每次请求的时候都执行一遍。因为单个请求创建的环境在请求执行结束后会立即销毁。
换句话说, 在传统的 PHP 生命周期中, 为了脚本执行而浪费了大量的时间去创建和销毁资源。想象一下像 Laravel 这样的框架, 在每次请求中需要加载多少文件?同时也浪费了大量的 I/O 操作
因此如果我们利用 Swoole 内置一个应用级别的 Server, 并且所有脚本文件在加载一次之后便可以保存在内存中呢? 这就是为什么我们需要尝试在 Swoole 上运行 Laravel。 Swoole 可以提供强大性能而 Laravel 则可以提供优雅代码结构使用。这俩儿真是完美组合!
以下是 swooletw/laravel-swoole 的主要特点:
在 Swoole 运行 Laravel/Lumen 应用出色的性能提升至 30x沙盒模式隔离应用程序容器支持在 Laravel 应用中运行 WebSocket 服务器支持 Socket.io 协议支持 Swoole 表跨进程共享使用 Composer 安装:
$ composer require swooletw/laravel-swoole这个包依赖于 Swoole 。在使用这个包之前,请确保你的机器安装了正确的 Swoole 。使用下面的命令快速安装(linux):
pecl install swoole在安装这个扩展之后,你需要编辑 php.ini 添加 extension=swoole.so。
php -i | grep php.ini # check the php.ini file location sudo echo "extension=swoole.so" >> php.ini # add the extension=swoole.so to the end of php.ini php -m | grep swoole # check if the swoole extension has been enabled
访问 官网 获取更多的信息。
注意:Swoole 现在只支持 Linux 和 OSX 。Windows 服务器现在还不支持。
然后,添加服务提供者:
如果你使用 Laravel ,在 config/app.php 服务提供者数组添加该服务提供者:
[ 'providers' => [ SwooleTW\Http\LaravelServiceProvider::class, ], ]
现在,你可以执行以下的命令来启动 Swoole HTTP 服务。
$ php artisan swoole:http start然后你可以看到以下信息:
Starting swoole http server... Swoole http server started: <http://127.0.0.1:1215>现在可以通过访问 http://127.0.0.1:1215 来进入 Laravel 应用。
转载于:https://www.cnblogs.com/vania/p/11263709.html