


Pourquoi j'ai migré mon application Laravel vers AWS Serverless (et pourquoi je pourrais vous faire économiser du temps et de l'argent)
Cet article explore les avantages du déploiement d'une application Laravel sur AWS Server sans serveur, en le contrastant avec l'hébergement EC2 traditionnel. L'auteur partage leur expérience en migration d'une configuration EC2 à forte intensité de ressources vers une architecture de serveur rentable et évolutive.
spoiler : Il ne s'agit pas seulement d'économiser de l'argent - bien que mon portefeuille ne se plaint pas.
Imaginez ceci: vous avez construit une brillante application Laravel - votre chef-d'œuvre, un couteau à armée suisse numérique avec des fonctionnalités si utiles qu'ils pourraient couper du beurre ... ou des commentaires des utilisateurs. Mais il y a une prise. Chaque mois, vous payez pour une instance EC2 sous-utilisée. La mise à l'échelle ressemble à un bateau de croisière dans un ouragan.
Cela semble familier? Ça m'a fait.
Il y a trois ans, j'ai fait ce que la plupart des développeurs appelleraient fou: j'ai déployé PHP à AWS Lambda. «PHP? Sur Serverless? C'est comme mettre l'ananas sur la pizza! », Ont-ils dit.
Mais je suis ici, trois ans plus tard, en mangeant fièrement ma pizza d'ananas. Permettez-moi de vous dire pourquoi Laravel sur Serverless est la mise à niveau du cloud dont vous ne saviez pas que vous aviez besoin.
-
Le problème traditionnel d'hébergement de Laravel
(ou: pourquoi mes instances EC2 avaient une crise existentielle)
Avant le serveur sans serveur, mon application Laravel résidait sur EC2. Pour les non-initiés, EC2 est la version d'Amazon d'un serveur privé virtuel, où vous louez une tranche d'une machine pour exécuter votre code. Ça a l'air génial, non? Jusqu'à ce que la réalité frappe plus fort qu'un voyou composer update
.
a) Premièrement: le coût de l'existence
Exécuter une instance EC2, c'est comme posséder une Tesla, vous laissez en marche 24/7, juste au cas où vous voudriez conduire. Ma demande n'était pas toujours occupée, mais cela n'a pas arrêté le compteur. Entre les instances EC2, les équilibreurs de chargement et le stockage partagé, je dépensais environ 110 $ / mois sur une pile de serveurs qui a passé la plupart de son temps inactif. Mon portefeuille? Coulé comme le Titanic.
Je sais, ce n'est pas beaucoup dans le grand schéma des choses, mais en tant que développeur / entrepreneur en solo, chaque dollar compte.
b) Ensuite: mise à l'échelle des cauchemars
Les instances EC2 sont comme cet ami qui réagit de manière excessive à tout.
- Spike de trafic? "Je m'écrase maintenant, merci!"
- pas de trafic? "Je vais toujours brûler votre argent!"
La gestion de l'automate avait envie d'enseigner un poisson à jongler - possible, mais à quel prix? Ajuster manuellement les groupes de mise à l'échelle, configurer des équilibreurs de charge et prier que vous ne surprovisiez pas ressemblant à un deuxième emploi que je n'ai jamais postulé.
c) Et enfin: DevOps, le stagiaire impayé
Personne ne m'a dit que le développement de Laravel est venu avec un côté des responsabilités sysadmin:
- appliquer des correctifs de sécurité.
- Débogage des configurations Nginx / Apache à 3 heures.
- chuchotant des notants doux aux commandes
sudo
, en espérant qu'ils fonctionneraient cette fois.
Je ne me suis pas inscrit à cette vie.
C'est à ce moment-là que j'ai commencé à explorer des alternatives, et sans serveur s'est démarqué comme la solution parfaite à ces maux de tête.
-
AWS Server sans: la résurgence de PHP dans le cloud
Clarifions un mythe: Serverless ne signifie pas «pas de serveurs». Cela signifie simplement que les serveurs sont le problème de quelqu'un d'autre. Dans ce cas, AWS gère le levage de lourds pendant que je me concentre sur ce que j'apprécie vraiment: le codage.
a) Lambda: le sorcier motivé en événement
AWS Lambda est comme un super-héros qui ne se présente que lorsque vous en avez besoin. Il exécute votre code en réponse aux événements - requêtes HTTP, messages SQS, tâches planifiées, vous l'appelez. Et lorsque le travail est terminé, il disparaît plus rapidement que la pizza gratuite lors d'une rencontre de développeur.
- pas de coûts de ralenti : Vous ne payez que pour le temps d'exécution (mesuré en millisecondes).
- Magic de mise à l'échelle automatique : Vous avez un pic de 100 000 demandes? Lambda le gère sans transpirer (ou vider votre compte bancaire).
- sans état par conception : C'est comme un nouveau départ à chaque fois, un design qui vous oblige à penser modulaire.
b) Services gérés: les héros méconnus
Serverless n'est pas seulement Lambda - c'est un écosystème. AWS remplace votre infrastructure de bricolage par des services gérés qui "travaillent juste":
- Base de données : Options comme Aurora Serverless (MySQL / Postgres) pour les amateurs de SQL.
- S3 : Stockez vos fichiers sans vous soucier de manquer d'espace disque.
- sqs : Découplez les travaux de longue durée et traitez-les de manière asynchrone.
c) Le paradoxe PHP
Je l'admets: PHP n'était pas né pour le serveur sans serveur. C'est comme demander à un poisson de gravir un arbre - il se plaindra, mais il finira par le faire. Laravel, traditionnellement dépendant du PHP-FPM, avait besoin de quelques ajustements pour prospérer dans le monde éphémère de Lambda:
- Sessions : Déplacez-les vers une base de données externe comme MySQL ou Redis.
- Stockage de fichiers : Redirigez toutes les opérations de stockage vers S3, en utilisant la façade de Laravel
Storage
. - Gestion des files d'attente : Configurez SQS comme pilote par défaut pour l'exécution de la tâche asynchrone.
- CACHING : Tirez parti des services externes comme Redis ou DynamoDB au lieu du stockage local.
- Optimisation du temps de démarrage : minimiser le froid commence par couper la graisse (dépendances inutilisées).
- Variables d'environnement : Remplacez
.env
Fichiers par AWS Secrets Manager ou Paramètre Store pour la gestion de la configuration centralisée et sécurisée.
N'oubliez pas que Serverless ne consiste pas seulement à remplacer les serveurs par des fonctions lambda. Il s'agit de repenser votre architecture - ce que AWS gère les points de douleur opérationnels pendant que vous vous concentrez sur la construction.
-
comment le serveur déverrouille le plein potentiel de Laravel
Ainsi, Laravel sur Serverless tient-il réellement ses promesses?
Serverless n'est pas seulement un mot à la mode, c'est un changement transformateur. La beauté de Laravel sur le sans serveur réside dans sa capacité à résoudre les faiblesses de l'hébergement traditionnel tout en permettant des solutions plus rapides, plus évolutives et rentables. Mais la vraie magie se produit lorsque vous vous plongez sur la façon dont ces avantages se combinent. Décomposons-le.
a) Démarrage du froid: séparer le mythe de la réalité
Le froid démarre se produit lorsque Lambda initialise une nouvelle instance. Considérez-le comme PHP se réveillant d'une sieste. Les critiques les traitent comme l'apocalypse, mais ils sont gérables:
- réalité : Le froid typique commence par PHP Laravel est d'environ ~ 3-5 secondes.
- Solutions :
- Laravel Octane : maintient l'application en vie entre les demandes, en réduisant les temps de démarrage. Les demandes ultérieures sont traitées dans ~ 200 ms ou moins.
- Concurrence provisoire : AWS pré-téléchaume pour les points de terminaison critiques (coûte supplémentaire, mais valable pour les points de terminaison clés) .
Pour la plupart des applications, les retards inférieurs à la 3 seconde pendant le faible trafic sont acceptables. La plupart des utilisateurs ne remarqueront pas un démarrage à froid, en particulier pendant les pointes de la circulation lorsque Lambda reste "au chaud".
b) Échelle indolore
La mise à l'échelle de l'hébergement traditionnel ressemble souvent à une bataille sans fin. Avec sans serveur, la mise à l'échelle devient sans effort: plus de réglages d'autoscalités ou de traverser les doigts pendant une augmentation soudaine de la circulation. AWS Lambda supprime la conjecture, mise à l'échelle horizontalement par défaut.
Voici un exemple:
- Scénario : Votre application devient virale? yay!
- Old EC2 Configuration : Vous commencez à ressentir la latence, vous précipitez pour vous connecter à AWS, ajustez manuellement le nombre d'instances et priez pour le meilleur ?. Oh, et n'oubliez pas d'équilibrer correctement ces instances sur les zones de disponibilité.
- Nouvelle configuration de lambda : AWS crée automatiquement autant d'instances que nécessaire, en manipulant des milliers de demandes simultanées sans que vous leviez un doigt. Vous prenez du pop-corn et regardez des métriques CloudWatch comme une série Netflix ?.
Ce n'est pas seulement la commodité, c'est la tranquillité d'esprit. Alors que vous vous concentrez sur la célébration du succès de votre application, Lambda fait le gros du travail. Et la meilleure partie? Vous ne payez que pour le temps de calcul que vous utilisez, pas pour la capacité inactive dont vous pourriez avoir besoin "au cas où."
c) CONTACK-CONCICATION: le MVP
Serverless n'économise pas seulement de l'argent, c'est comme avoir un buffet à volonté où vous ne payez que pour ce que vous consommez.
- mon ancienne configuration EC2: ~ 110 $ / mois.
- 4x T3.Small EC2 Instances: 60,00 $
- 1x équilibreur de charge: 16,40 $
- 1x EBS (stockage partagé entre les instances EC2): 7,80 $
- 1x instance MySQL RDS (db.t4g.medium): ~ 26,00 $
- lambda: ~ 34 $ / mois (une économie de 60%!) .
- lambda, passerelle API ~ demandes de 2,5 m (~ 500 ms / 512 Mo de mémoire) / mois: 4,80 $
- Services gérés (S3, SQS, CloudWatch): ~ 2,90 $
- RDS MySQL Instance (db.t4g.medium): ~ 26,00 $
**Resource** | **EC2 Cost** | **Lambda Cost** |
---|---|---|
Compute | .00 | .50 |
Networking (LB, API Gateway) | .40 | .30 |
Storage | .80 | .90 |
Database | .00 | .00 |
**TOTAL** | **0.20** | **~.70** |
En bref, sans serveur économise non seulement de l'argent, mais libère la bande passante mentale. Moins je gaspille les ressources que je me soucie de la surdivision, plus je peux me concentrer sur la construction de quelque chose d'incroyable.
À ce stade, j'utilisais toujours une instance MySQL comme moteur de base de données. Les messages futurs exploreront la migration vers DynamoDB pour réduire davantage les coûts.
d) Liberté de maintenance: Dites adieu aux cauchemars opérationnels
SERVER M'a libéré des chaînes de la maintenance du serveur. Voici comment:
- Plus de mises à jour manuelles : AWS gère les correctifs de sécurité, les mises à jour du système d'exploitation et les améliorations d'exécution, ce qui signifie que vous utilisez toujours des infrastructures sécurisées et à jour.
- Configurations simplifiées : Avec des services comme la passerelle API et S3, la complexité de la gestion des configurations Nginx et des déploiements personnalisés devient une chose du passé.
- Capacité élastique : Oubliez le débit supplémentaire pour les ressources du serveur inutilisées ou la brouillage pour provisionner davantage pendant les pointes de trafic. Lambda évolue automatiquement pour répondre à la demande et arrête la facturation lorsque le ralenti.
- Focus sur les fonctionnalités, pas la lutte contre les incendies : Le temps que j'ai passé auparavant à appliquer des correctifs ou à déboguer les problèmes de production est désormais investi dans la création de fonctionnalités et l'amélioration de l'expérience utilisateur.
Serverless ne réduit pas seulement la maintenance, il élimine les distractions opérationnelles qui vous empêchent de coder.
-
mais Laravel est-il sans serveur pour tout le monde?
Aussi révolutionnaire que Laravel sur Serverless, ce n'est pas une solution universelle. Pour certaines applications, la nature apatride et axée sur les événements de Serverless peut sembler être un rêve devenu réalité. Pour d'autres, cela pourrait avoir l'impression d'essayer d'adapter une cheville carrée dans un trou rond. Avant de sauter dans le train sans serveur, prenons du recul et évaluons si cela convient à votre projet.
a) La nature apatride: une épée à double tranchant
Laravel aime les opérations qui préservent les informations entre les interactions, comme le stockage des fichiers localement et l'enregistrement des sessions au système de fichiers. Pour devenir sans serveur, vous devez changer:
- Sessions : Utilisez des bases de données (MySQL / Postgres) ou Redis; Plus de dépendance du système de fichiers.
- fichiers : rediriger les téléchargements de fichiers vers S3, ou éviter complètement Laravel et utiliser les URL pré-signées S3.
- Journaux : Configurez Laravel pour les diffuser sur CloudWatch.
- Configuration : Déplacer
.env
Variables vers AWS Secrets Manager ou Paramètre Store pour la gestion centralisée. - files d'attente : migrer les travaux vers AWS SQS pour la manipulation de file d'attente et de messages évolutifs.
b) Considérations de verrouillage des fournisseurs
Les services AWS sont magiques, mais ils sont également propriétaires:
- Vous voulez migrer de SQS vers Redis files d'attente? Préparez-vous à réécrire le code.
- Vous voulez passer de Lambda à Docker? Prenez un café: ce sera une longue nuit.
c) Quand ne pas choisir de serveur sans serveur
Serverless n'est pas une solution miracle pour toutes les charges de travail. Évitez-le si:
- Vous avez besoin de WebSockets : Bien que réalisable avec des services comme API Gateway WebSocket API ou outils tiers comme habilement, il ajoute de la complexité.
- Votre application a des charges de calcul lourdes : des tâches comme l'inférence AI / ML ou le codage vidéo peuvent toucher le délai de 15 minutes de Lambda.
- Vous comptez sur Services avec état : Les applications qui supposent un disque ou un état de serveur persistant peuvent être coûteux à refactor.
-
Quelle est la prochaine étape?
Laravel sur Serverless a le potentiel de transformer la façon dont vous créez et déployez des applications, mais la vraie magie est dans l'implémentation. Prêt à faire le saut et à donner à votre application Laravel le traitement sans serveur? Restez à l'écoute pour la partie 2, où je vais vous guider à travers les étapes exactes pour donner vie à cette architecture.
Une question pour vous : Quelle est votre plus grande crainte à propos du serveur sans serveur? Partagez-le ci-dessous, et j'adresserai au top 3 de la partie 2!
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.

