PHP와 Lumen이 통합되어 마이크로서비스 아키텍처 개발 실현
IT 기술의 급속한 발전으로 현대 기업은 점점 더 복잡한 비즈니스 시스템에 직면해 있습니다. 기존의 단일 애플리케이션 아키텍처는 더 이상 요구 사항을 충족할 수 없으며 시대의 요구에 따라 마이크로서비스 아키텍처가 등장했습니다. 마이크로서비스 아키텍처는 더 나은 확장성, 재사용성 및 유연성을 달성하기 위해 독립적으로 배포, 실행, 확장 및 유지 관리할 수 있는 여러 개의 소규모 서비스로 애플리케이션을 구성하는 아키텍처 스타일입니다.
그렇다면 PHP를 사용하여 마이크로서비스 아키텍처를 구현하는 방법은 무엇일까요? 대답은 경량 PHP 프레임워크인 Lumen을 사용하는 것입니다. Laravel을 기반으로 하는 Lumen은 마이크로서비스 및 API 구축을 위해 설계된 PHP 프레임워크입니다. 이 글에서는 Lumen 프레임워크에 마이크로서비스 아키텍처를 통합하는 방법을 소개합니다.
1단계: Lumen 설치
먼저 Lumen 프레임워크를 로컬에 설치해야 합니다. 설치 단계는 Laravel과 동일합니다. 아래와 같이 작곡가를 통해 설치할 수 있습니다.
composer create-project --prefer-dist laravel/lumen lumen_api
완료 후 Lumen 프레임워크 실행 환경을 로컬에서 시작할 수 있습니다.
php -S localhost:8000 -t public
"Lumen 개발 서버 시작:
2단계: 마이크로서비스 작성
다음으로 Lumen 프레임워크를 사용하여 첫 번째 마이크로서비스를 작성하겠습니다. 모든 사용자 목록을 가져오는 간단한 API를 만들어 보겠습니다. 이 API를 구현하는 단계는 다음과 같습니다.
- API 경로 생성
라우팅 파일 Routes/web.php에서 API에 대한 요청을 처리하기 위한 경로를 작성해야 합니다. 이번 예시에서는 /get_users 요청을 처리하기 위해 아래와 같이 라우팅 파일에 GET 경로를 작성하겠습니다.
$router->get('/get_users', function () use ($router) { return 'List of all users'; });
이때 http://localhost:8000/get_users를 요청하면 "List"가 됩니다. 모든 사용자의 반환" 문자열입니다.
- API 요청 처리
이제 API용 컨트롤러 클래스를 생성해야 합니다. get_users 요청을 처리하고 사용자 목록을 반환하는 역할을 담당하는 UserController 클래스를 만들어 보겠습니다. app/Http/Controllers 디렉토리에 UserController.php 파일을 생성하고 여기에 다음 코드를 복사할 수 있습니다:
<?php namespace AppHttpControllers; use IlluminateHttpRequest; class UserController extends Controller { public function getAllUsers() { $users = ['User 1', 'User 2', 'User 3']; return response()->json($users); } }
위 코드에서는 모든 사용자의 목록을 응답으로 반환하는 공용 함수 getAllUsers()를 정의했습니다. JSON 형식으로.
- 컨트롤러에 API 경로 등록
이제 경로 파일의 UserController 컨트롤러에 API 경로를 등록하고, /api/get_users 경로를 UserController@getAllUsers 메소드에 매핑하고, 표시된 대로 경로 파일을 수정해야 합니다. 아래 :
$router->get('api/get_users', 'UserController@getAllUsers');
이 시점에서 http://localhost:8000/api/get_users를 요청하면 아래와 같이 JSON 형식의 사용자 목록이 반환됩니다.
{ "0": "User 1", "1": "User 2", "2": "User 3" }
마지막으로 UserController도 가져와야 합니다.
<?php use AppHttpControllersUserController;
이러한 방식으로 우리는 가장 기본적인 API를 성공적으로 구현했으며 Lumen 프레임워크에서 실행할 수 있습니다.
3단계: 마이크로서비스 프레임워크 통합
이전에 Lumen 프레임워크에서 첫 번째 API를 만들었지만 실제 마이크로서비스 애플리케이션은 아닙니다. Lumen을 마이크로서비스 아키텍처 애플리케이션으로 전환하려면 DDD 도메인 모델 설계 아이디어를 사용하여 애플리케이션을 다시 구축해야 합니다. 그런 다음 마이크로서비스라는 아이디어를 활용하여 각 서비스를 마이크로서비스로 분해해 보겠습니다.
- 도메인 디자인
먼저, 애플리케이션의 핵심인 도메인 모델을 정의해야 합니다. 이 예에서는 사용자 데이터를 관리하는 것이 주요 기능인 간단한 사용자 관리 마이크로서비스를 만들어 보겠습니다.
사용자 관리 마이크로서비스에는 다음 기능이 있어야 합니다.
- 사용자 등록
- 사용자 인증
- 사용자 권한 부여
- 사용자 정보 관리
이제 이러한 기능을 마이크로서비스의 인터페이스에 매핑해야 합니다.
- 마이크로서비스 인터페이스
우리는 도메인 모델의 다양한 기능에 따라 다양한 마이크로서비스 인터페이스를 디자인할 것입니다. 여기서는 다음과 같은 마이크로서비스 인터페이스를 정의합니다.
- 사용자 등록 인터페이스(registerUser)
- 사용자 인증 인터페이스(authenticateUser)
- 사용자 인증 인터페이스(authorizeUser)
- 사용자 정보 관리 인터페이스(manageUserInfo)
- 마이크로서비스 모듈
이제 마이크로서비스 인터페이스를 다양한 마이크로서비스 모듈로 나누어야 합니다. 이 예에서는 다음 세 가지 마이크로서비스 모듈을 사용합니다.
- 사용자 인증 및 권한 부여 마이크로서비스
- 사용자 정보 관리 마이크로서비스
- 사용자 등록 마이크로서비스
이러한 마이크로서비스 모듈은 데이터베이스와 직접 인터페이스하여 상호 작용합니다.
- 마이크로서비스 아키텍처
이제 도메인 모델, 마이크로서비스 인터페이스 및 마이크로서비스 모듈의 구성 요소가 있으며 이제 이를 마이크로서비스 아키텍처로 간단히 결합할 수 있습니다. 전체 아키텍처는 다음과 같습니다.
API Gateway (Lumen) <--> User Authentication and Authorization Microservice <--> User Information Management Microservice <--> User Registration Microservice
시스템의 초기 지점인 Lumen API 게이트웨이를 활성화하고 모든 요청을 수신하여 적절한 마이크로서비스 모듈로 라우팅합니다. 도메인 모델은 비즈니스 로직이며 마이크로서비스 인터페이스는 데이터 상호 작용을 제어합니다.
第四步:实现微服务
现在,我们已经设计了微服务模块、微服务接口和整体微服务架构,我们可以开始实现我们的微服务。我们将针对上述三个微服务模块分别进行介绍。
1. 用户认证与授权微服务
我们的用户认证与授权微服务负责处理所有与用户认证相关的任务。它将接收用户凭据并验证它们的凭证是否正确。如果验证成功,它将生成一个JWT标记并将其返回给用户。
我们将针对以下任务编写用户认证与授权微服务:
- 为用户生成JWT标记
- 验证用户凭据
我们可以通过安装tymon / jwt-auth组件来编写我们的用户认证与授权微服务。使用以下命令进行安装:
composer require tymon/jwt-auth
然后,我们需要在配置文件中配置JWT密钥。现在,我们可以使用以下代码为用户认证与授权微服务创建一个新控制器:
<?php namespace AppHttpControllers; use IlluminateSupportFacadesAuth; use AppModelsUser; use IlluminateHttpRequest; class AuthController extends Controller { /** * Create a new AuthController instance. * * @return void */ public function __construct() { $this->middleware('auth:api', ['except' => ['login']]); } /** * Get a JWT token. * * @return void */ public function login(Request $request) { $credentials = $request->only('email', 'password'); if ($token = $this->guard()->attempt($credentials)) { return $this->respondWithToken($token); } return response()->json(['error' => 'Unauthorized'], 401); } /** * Get the authenticated User. * * @return void */ public function me() { return response()->json(auth()->user()); } /** * Log the user out (Invalidate the token). * * @return void */ public function logout() { auth()->logout(); return response()->json(['message' => 'Successfully logged out']); } /** * Refresh a token. * * @return void */ public function refresh() { return $this->respondWithToken(auth()->refresh()); } /** * Get the token array structure. * * @param string $token * * @return mixed */ protected function respondWithToken($token) { return response()->json([ 'access_token' => $token, 'token_type' => 'bearer', 'expires_in' => auth()->factory()->getTTL() * 60 ]); } /** * Get the guard to be used during authentication. * * @return IlluminateContractsAuthGuard */ public function guard() { return Auth::guard(); } }
2. 用户信息管理微服务
用户信息管理微服务将负责向用户提供用户相关信息。在本例中,我们将创建以下操作的API:
- 获取用户个人信息
- 更新用户密码
首先,我们将创建一个新控制器来管理用户信息:
<?php namespace AppHttpControllers; use IlluminateSupportFacadesHash; use AppModelsUser; use IlluminateHttpRequest; class UserController extends Controller { public function getUser(Request $request) { $user = User::where('id', $request->id)->first(); if (!$user) { return response()->json(['message' => 'User not found.'], 404); } return response()->json(['user' => $user]); } public function updateUserPassword(Request $request) { $user = User::where('id', $request->id)->first(); if (!$user) { return response()->json(['message' => 'User not found.'], 404); } $user->password = Hash::make($request->password); $user->save(); return response()->json(['message' => 'User password updated successfully.']); } }
3. 用户注册微服务
注册微服务将处理用户注册过程。在本例中,我们将创建以下功能:
- 创建一个新用户,保存到数据库中
- 发送电子邮件以验证用户的电子邮件地址
首先,我们将创建一个新控制器来处理用户注册。它应该读取POST有效载荷并保存新用户到数据库中。然后,它应该生成用户验证令牌并将其发送到用户的电子邮件地址。
<?php namespace AppHttpControllers; use IlluminateSupportFacadesHash; use AppModelsUser; use IlluminateHttpRequest; class RegisterController extends Controller { public function create(Request $request) { $user = User::create([ 'name' => $request->name, 'email' => $request->email, 'password' => Hash::make($request->password), ]); $user->sendEmailVerificationNotification(); // send verification email return response()->json(['message' => 'User created successfully.']); } }
现在,我们可以在Lumen框架中实现我们的微服务。我们的系统现在有三个微服务模块:“用户认证和授权微服务”、“用户信息管理微服务”和“用户注册微服务”,这些微服务与数据库交互,并由Lumen API Gateway处理。
总结
本文介绍了如何在Lumen框架中集成微服务架构,包括领域模型设计、微服务接口和微服务模块的开发。以上代码展示了Lumen框架如何开发微服务的过程。通过使用Lumen框架,开发者可以快速构建微服务,提高代码质量,加快项目进程。
위 내용은 PHP와 Lumen이 통합되어 마이크로서비스 아키텍처 개발 실현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다
