

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

# Création de fonctions Lambda avec Ruby
<a name="lambda-ruby"></a>

Vous pouvez exécuter du code Ruby dans AWS Lambda. Lambda fournit des [runtimes](lambda-runtimes.md) pour Ruby qui exécutent votre code afin de traiter des événements. Votre code s'exécute dans un environnement qui inclut le AWS SDK pour Ruby, avec les informations d'identification d'un rôle Gestion des identités et des accès AWS (IAM) que vous gérez. Pour en savoir plus sur les versions du kit SDK incluses dans les environnements d’exécution Ruby, consultez [Versions du SDK incluses dans l’environnement d’exécution](#ruby-sdk-included).

Lambda prend en charge les runtimes Ruby suivants.


| Nom | Identifiant | Système d’exploitation | Date d’obsolescence | Créer la fonction de blocage | Mettre à jour la fonction de blocage | 
| --- | --- | --- | --- | --- | --- | 
| Ruby 3.4 | `ruby3.4` | Amazon Linux 2023 |  31 mars 2028  |  30 avril 2028  |  31 mai 2028  | 
| Ruby 3.3 | `ruby3.3` | Amazon Linux 2023 |  31 mars 2027  |  30 avril 2027  |  31 mai 2027  | 
| Ruby 3.2 | `ruby3.2` | Amazon Linux 2 |  31 mars 2026  |  31 août 2026  |  30 sept. 2026  | 

**Pour créer une fonction Ruby**

1. Ouvrez la [console Lambda](https://console.aws.amazon.com/lambda).

1. Sélectionnez **Créer une fonction**.

1. Configurez les paramètres suivants :
   + **Nom de la fonction** : saisissez le nom de la fonction.
   + **Runtime** : Choisissez **Ruby 3.4**.

1. Choisissez **Créer une fonction**.

La console crée une fonction Lambda avec un seul fichier source nommé `lambda_function.rb`. Vous pouvez modifier ce fichier et ajouter d'autres fichiers dans l'éditeur de code intégré. Dans la section **DÉPLOYER**, choisissez **Déployer** pour mettre à jour le code de votre fonction. Ensuite, pour exécuter votre code, choisissez **Créer un événement de test** dans la section **ÉVÉNEMENTS DE TEST**.

Le fichier `lambda_function.rb` exporte une fonction nommée `lambda_handler` qui accepte un objet événement et un objet contexte. Il s'agit de la [fonction de gestionnaire](ruby-handler.md) que Lambda appelle lors de l'invocation de la fonction. L'environnement d'exécution (runtime) de la fonction Ruby obtient les événements d'invocations de Lambda et les transmet au gestionnaire. Dans la configuration de fonction, la valeur de gestionnaire est `lambda_function.lambda_handler`.

Lorsque vous enregistrez votre code de fonction, la console Lambda crée un package de déploiement d’archive de fichiers .zip. Lorsque vous développez votre code de fonction en dehors de la console (à l’aide d’un IDE), vous devez [créer un package de déploiement](ruby-package.md) pour charger votre code dans la fonction Lambda.

Le runtime de la fonction transmet un objet de contexte au gestionnaire, en plus de l’événement d’invocation. L’[objet de contexte](ruby-context.md) contient des informations supplémentaires sur l’invocation, la fonction et l’environnement d’exécution. Des informations supplémentaires sont disponibles dans les variables d’environnement.

Votre fonction Lambda est fournie avec un groupe de CloudWatch journaux Logs. La fonction runtime envoie les détails de chaque appel à CloudWatch Logs. Il relaie tous les [journaux que votre fonction génère](ruby-logging.md) pendant l’invocation. Si votre fonction renvoie une erreur, Lambda met en forme l’erreur et la renvoie à l’appelant.

**Topics**
+ [Versions du SDK incluses dans l’environnement d’exécution](#ruby-sdk-included)
+ [Activer un autre JIT Ruby (YJIT)](#ruby-yjit)
+ [Définition du gestionnaire de fonction Lambda dans Ruby](ruby-handler.md)
+ [Déployer des fonctions Lambda en Ruby avec des archives de fichiers .zip](ruby-package.md)
+ [Déploiement de fonctions Lambda en Ruby avec des images conteneurs](ruby-image.md)
+ [Utilisation de couches pour les fonctions Lambda Ruby](ruby-layers.md)
+ [Utilisation de l’objet de contexte Lambda pour récupérer les informations de la fonction Ruby](ruby-context.md)
+ [Journalisation et surveillance des fonctions Lambda Ruby](ruby-logging.md)
+ [Instrumentation du code Ruby dans AWS Lambda](ruby-tracing.md)

## Versions du SDK incluses dans l’environnement d’exécution
<a name="ruby-sdk-included"></a>

La version du AWS SDK incluse dans le runtime Ruby dépend de la version d'exécution et de votre Région AWS. Le AWS SDK pour Ruby est conçu pour être modulaire et est séparé par Service AWS. Pour trouver le numéro de version d’un gem de service particulier inclus dans l’environnement d’exécution que vous utilisez, créez une fonction Lambda avec un code au format suivant. Remplacez `aws-sdk-s3` et `Aws::S3` par le nom des gems de service utilisés par votre code.

```
require 'aws-sdk-s3'

def lambda_handler(event:, context:)
  puts "Service gem version: #{Aws::S3::GEM_VERSION}"
  puts "Core version: #{Aws::CORE_GEM_VERSION}"
end
```

## Activer un autre JIT Ruby (YJIT)
<a name="ruby-yjit"></a>

Les environnements d'exécution Ruby supportent [YJIT](https://docs.ruby-lang.org/en/master/jit/yjit_md.html), un compilateur Ruby JIT léger et minimaliste. YJIT offre des performances nettement supérieures, mais utilise également plus de mémoire que l'interpréteur Ruby. YJIT est recommandé pour les charges de travail Ruby on Rails.

YJIT n'est pas activé par défaut. Pour activer YJIT pour une fonction Ruby, définissez la variable d'`RUBY_YJIT_ENABLE`environnement sur`1`. Pour confirmer que YJIT est activé, imprimez le résultat de la méthode `RubyVM::YJIT.enabled?`.

**Example – Confirmez que YJIT est activé**  

```
puts(RubyVM::YJIT.enabled?())
# => true
```