定制 wedesignit/laravel-performance 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

wedesignit/laravel-performance

最新稳定版本:v1.0.1

Composer 安装命令:

composer require wedesignit/laravel-performance

包简介

Optimize your code even before it hits production

README 文档

README

This performance package (currently) contains two configurable performance related features which you can use to identify potential slow parts in your application:

  • Slow query logging
  • Force eager loading (use in development!)

Include the package

For dev-only (be sure to read the note below) use:

composer require --dev wedesignit/laravel-performance

!! Note that if you use the ContainsUnEagerLoadableRelations trait in your code, this will cause errors in production. You might want to require the package (without --dev) !!

For using it on other environments too:

composer require wedesignit/laravel-performance

Publishing the config

php artisan vendor:publish --provider="WeDesignIt\LaravelPerformance\Providers\LaravelPerformanceServiceProvider" --tag="config"

Slow query logging

config

The package can log slow queries. To do this, either

  • enable this in the config or
  • set an environment key ENABLE_SLOW_QUERY_LOGGING=true

Then, configure the threshold: this is the amount of milliseconds after which you consider a query to be "slow"

logging

The package will look for a query channel for logging. You can create your own channel called query in config/logging.php to define where you want the slow queries to be logged. If you don't define it, the query channel will be temporarily created using the following config:

[
    'driver' => 'daily',
    'path'   => storage_path('logs/query.log'),
    'level'  => env('LOG_LEVEL', 'debug'),
    'days'   => 2,
]

This means: by default the slow queries will be logged in a query.log file prefixed with date (due to the daily driver) and kept for 2 days, in the (default) logs folder storage/app/logs.

what's being logged

The following details are logged per entry:

  • SQL
  • Query bindings
  • Time took
  • The file with the code that triggered the query
  • The line in the file on which the code is

Force eager loading

Eager loading relationships can greatly speed up your application by eliminating subsequent queries. By enabling forced eager loading, an exception will be thrown when a relationship is not eager loaded so you can decide if it's right to eager load that relationship.

Note: forced eager loading will NOT be enabled in production!

config

To enable this feature:

  • enable this in the config or
  • set an environment key ENABLE_FORCED_EAGER_LOADING=true

After this, pages or code which use a not-eager-loaded relationship will throw an Exception telling you which relationship wasn't eager loaded on which model.

UnEagerLoadableRelations

Some relationships should not be eager loaded, but would also yield an Exception according to the above setting. If a model contains one or more relationships that cannot or should not be eager loaded, use the ContainsUnEagerLoadableRelations trait.

Then, use a property array $without on the Model(s) using the trait to prevent the relations in the $without from throwing eager loading exceptions.

<?php

use WeDesignIt\LaravelPerformance\Traits\ContainsUnEagerLoadableRelations;

class Car {

    use ContainsUnEagerLoadableRelations;

    protected $with = [
        'windows', 'lights',
    ];

    protected array $without = [
        'wheels',
    ];
}

统计信息

  • 总下载量: 9.27k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-12-16

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固