


PHP und Lumen werden integriert, um die Entwicklung einer Microservice-Architektur zu realisieren
Mit der rasanten Entwicklung der IT-Technologie sind moderne Unternehmen mit immer komplexeren Geschäftssystemen konfrontiert. Die traditionelle Einzelanwendungsarchitektur kann den Anforderungen nicht mehr gerecht werden, und die Microservice-Architektur ist mit der Zeit entstanden. Microservice-Architektur ist ein Architekturstil, bei dem Anwendungen aus mehreren kleinen Diensten bestehen, die unabhängig voneinander bereitgestellt, ausgeführt, erweitert und gewartet werden können, um eine bessere Skalierbarkeit, Wiederverwendbarkeit und Flexibilität zu erreichen.
Wie kann man also PHP verwenden, um eine Microservice-Architektur zu implementieren? Die Antwort ist die Verwendung von Lumen – einem leichten PHP-Framework. Basierend auf Laravel ist Lumen ein PHP-Framework, das für die Erstellung von Microservices und APIs entwickelt wurde. In diesem Artikel wird vorgestellt, wie man eine Microservice-Architektur in das Lumen-Framework integriert.
Schritt 1: Lumen installieren
Zuerst müssen wir das Lumen-Framework lokal installieren. Die Installationsschritte sind die gleichen wie für Laravel. Es kann über Composer installiert werden, wie unten gezeigt:
composer create-project --prefer-dist laravel/lumen lumen_api
Nach Abschluss können wir die Lumen-Framework-Laufumgebung lokal starten:
php -S localhost:8000 -t public
Wenn „Lumen-Entwicklungsserver gestartet:
Schritt zwei: Microservices schreiben
Als nächstes werden wir das Lumen-Framework verwenden, um unseren ersten Microservice zu schreiben. Wir werden eine einfache API erstellen, die eine Liste aller Benutzer erhält. Die Schritte zum Implementieren dieser API sind wie folgt:
- API-Routen erstellen
In der Routing-Datei „routes/web.php“ müssen wir eine Route schreiben, um Anfragen an die API zu verarbeiten. In diesem Beispiel schreiben wir eine GET-Route in die Routing-Datei, um die /get_users-Anfrage zu verarbeiten, wie unten gezeigt:
$router->get('/get_users', function () use ($router) { return 'List of all users'; });
Wenn Sie zu diesem Zeitpunkt http://localhost:8000/get_users anfordern, wird „List“ angezeigt von allen Benutzern zurückgegebene Zeichenfolge.
- API-Anfragen verarbeiten
Jetzt müssen wir eine Controller-Klasse für unsere API erstellen. Erstellen wir die UserController-Klasse, die für die Verarbeitung der get_users-Anfrage und die Rückgabe der Benutzerliste verantwortlich ist. Wir können die Datei UserController.php im Verzeichnis app/Http/Controllers erstellen und den folgenden Code hineinkopieren:
<?php namespace AppHttpControllers; use IlluminateHttpRequest; class UserController extends Controller { public function getAllUsers() { $users = ['User 1', 'User 2', 'User 3']; return response()->json($users); } }
Im obigen Code haben wir eine öffentliche Funktion getAllUsers() definiert, die die Liste aller Benutzer als Antwort zurückgibt im JSON-Format.
- API-Route zum Controller registrieren
Jetzt müssen wir die API-Route zum UserController-Controller in der Routendatei registrieren, unsere Route /api/get_users der Methode UserController@getAllUsers zuordnen und die Routendatei wie gezeigt ändern unten:
$router->get('api/get_users', 'UserController@getAllUsers');
Wenn Sie zu diesem Zeitpunkt http://localhost:8000/api/get_users anfordern, wird eine Benutzerliste im JSON-Format zurückgegeben, wie unten gezeigt:
{ "0": "User 1", "1": "User 2", "2": "User 3" }
Schließlich müssen wir auch den UserController importieren Klasse oben, wie folgt. Gezeigt:
<?php use AppHttpControllersUserController;
Auf diese Weise haben wir erfolgreich eine grundlegendste API implementiert und können unter dem Lumen-Framework ausgeführt werden.
Schritt 3: Microservices-Framework integrieren
Zuvor haben wir unsere erste API im Lumen-Framework erstellt, es handelt sich jedoch nicht um eine echte Microservices-Anwendung. Um Lumen in eine Microservice-Architekturanwendung umzuwandeln, müssen wir Designideen für DDD-Domänenmodelle verwenden, um unsere Anwendung neu zu erstellen. Anschließend werden wir die Idee der Microservices nutzen, um jeden unserer Services in Microservices zu zerlegen.
- Domänendesign
Zunächst müssen wir unser Domänenmodell definieren, das den Kern unserer Anwendung bildet. In diesem Beispiel erstellen wir einen einfachen Microservice zur Benutzerverwaltung, dessen Hauptfunktion darin besteht, Benutzerdaten zu verwalten.
Unser Benutzerverwaltungs-Microservice muss über die folgenden Funktionen verfügen:
- Benutzerregistrierung
- Benutzerauthentifizierung
- Benutzerautorisierung
- Benutzerinformationsverwaltung
Jetzt müssen wir diese Funktionen der Schnittstelle des Microservice zuordnen.
- Microservice-Schnittstelle
Wir werden verschiedene Microservice-Schnittstellen entsprechend unterschiedlichen Funktionen im Domänenmodell entwerfen. Hier definieren wir die folgenden Microservice-Schnittstellen:
- Benutzerregistrierungsschnittstelle (registerUser)
- Benutzerauthentifizierungsschnittstelle (authenticateUser)
- Benutzerautorisierungsschnittstelle (authorizeUser)
- Benutzerinformationsverwaltungsschnittstelle (manageUserInfo)
- Microservice-Modul
Jetzt müssen wir unsere Microservice-Schnittstelle in verschiedene Microservice-Module unterteilen. In diesem Beispiel verwenden wir die folgenden drei Microservice-Module:
- User Authentication and Authorization Microservice
- User Information Management Microservice
- User Registration Microservice
Diese Microservice-Module stellen eine direkte Schnittstelle zu unserer Datenbank her, um zu interagieren.
- Microservices-Architektur
Wir verfügen nun über die Komponenten unseres Domänenmodells, Microservice-Schnittstellen und Microservice-Module und können diese nun einfach zu einer Microservices-Architektur kombinieren. Die gesamte Architektur sieht so aus:
API Gateway (Lumen) <--> User Authentication and Authorization Microservice <--> User Information Management Microservice <--> User Registration Microservice
Wir aktivieren das Lumen API Gateway, das den Ausgangspunkt unseres Systems darstellt und alle Anfragen empfängt und an das entsprechende Microservice-Modul weiterleitet. Unser Domänenmodell ist unsere Geschäftslogik, und die Microservice-Schnittstelle steuert unsere Dateninteraktionen.
第四步:实现微服务
现在,我们已经设计了微服务模块、微服务接口和整体微服务架构,我们可以开始实现我们的微服务。我们将针对上述三个微服务模块分别进行介绍。
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框架,开发者可以快速构建微服务,提高代码质量,加快项目进程。
Das obige ist der detaillierte Inhalt vonPHP und Lumen werden integriert, um die Entwicklung einer Microservice-Architektur zu realisieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

