laravel-octane 體驗及壓測

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

建立容器

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

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 沒用過,後面再說。mysql

容器部署

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

# 登陸容器
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
啓動服務

--watchgit

#須要熱加載 --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/
壓測代碼

諸位自取sql

app/Http/Kernel.php 註釋掉 throttle:apidocker

'api' => [
            // 'throttle:api',
            // \Illuminate\Routing\Middleware\SubstituteBindings::class,
        ],

routes/api.php數據庫

Route::any('/db', [\App\Http\Controllers\IndexController::class, 'db']);

app/Http/Controllers/IndexController.phpapache

<?php

namespace App\Http\Controllers;

use App\Models\Test;
use Illuminate\Http\Request;

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.phpnpm

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;

/**
 * Class Test
 *
 * @package App\Models
 * @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

壓測結果

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

相關文章
相關標籤/搜索