La fonction d'énumération dans PHP8.1 améliore la clarté et la sécurité du type du code en définissant les constantes nommées. 1) Les énumérations peuvent être des entiers, des chaînes ou des objets, améliorant la lisibilité du code et la sécurité des types. 2) L'énumération est basée sur la classe et prend en charge des fonctionnalités orientées objet telles que la traversée et la réflexion. 3) L'énumération peut être utilisée pour la comparaison et l'attribution pour assurer la sécurité du type. 4) L'énumération prend en charge l'ajout de méthodes pour implémenter une logique complexe. 5) La vérification stricte et la gestion des erreurs peuvent éviter les erreurs courantes. 6) L'énumération réduit la valeur magique et améliore la maintenabilité, mais prêtez attention à l'optimisation des performances.

L'application du principe solide dans le développement de PHP comprend: 1. Principe de responsabilité unique (SRP): Chaque classe n'est responsable d'une seule fonction. 2. Principe ouvert et ferme (OCP): les changements sont réalisés par extension plutôt que par modification. 3. Principe de substitution de Lisch (LSP): les sous-classes peuvent remplacer les classes de base sans affecter la précision du programme. 4. Principe d'isolement d'interface (ISP): utilisez des interfaces à grain fin pour éviter les dépendances et les méthodes inutilisées. 5. Principe d'inversion de dépendance (DIP): les modules élevés et de bas niveau reposent sur l'abstraction et sont mis en œuvre par injection de dépendance.

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Les principes de conception de Restapi incluent la définition des ressources, la conception URI, l'utilisation de la méthode HTTP, l'utilisation du code d'état, le contrôle de version et les haineux. 1. Les ressources doivent être représentées par des noms et maintenues dans une hiérarchie. 2. Les méthodes HTTP devraient être conformes à leur sémantique, telles que GET est utilisée pour obtenir des ressources. 3. Le code d'état doit être utilisé correctement, tel que 404 signifie que la ressource n'existe pas. 4. Le contrôle de la version peut être implémenté via URI ou en-tête. 5. Hateoas bottise les opérations du client via des liens en réponse.

En PHP, la gestion des exceptions est réalisée grâce aux mots clés d'essai, de catch, enfin et de lancement. 1) Le bloc d'essai entoure le code qui peut lancer des exceptions; 2) Le bloc de capture gère les exceptions; 3) Enfin, Block garantit que le code est toujours exécuté; 4) Le lancer est utilisé pour lancer manuellement les exceptions. Ces mécanismes aident à améliorer la robustesse et la maintenabilité de votre code.

La fonction principale des classes anonymes en PHP est de créer des objets uniques. 1. Les classes anonymes permettent aux classes sans nom d'être définies directement dans le code, ce qui convient aux exigences temporaires. 2. Ils peuvent hériter des classes ou implémenter des interfaces pour augmenter la flexibilité. 3. Faites attention aux performances et à la lisibilité au code lorsque vous l'utilisez et évitez de définir à plusieurs reprises les mêmes classes anonymes.
