요청 라이프사이클
소개
"실제 세계"에서 어떤 도구를 사용할 때, 그 도구가 어떻게 동작하는지 이해하면 더 자신감 있게 사용할 수 있습니다. 애플리케이션 개발도 마찬가지입니다. 개발 도구가 어떻게 동작하는지 이해하면, 더 편안하고 자신감 있게 사용할 수 있습니다.
이 문서의 목적은 Laravel 프레임워크가 어떻게 동작하는지에 대한 높은 수준의 개요를 제공하는 것입니다. 전체적인 프레임워크를 더 잘 알게 되면, 모든 것이 덜 "마법"처럼 느껴지고 애플리케이션을 더 자신 있게 구축할 수 있습니다. 모든 용어를 바로 이해하지 못하더라도 낙담하지 마세요! 전체적인 흐름을 대략적으로 파악하려고 노력하면, 문서의 다른 섹션을 탐색하면서 지식이 점차 쌓일 것입니다.
라이프사이클 개요
첫 단계
Laravel 애플리케이션에 대한 모든 요청의 진입점은 public/index.php
파일입니다. 모든 요청은 웹 서버(Apache / Nginx) 설정에 의해 이 파일로 전달됩니다. index.php
파일에는 많은 코드가 들어 있지 않습니다. 오히려, 프레임워크의 나머지 부분을 로드하는 출발점 역할을 합니다.
index.php
파일은 Composer가 생성한 오토로더 정의를 로드한 다음, bootstrap/app.php
에서 Laravel 애플리케이션 인스턴스를 가져옵니다. Laravel이 처음으로 수행하는 동작은 애플리케이션 / 서비스 컨테이너 인스턴스를 생성하는 것입니다.
HTTP / 콘솔 커널
그 다음, 들어오는 요청은 애플리케이션 인스턴스의 handleRequest
또는 handleCommand
메서드를 사용하여 HTTP 커널 또는 콘솔 커널로 전달됩니다. 어떤 종류의 요청이 들어오는지에 따라 다릅니다. 이 두 커널은 모든 요청이 흐르는 중심 위치 역할을 합니다. 지금은 Illuminate\Foundation\Http\Kernel
의 인스턴스인 HTTP 커널에만 집중해 봅시다.
HTTP 커널은 요청이 실행되기 전에 실행될 bootstrappers
배열을 정의합니다. 이 부트스트래퍼들은 에러 핸들링을 구성하고, 로깅을 설정하며, 애플리케이션 환경을 감지하고, 실제로 요청을 처리하기 전에 필요한 기타 작업을 수행합니다. 일반적으로 이 클래스들은 여러분이 신경 쓸 필요 없는 Laravel 내부 설정을 처리합니다.
HTTP 커널은 또한 요청을 애플리케이션의 미들웨어 스택을 통해 전달하는 역할도 합니다. 이 미들웨어들은 HTTP 세션 읽기 및 쓰기, 애플리케이션이 유지보수 모드인지 확인, CSRF 토큰 검증 등 다양한 작업을 처리합니다. 이에 대해서는 곧 더 자세히 다루겠습니다.
HTTP 커널의 handle
메서드 시그니처는 매우 간단합니다. Request
를 받아서 Response
를 반환합니다. 커널을 여러분의 전체 애플리케이션을 대표하는 큰 블랙박스라고 생각하세요. HTTP 요청을 넣으면 HTTP 응답이 반환됩니다.
서비스 프로바이더
커널 부트스트래핑 작업 중 가장 중요한 것 중 하나는 애플리케이션의 서비스 프로바이더를 로드하는 것입니다. 서비스 프로바이더는 데이터베이스, 큐, 유효성 검사, 라우팅 등 프레임워크의 다양한 컴포넌트를 부트스트랩하는 역할을 합니다.
Laravel은 이 프로바이더 목록을 순회하며 각각을 인스턴스화합니다. 프로바이더를 인스턴스화한 후, 모든 프로바이더의 register
메서드가 호출됩니다. 그런 다음, 모든 프로바이더가 등록된 후에는 각 프로바이더의 boot
메서드가 호출됩니다. 이는 서비스 프로바이더의 boot
메서드가 실행될 때 모든 컨테이너 바인딩이 등록되고 사용 가능하도록 보장하기 위함입니다.
Laravel이 제공하는 거의 모든 주요 기능은 서비스 프로바이더에 의해 부트스트랩되고 구성됩니다. 프레임워크에서 제공하는 수많은 기능을 부트스트랩하고 구성하기 때문에, 서비스 프로바이더는 전체 Laravel 부트스트랩 과정에서 가장 중요한 요소입니다.
프레임워크 내부적으로는 수십 개의 서비스 프로바이더를 사용하지만, 여러분도 직접 프로바이더를 만들 수 있습니다. 애플리케이션에서 사용하는 사용자 정의 또는 서드파티 서비스 프로바이더 목록은 bootstrap/providers.php
파일에서 확인할 수 있습니다.
라우팅
애플리케이션이 부트스트랩되고 모든 서비스 프로바이더가 등록되면, Request
는 라우터로 전달되어 디스패치됩니다. 라우터는 요청을 라우트 또는 컨트롤러로 전달하고, 라우트별 미들웨어도 실행합니다.
미들웨어는 애플리케이션에 들어오는 HTTP 요청을 필터링하거나 검사할 수 있는 편리한 메커니즘을 제공합니다. 예를 들어, Laravel에는 애플리케이션 사용자가 인증되었는지 확인하는 미들웨어가 포함되어 있습니다. 사용자가 인증되지 않았다면, 미들웨어는 사용자를 로그인 화면으로 리디렉션합니다. 반면, 사용자가 인증되어 있다면 요청이 애플리케이션 내부로 더 진행될 수 있도록 허용합니다. 일부 미들웨어는 PreventRequestsDuringMaintenance
처럼 애플리케이션의 모든 라우트에 할당되며, 일부는 특정 라우트나 라우트 그룹에만 할당됩니다. 미들웨어에 대해 더 자세히 알고 싶다면 미들웨어 문서를 참고하세요.
요청이 매칭된 라우트에 할당된 모든 미들웨어를 통과하면, 라우트 또는 컨트롤러 메서드가 실행되고, 해당 메서드가 반환한 응답이 라우트의 미들웨어 체인을 따라 다시 전달됩니다.
마무리
라우트 또는 컨트롤러 메서드가 응답을 반환하면, 그 응답은 라우트의 미들웨어를 거쳐 다시 바깥쪽으로 전달되어, 애플리케이션이 나가는 응답을 수정하거나 검사할 수 있는 기회를 얻게 됩니다.
마지막으로, 응답이 미들웨어를 모두 통과하면 HTTP 커널의 handle
메서드는 응답 객체를 애플리케이션 인스턴스의 handleRequest
로 반환하고, 이 메서드는 반환된 응답의 send
메서드를 호출합니다. send
메서드는 응답 내용을 사용자의 웹 브라우저로 전송합니다. 이제 Laravel 요청 라이프사이클 전체 여정을 마쳤습니다!
서비스 프로바이더 집중 탐구
서비스 프로바이더는 Laravel 애플리케이션을 부트스트랩하는 데 있어 정말 핵심적인 역할을 합니다. 애플리케이션 인스턴스가 생성되고, 서비스 프로바이더가 등록되며, 요청이 부트스트랩된 애플리케이션에 전달됩니다. 정말 그게 전부입니다!
서비스 프로바이더를 통해 Laravel 애플리케이션이 어떻게 구축되고 부트스트랩되는지 확실히 이해하는 것은 매우 가치 있는 일입니다. 여러분이 정의한 서비스 프로바이더는 app/Providers
디렉터리에 저장됩니다.
기본적으로 AppServiceProvider
는 거의 비어 있습니다. 이 프로바이더는 애플리케이션의 자체 부트스트래핑 및 서비스 컨테이너 바인딩을 추가하기에 좋은 위치입니다. 대규모 애플리케이션의 경우, 각 서비스에 대해 더 세분화된 부트스트래핑을 제공하는 여러 개의 서비스 프로바이더를 생성할 수도 있습니다.