zoukankan      html  css  js  c++  java
  • 使用 Swoole 来加速你的 Laravel 应用

    为什么要在 Swoole 上运行 Laravel?

    下图展示了 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' => [
            SwooleTWHttpLaravelServiceProvider::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 应用。

  • 相关阅读:
    转载 | CSS文本溢出显示省略号
    转载 | CSS书写顺序
    转载 | CSS布局大全
    threejs sprite 制作标签
    typeScript 中的类
    Es5中的类
    typeScript中的函数
    websocket在vue项目中的使用
    typeScript中的变量数据类型
    echarts 中的1/4圆环行图的使用
  • 原文地址:https://www.cnblogs.com/vania/p/11263709.html
Copyright © 2011-2022 走看看