Dieses Tutorial zeigt, wie XML -Dokumente mit PHP effizient verarbeitet werden. XML (Extensible Markup-Sprache) ist eine vielseitige textbasierte Markup-Sprache, die sowohl für die Lesbarkeit des Menschen als auch für die Analyse von Maschinen entwickelt wurde. Es wird üblicherweise für die Datenspeicherung ein verwendet und wird häufig verwendet

Wenn Sie ein erfahrener PHP-Entwickler sind, haben Sie möglicherweise das Gefühl, dass Sie dort waren und dies bereits getan haben. Sie haben eine beträchtliche Anzahl von Anwendungen entwickelt, Millionen von Codezeilen debuggt und eine Reihe von Skripten optimiert, um op zu erreichen

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Eine Zeichenfolge ist eine Folge von Zeichen, einschließlich Buchstaben, Zahlen und Symbolen. In diesem Tutorial wird lernen, wie Sie die Anzahl der Vokale in einer bestimmten Zeichenfolge in PHP unter Verwendung verschiedener Methoden berechnen. Die Vokale auf Englisch sind a, e, i, o, u und sie können Großbuchstaben oder Kleinbuchstaben sein. Was ist ein Vokal? Vokale sind alphabetische Zeichen, die eine spezifische Aussprache darstellen. Es gibt fünf Vokale in Englisch, einschließlich Großbuchstaben und Kleinbuchstaben: a, e, ich, o, u Beispiel 1 Eingabe: String = "TutorialPoint" Ausgabe: 6 erklären Die Vokale in der String "TutorialPoint" sind u, o, i, a, o, ich. Insgesamt gibt es 6 Yuan

Statische Bindung (statisch: :) implementiert die späte statische Bindung (LSB) in PHP, sodass das Aufrufen von Klassen in statischen Kontexten anstatt Klassen zu definieren. 1) Der Analyseprozess wird zur Laufzeit durchgeführt.

Was sind die magischen Methoden von PHP? Zu den magischen Methoden von PHP gehören: 1. \ _ \ _ Konstrukt, verwendet, um Objekte zu initialisieren; 2. \ _ \ _ Destruct, verwendet zur Reinigung von Ressourcen; 3. \ _ \ _ Call, behandeln Sie nicht existierende Methodenaufrufe; 4. \ _ \ _ GET, Implementieren Sie den dynamischen Attributzugriff; 5. \ _ \ _ Setzen Sie dynamische Attributeinstellungen. Diese Methoden werden in bestimmten Situationen automatisch aufgerufen, wodurch die Code -Flexibilität und -Effizienz verbessert werden.
