Laravel 미들웨어: 애플리케이션에 데이터베이스 쿼리 및 성능 모니터링을 추가하세요.

WBOY
풀어 주다: 2023-07-28 15:48:02
원래의
1358명이 탐색했습니다.

Laravel 미들웨어: 애플리케이션에 데이터베이스 쿼리 및 성능 모니터링 추가

소개:
웹 애플리케이션을 개발할 때 데이터 쿼리 및 성능 모니터링은 매우 중요합니다. Laravel은 이러한 요구 사항, 즉 미들웨어를 처리하는 편리한 방법을 제공합니다. 미들웨어는 요청과 응답 사이를 처리하는 기술로, 요청이 컨트롤러에 도달하기 전이나 응답이 사용자에게 반환된 후에 일부 논리를 수행할 수 있습니다. 이 글에서는 Laravel 미들웨어를 사용하여 데이터베이스 쿼리 및 성능 모니터링을 구현하는 방법을 소개합니다.

1. 미들웨어 생성
먼저 미들웨어를 생성해야 합니다. 다음 명령을 실행하여 QueryLogMiddleware라는 새 미들웨어 파일을 만듭니다.

php artisan make:middleware QueryLogMiddleware
로그인 후 복사

이 명령은 app/Http/Middleware 디렉터리에 QueryLogMiddleware.php 파일을 생성합니다. 이제 이 파일에 미들웨어 로직을 작성할 수 있습니다.

2. 데이터베이스 쿼리 로깅 기능 구현
데이터베이스 쿼리 로깅 기능을 추가하기 위해 미들웨어의 핸들 메소드에서 Laravel의 DB Facade(Facade)를 사용하여 모든 SQL 쿼리를 가져와 로그 파일에 기록할 수 있습니다. 다음은 샘플 코드입니다.

<?php

namespace AppHttpMiddleware;

use Closure;
use IlluminateSupportFacadesDB;

class QueryLogMiddleware
{
    public function handle($request, Closure $next)
    {
        DB::connection()->enableQueryLog();

        $response = $next($request);

        $queries = DB::getQueryLog();

        foreach ($queries as $query) {
            // 将$query写入日志文件
        }

        return $response;
    }
}
로그인 후 복사

위 코드에서는 먼저 DB 파사드의 활성화QueryLog 메소드를 호출하여 쿼리 로깅 기능을 활성화합니다. 그런 다음 요청이 미들웨어 체인을 통과한 후 getQueryLog 메서드를 호출하여 모든 쿼리 로그를 가져옵니다. 마지막으로 쿼리 로그를 반복하여 각 쿼리 레코드를 로그 파일에 쓸 수 있습니다.

3. 성능 모니터링 기능 추가
쿼리 로그 기록 외에도 미들웨어를 사용하여 성능 모니터링 기능을 구현할 수도 있습니다. 예를 들어, Laravel의 Debugbar 확장 패키지를 사용하여 애플리케이션의 응답 시간을 모니터링할 수 있습니다. 다음은 샘플 코드입니다.

<?php

namespace AppHttpMiddleware;

use Closure;
use BarryvdhDebugbarFacade as Debugbar;

class PerformanceMiddleware
{
    public function handle($request, Closure $next)
    {
        $start = microtime(true);

        $response = $next($request);

        $end = microtime(true);

        $executionTime = $end - $start;

        Debugbar::addMeasure('Execution Time', $start, $end);

        return $response;
    }
}
로그인 후 복사

위 코드에서는 Debugbar 확장 패키지의 Facade를 사용하여 "Execution Time"이라는 성능 표시기를 추가하고 요청의 실행 시간을 계산합니다. 데이터베이스 쿼리 수, 메모리 사용량 등과 같은 다른 성능 지표를 추가할 수도 있습니다.

4. 미들웨어 등록
이제 이러한 미들웨어를 애플리케이션에 등록해야 합니다. app/Http/Kernel.php 파일을 열고 $middlewareGroups 속성에 다음 코드를 추가합니다:

protected $middlewareGroups = [
    'web' => [
        // 其他中间件...
        AppHttpMiddlewareQueryLogMiddleware::class,
        AppHttpMiddlewarePerformanceMiddleware::class,
    ],
    // 其他中间件组...
];
로그인 후 복사

이렇게 하면 QueryLogMiddleware 및 PerformanceMiddleware가 웹 미들웨어 그룹에 추가됩니다. 즉, 웹 요청 중에 실행됩니다.

5. 미들웨어 사용
이제 애플리케이션의 모든 경로나 컨트롤러 메서드에서 이러한 미들웨어를 사용할 수 있습니다. 예를 들어, Routes/web.php 파일에서 다음을 사용할 수 있습니다:

Route::middleware('query.log', 'performance')->group(function () {
    // 路由定义...
});
로그인 후 복사

이 예는 라우트 그룹에 미들웨어를 적용하는 방법을 보여줍니다. 개별 경로나 컨트롤러 메서드에 미들웨어를 적용할 수도 있습니다.

결론:
Laravel의 미들웨어 기술을 사용하면 애플리케이션에 데이터베이스 쿼리 및 성능 모니터링 기능을 쉽게 추가할 수 있습니다. 위와 같이 데이터베이스 쿼리 로그를 기록하기 위해 QueryLogMiddleware를 생성하고 PerformanceMiddleware를 사용하여 애플리케이션의 성능을 모니터링했습니다. 이러한 미들웨어는 간단한 등록 및 사용으로 애플리케이션을 향상시켜 더욱 강력하고 안정적으로 만들 수 있습니다.

위 내용은 Laravel 미들웨어: 애플리케이션에 데이터베이스 쿼리 및 성능 모니터링을 추가하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