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
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/
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
git
#須要熱加載 --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:api
docker
'api' => [ // 'throttle:api', // \Illuminate\Routing\Middleware\SubstituteBindings::class, ],
routes/api.php
數據庫
Route::any('/db', [\App\Http\Controllers\IndexController::class, 'db']);
app/Http/Controllers/IndexController.php
apache
<?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.php
npm
<?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
結果讓我有些懷疑自我,暫不發,你們自行壓測吧。