recherche
MaisonJavajavaDidacticielOptimisation de Lambda sans serveur avec l'image native GraalVM

Introduction

Suite au développement d'un service d'envoi d'e-mails évolutif utilisant AWS SES, Spring Boot et AWS Lambda, j'ai entrepris d'optimiser ses performances. L'objectif était de remédier à la latence de démarrage à froid et à l'utilisation de la mémoire inhérentes aux applications Java sur AWS Lambda. Pour y parvenir, je me suis tourné vers GraalVM Native Image, une technologie conçue pour compiler des applications Java en exécutables natifs. Cet article présente la mise en œuvre et les résultats de cette optimisation.

Pourquoi l'image native GraalVM ?

GraalVM Native Image compile les applications Java à l'avance (AOT) en exécutables autonomes. Ce faisant, il élimine le besoin d'une JVM au moment de l'exécution, ce qui entraîne :

  • Temps de démarrage à froid réduits : les applications démarrent presque instantanément, un facteur crucial pour les environnements sans serveur.

  • Utilisation réduite de la mémoire : en supprimant les composants inutiles, cela crée une empreinte d'application légère.

Ces avantages font de GraalVM une solution idéale pour améliorer les performances des applications sans serveur.

Étapes de mise en œuvre

1. Configuration du projet

J'ai commencé avec le projet pet-store-native d'AWS, qui fournit une implémentation de référence pour convertir les applications Spring Boot 3 en images natives GraalVM. Cela a servi de base à l'intégration des capacités d'image natives dans le service d'envoi d'e-mails.

2. Adaptation à l'architecture ARM

Comme mon environnement utilise une architecture basée sur ARM, le Dockerfile a nécessité des modifications :

  • Mise à jour de l'image de base pour l'aligner sur ARM.
  • Configuré le compilateur GraalVM pour la compatibilité ARM. Ces modifications ont permis de garantir que l'image native était optimisée pour le système cible.

3. Configuration d'exécution

La création d'un fichier d'amorçage personnalisé pour l'environnement d'exécution est essentielle pour garantir l'initialisation et le démarrage corrects de l'application. Ce fichier définit le point d'entrée de la fonction Lambda et initialise l'environnement d'exécution. Il offre également une flexibilité dans la configuration des paramètres d'application, permettant une intégration transparente avec AWS Lambda.

J'ai également activé la prise en charge du protocole HTTP dans le plugin GraalVM Maven et intégré le conteneur AWS Java pour Spring Boot pour gérer les événements API Gateway. Ces configurations garantissaient que l'application pouvait traiter efficacement les requêtes et les réponses HTTP sous sa forme d'image native.

4. Déploiement de l'application

À l'aide du modèle d'application sans serveur AWS (SAM), j'ai déployé l'image native en tant que fonction Lambda. Personnalisations clés incluses :

  • Passer de HTTP API Gateway à une API Gateway standard pour activer l'authentification basée sur la clé API.
  • Mise en œuvre de plans d'utilisation pour un accès API sécurisé et évolutif. Ces ajustements ont non seulement amélioré la sécurité, mais ont également permis une meilleure allocation des ressources pour la fonction.

Résultats

La transition vers GraalVM Native Image a apporté des améliorations significatives :

  • Temps de démarrage à froid : réduits en éliminant l'initialisation de la JVM.

  • Utilisation de la mémoire : minimisée en raison de la nature compacte des exécutables natifs.

  • Mise à l'échelle des performances : des temps de réponse plus rapides et une meilleure gestion des demandes simultanées.

Image native
Optimizing Serverless Lambda with GraalVM Native Image

SpringBoot3

Optimizing Serverless Lambda with GraalVM Native Image

De plus, l'intégration d'API Gateway a fourni un contrôle robuste sur l'accès et l'utilisation, permettant au service de fonctionner comme un point de terminaison sécurisé et évolutif.

Leçons apprises

Grâce à cette implémentation, j'ai acquis une compréhension plus approfondie de l'interaction entre GraalVM, Spring Boot et AWS Lambda. Le processus a mis en évidence l'importance de :

  • Optimisation pour des architectures spécifiques afin de maximiser les performances.
  • Configuration des environnements d'exécution pour équilibrer flexibilité et efficacité.
  • Tirer parti d'outils tels qu'AWS SAM pour un déploiement rationalisé.

Ce projet a renforcé le potentiel de GraalVM Native Image en tant qu'outil d'optimisation puissant pour les applications Java sans serveur, offrant une voie à suivre convaincante pour améliorer les performances et réduire les coûts dans les environnements de production.

GitHub Repo pour ce projet

Ressources

Replateforme des applications Java avec le conteneur Java sans serveur AWS mis à jour

Guide de démarrage rapide : Spring Boot 3

Image native GraalVM : plus rapide, plus intelligente, plus simple

Going AOT : un guide complet de GraalVM pour les applications Java par Alina Yurenko | PrintempsIO

