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();
}
Ok so a brand new table, with a brand new Request. with a single ID in it, looks like this:
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.