Laravel Медленные запросы - PullRequest
10 голосов
/ 10 июля 2020
public function delete( ReportDetailRequest $request )
    {
        $id = (int)$request->id;
        $customerRecord = CustomerInfo::find($id);
        $customerRecord->delete();
    }

В настоящее время у меня есть указанное выше в приложении laravel, где этому контроллеру отправляется запрос DELETE. На данный момент, как видите, это очень просто, но запрос кажется очень медленным. Он возвращается в почтальоне через 2,23 секунды. Что я должен попытаться ускорить? Уровень базы данных (mysql) действительно имеет индекс по идентификатору, насколько я могу судить, и приложение не работает в режиме отладки. Это типично?

edit: Хорошая мысль, что проверка запроса может что-то делать (это подтверждает, что этот пользователь имеет авторизацию для удаления).

class ReportDetailRequest extends FormRequest
{
    /**
     * Determine if the user is authorized to make this request.
     *
     * @return bool
     */
    public function authorize()
    {
        $id = (int)$this->route('id');
        $customerInfo = CustomerInfo::find($id)->first();
        $company = $customerInfo->company_id;
        return (auth()->user()->company->id  == $company );
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules()
    {
        return [
            //
        ];
    }
}

Показать таблицу создания:

CREATE TABLE "customer_info" (
  "id" int(11) NOT NULL AUTO_INCREMENT,
  "user_id" int(11) DEFAULT NULL,
  "report_guid" varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL,
  "customer_email" varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  "created_at" timestamp NULL DEFAULT NULL,
  "updated_at" timestamp NULL DEFAULT NULL,
  "report_read" tinyint(1) NOT NULL,
  "customer_name" varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  "customer_support_issue" longtext CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci,
  "company_id" int(11) NOT NULL,
  "archived" tinyint(1) NOT NULL,
  "archived_at" timestamp NULL DEFAULT NULL,
  "report_active" tinyint(4) DEFAULT NULL,
  "customer_screenshot" varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  "video_url" varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  PRIMARY KEY ("id"),
  KEY "indexReportLookup" ("report_guid"),
  KEY "guid" ("report_guid"),
  KEY "customer_info_id_index" ("id")
)

Исходный уровень:

 public function delete( Request $request )
    {
        // $id = (int)$request->id;
        // $customerRecord = CustomerInfo::find($id);
        // $foo_sql = $customerRecord->delete()->toSql();
        // echo($foo_sql);
        return 'test';
        //$customerRecord->delete();
    }

test response.

Ok so a brand new table, with a brand new Request. with a single ID in it, looks like this:

enter image description here

The controller looks like:

public function deleteTest( Request $request )
    {
        $id = (int)$request->id;
        $customerRecord = NewTable::where('id', '=', $id)->first();
        $customerRecord->delete();
        return response(null, 200);
    }

Postman version is :Version 7.27.1 (7.27.1)

1630 ms. WTF. 1.6 seconds for a simple request on a new table.

EXPLAIN DELETE:

1   DELETE  new_tables      range   PRIMARY PRIMARY 8   const   1   100 Using where

EXPLAIN SELECT

1   SIMPLE  new_tables      const   PRIMARY PRIMARY 8   const   1   100 Using index

MYSQL version 8.0.18 innodb_version 8.0.18


So now to add to the fun.

A framework free PHP file. Simple GET request. 100ms.

<?php
echo('tester');
?>

введите описание изображения здесь

Редактировать. Просто повторим.

A Laravel Метод GET (с аутентификацией), возвращающий тест, возвращает 1,6 с.

Файл «образец без фреймворка». php »возвращается через 100 мс. .

Метод Laravel GET (без аутентификации) возвращает тест, возвращается через 430 мс.

A Laravel Метод GET (без аутентификации, но с доступом к БД), возвращается через 1483 мс.

Похоже, что что-то действительно задерживает запросы, когда приложение начинает использовать базу данных.

Route::middleware('auth:api')->get('/test1','Api\CustomerInfoController@deleteTest')->name('report.deleteTest1.api');
Route::middleware('auth:api')->get('/test2','Api\NewTableController@index')->name('report.deleteTest2.api');

Route::get('/test3','Api\CustomerInfoController@deleteTest')->name('report.deleteTest3.api');
Route::get('/test4','Api\NewTableController@index')->name('report.deleteTest4.api');
 Route::get('/test5','Api\NewTableController@dbTest')->name('report.deleteTest5.api');

NewTableController:

<?php

namespace App\Http\Controllers\Api;

class NewTableController extends Controller
{

    
    public function index()
    {
        return "test2";
    }



}

CustomerInfoController (с некоторыми удаленными элементами, но метод концептуально очень похож на NewTableController, хотя и с некоторой инъекцией зависимостей).

<?php

namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Http\Requests\ReportDetailRequest;
use App\Services\CustomerInfoService;
use Auth;
use App\LookupParent;
use App\LookupChild;
use App\CustomerInfo;
use App\Http\Resources\CustomerInfoResourceCollection;
use App\Http\Resources\CustomerInfoResource;
use App\Http\Resources\CustomerInfoResourceDetail;
use Carbon\Carbon;
use App\NewTable;

class CustomerInfoController extends Controller
{
    protected $customerInfoService;

    public function __construct(
        CustomerInfoService $customerInfoService
        )
    {
        $this->customerInfoService = $customerInfoService;
    }


    public function deleteTest()
    {
        return 'deleteTest';
    }


   public function dbTest()
   {   
     tap(NewTable::find(1))->delete();
   }


}

Результаты:

/test1 (with authentication 1380ms)
/test2 (with authentication 1320ms)
/test3 (without authentication 112ms)
/test4 (without authentication 124ms)
/test5 (db without authentication 1483ms)

Другими словами, аутентификация обращается к базы данных, как и простой запрос на удаление без аутентификации. На выполнение каждого из них уходит не менее секунды. Это приводит к примерно двухсекундному запросу, упомянутому выше, который имеет оба элемента (аутентификация и доступ к базе данных).

Мне нужно попытаться получить контроль над скоростью моей управляемой базы данных DO.

1 Ответ

0 голосов
/ 21 июля 2020

Mysql 8 вводятся двоичный журнал при запуске. Чтобы отключить бинарный вход в Mysql 8, вам нужно запустить сервер MySQL с --disable-log-bin. Насколько мне известно, отключите это выше, скорость будет увеличена минимум на 10%.

Если вам нужны дополнительные объяснения, посетите эту тему https://dba.stackexchange.com/a/216624

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...