Devenir natif : créer des applications Spring Boot rapides et légères avec GraalVM par Alina Yurenko

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!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Comment le sous-système de chargeur de classe du JVM contribue-t-il à l'indépendance de la plate-forme?Comment le sous-système de chargeur de classe du JVM contribue-t-il à l'indépendance de la plate-forme?Apr 23, 2025 am 12:14 AM

Le chargeur de classe garantit la cohérence et la compatibilité des programmes Java sur différentes plates-formes via le format de fichier de classe unifié, le chargement dynamique, le modèle de délégation parent et les bytecode indépendants de la plate-forme et réalisent l'indépendance de la plate-forme.

Le compilateur Java produit-il un code spécifique à la plate-forme? Expliquer.Le compilateur Java produit-il un code spécifique à la plate-forme? Expliquer.Apr 23, 2025 am 12:09 AM

Le code généré par le compilateur Java est indépendant de la plate-forme, mais le code finalement exécuté est spécifique à la plate-forme. 1. Le code source Java est compilé en bytecode indépendant de la plate-forme. 2. Le JVM convertit le bytecode en code machine pour une plate-forme spécifique, garantissant un fonctionnement multiplateforme mais les performances peuvent être différentes.

Comment le JVM gère-t-il le multithreading sur différents systèmes d'exploitation?Comment le JVM gère-t-il le multithreading sur différents systèmes d'exploitation?Apr 23, 2025 am 12:07 AM

Le multithreading est important dans la programmation moderne car elle peut améliorer la réactivité du programme et l'utilisation des ressources et gérer des tâches simultanées complexes. JVM assure la cohérence et l'efficacité des multitheads sur différents systèmes d'exploitation grâce à la cartographie des filetages, au mécanisme de planification et au mécanisme de verrouillage de synchronisation.

Que signifie «l'indépendance de la plate-forme» dans le contexte de Java?Que signifie «l'indépendance de la plate-forme» dans le contexte de Java?Apr 23, 2025 am 12:05 AM

L'indépendance de la plate-forme de Java signifie que le code écrit peut fonctionner sur n'importe quelle plate-forme avec JVM installé sans modification. 1) Le code source Java est compilé en bytecode, 2) ByteCode est interprété et exécuté par le JVM, 3) le JVM fournit des fonctions de gestion de la mémoire et de collecte des ordures pour s'assurer que le programme s'exécute sur différents systèmes d'exploitation.

Les applications Java peuvent-elles encore rencontrer des bogues ou des problèmes spécifiques à la plate-forme?Les applications Java peuvent-elles encore rencontrer des bogues ou des problèmes spécifiques à la plate-forme?Apr 23, 2025 am 12:03 AM

JavaApplicationsCanindeenCounterPlatform-spécificiSUesSuSesSetheTethejvm'sabstraction.reasonsinclude: 1) nativecode et libraires, 2) OperatingSystemdifferences, 3) jvmimplementationvariations, et4) condason

Comment le cloud computing a-t-il un impact sur l'importance de l'indépendance de la plate-forme de Java?Comment le cloud computing a-t-il un impact sur l'importance de l'indépendance de la plate-forme de Java?Apr 22, 2025 pm 07:05 PM

Le cloud computing améliore considérablement l'indépendance de la plate-forme de Java. 1) Le code Java est compilé en bytecode et exécuté par le JVM sur différents systèmes d'exploitation pour assurer le fonctionnement multiplateforme. 2) Utilisez Docker et Kubernetes pour déployer des applications Java pour améliorer la portabilité et l'évolutivité.

Quel rôle la plate-forme de Java a-t-elle joué dans son adoption généralisée?Quel rôle la plate-forme de Java a-t-elle joué dans son adoption généralisée?Apr 22, 2025 pm 06:53 PM

Java'splatformIndependenceNallowsDeveloperstowRiteCodeoncerandUnitonanyDeviceoroswithajvm. ThisisachievedthroughPulingToBytecode, quithejvMinterpretsorcompimentsAtruntime.ThisfeureHassignifant Boosttedjava'sadoptionDuetocross-PlatformDoyment, SplateFor, SplateformDoyment, sadoptionDuetocross-PlatformDoyment, Sendjava'sadoptionDuetocross-PlatformDoyment, Sendjava'sadoptionDuetocross-PlatformDoyment, Sendjava'sadoptionDuetocross-PlatformDoyment, SADOPtiondUtocross-PlatformDoyment, SADOPtiondUetocross-PlatformDoyment.

Comment les technologies de contenerisation (comme Docker) affectent-elles l'importance de l'indépendance de la plate-forme de Java?Comment les technologies de contenerisation (comme Docker) affectent-elles l'importance de l'indépendance de la plate-forme de Java?Apr 22, 2025 pm 06:49 PM

Les technologies de conteneurisation telles que Docker améliorent plutôt que de remplacer l'indépendance de la plate-forme de Java. 1) Assurer la cohérence entre les environnements, 2) Gérer les dépendances, y compris des versions JVM spécifiques, 3) Simplifier le processus de déploiement pour rendre les applications Java plus adaptables et gérables.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

Outils chauds

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),