登录  /  注册
首页 > php框架 > Laravel > 正文

分享关于laravel-octane的体验及压测

藏色散人
发布: 2021-06-09 15:13:34
转载
3293人浏览过

下面由laravel/" target="_blank">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',
            // \Illuminate\Routing\Middleware\SubstituteBindings::class,
        ],
登录后复制

routes/api.php

Route::any('/db', [\App\Http\Controllers\IndexController::class, 'db']);
登录后复制

app/Http/Controllers/IndexController.php

<?php namespace App\Http\Controllers;

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

class IndexController extends Controller
{
    public function db()
    {
        $nameList  = [&#39;james&#39;, &#39;lucy&#39;, &#39;jack&#39;, &#39;jessica&#39;, &#39;lily&#39;];
        $hobbyList = [&#39;football&#39;, &#39;basketball&#39;, &#39;swimming&#39;];

        $name  = $nameList[array_rand($nameList)];
        $hobby = $hobbyList[array_rand($hobbyList)];

        if (mt_rand(0, 5) >= 2) {// 0-1读 2-5写
            $test        = new Test();
            $test-&gt;name  = $name;
            $test-&gt;age   = 18;
            $test-&gt;sex   = 1;
            $test-&gt;hobby = $hobby;
            $test-&gt;save();
            $data = ['id' =&gt; $test-&gt;id];
        } else {
            $data = Test::query()-&gt;where('hobby', $hobby)-&gt;first();;
        }

        return $data;
    }
}
登录后复制

app/Models/Test.php

<?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 = &#39;test&#39;;

    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
登录后复制

压测结果

结果让我有些怀疑自我,暂不发,大家自行压测吧。


以上就是分享关于laravel-octane的体验及压测的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
相关标签:
来源:segmentfault网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号