分享關于laravel-octane的體驗及壓測

下面由laravel教程欄目給大家介紹laravel-octane 體驗及壓測,希望對需要的朋友有所幫助!

laravel-octane 必須在 php8 之上運行,無奈本地的 Mamp 最高還是 php7,所以只能用 docker 跑一下啦。

創建容器

在本地開個docker工作目錄,方便映射和編輯項目代碼。

mkdir ~/workspace/docker/ -p && cd ~/workspace/docker/  docker run -it --name php8  -v "$PWD":/exports/apps  -w /exports/apps --entrypoint="/bin/bash"  -p 8081:8081  php:8.0.3-cli

這里用 swoole 加持吧, roadrunner 沒用過,后面再說。

容器部署

組件、依賴都在容器中解決

# 登錄容器 docker exec -it php8 /bin/bash
# 不更新拉不到安裝包 fk apt-get update && apt-get upgrade apt-get install libzip-dev apt-get install apache2-utils apt-get install net-tools apt-get install inetutils-ping  # 熱加載用的 node chokidar 需要話可以安裝npm apt-get install nodejs npm npm config set registry https://registry.npm.taobao.org  # 在拉取 composer 包時需要 否則用 git 去拉源碼那叫一個慢喲 pecl install zip pecl install swoole echo extension=zip.so >> /usr/local/etc/php/conf.d/docker-php-ext-sodium.ini echo extension=swoole.so >> /usr/local/etc/php/conf.d/docker-php-ext-sodium.ini  # 安裝 pcntl octane 信號通信需要 docker-php-ext-install pcntl docker-php-ext-install pdo_mysql  php -m
安裝 composer
curl -sS https://getcomposer.org/installer | php mv composer.phar /usr/local/bin/composer composer --version composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
創建 laravel && octane
composer create-project laravel/laravel --prefer-dist -vvv laravel_octane cd laravel_octane  # 安裝 octane composer require laravel/octane php artisan octane:install  php artisan key:generate  # .env # 數據庫我用的宿主機的 # mac 容器訪問宿主機 mysql 使用 docker.for.mac.host.internal 即可 DB_CONNECTION=mysql DB_HOST=docker.for.mac.host.internal DB_PORT=3306 DB_DATABASE=laravel_octane DB_USERNAME=root DB_PASSWORD=123456
啟動服務

–watch

#需要熱加載 --watch 請安裝 npm && chokidar npm install chokidar
php artisan octane:start --host="0.0.0.0" --port=8081 --workers=4 --max-requests=10000 --task-workers=10
訪問測試
curl -XGET http://127.0.0.1:8081/
壓測代碼

諸位自取

app/Http/Kernel.php 注釋掉 throttle:api

        'api' => [             // 'throttle:api',             // IlluminateRoutingMiddlewareSubstituteBindings::class,         ],

routes/api.php

Route::any('/db', [AppHttpControllersIndexController::class, 'db']);

app/Http/Controllers/IndexController.php

<?php  namespace AppHttpControllers;  use AppModelsTest; use IlluminateHttpRequest;  class IndexController extends Controller {     public function db()     {         $nameList  = ['james', 'lucy', 'jack', 'jessica', 'lily'];         $hobbyList = ['football', 'basketball', 'swimming'];          $name  = $nameList[array_rand($nameList)];         $hobby = $hobbyList[array_rand($hobbyList)];          if (mt_rand(0, 5) >= 2) {// 0-1讀 2-5寫             $test        = new Test();             $test->name  = $name;             $test->age   = 18;             $test->sex   = 1;             $test->hobby = $hobby;             $test->save();             $data = ['id' => $test->id];         } else {             $data = Test::query()->where('hobby', $hobby)->first();;         }          return $data;     } }

app/Models/Test.php

<?php  namespace AppModels;  use IlluminateDatabaseEloquentFactoriesHasFactory; use IlluminateDatabaseEloquentModel;  /**  * Class Test  *  * @package AppModels  * @property int id  * @property string name  * @property int age  * @property string sex  * @property string hobby  */ class Test extends Model {     use HasFactory;      /**      * @var string      */     protected $table = 'test';      const CREATED_AT = null;     const UPDATED_AT = null; }

sql

CREATE TABLE `test` (   `id` int unsigned NOT NULL AUTO_INCREMENT,   `name` varchar(50) COLLATE utf8mb4_general_ci NOT NULL,   `age` int NOT NULL,   `sex` char(1) COLLATE utf8mb4_general_ci NOT NULL,   `hobby` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL,   PRIMARY KEY (`id`),   KEY `idx_hobby` (`hobby`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci

壓測結果

結果讓我有些懷疑自我,暫不發,大家自行壓測吧。

以上就是分享關于

? 版權聲明
THE END
喜歡就支持一下吧
點贊14 分享