Ceci est le guide du AWS CDK développeur de la version 2. L'ancienne CDK version 1 est entrée en maintenance le 1er juin 2022 et a pris fin le 1er juin 2023.
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.
Tutoriel : Créez votre première AWS CDK application
Commencez à utiliser le en AWS Cloud Development Kit (AWS CDK) utilisant l'interface de ligne de AWS CDK commande (AWS CDK CLI) pour développer votre première CDK application, démarrer votre AWS environnement et y déployer votre application. AWS
Prérequis
Avant de commencer ce didacticiel, effectuez toutes les étapes de configuration dansCommencer à utiliser le AWS CDK.
À propos de ce didacticiel
Dans ce didacticiel, vous allez créer et déployer une application simple AWS utilisant le AWS CDK. L'application consiste en une AWS Lambda fonction qui renvoie un Hello World!
message lorsqu'elle est invoquée. La fonction sera invoquée via une fonction Lambda URL qui sert de point de terminaison HTTP (S) dédié à votre fonction Lambda.
Dans le cadre de ce didacticiel, vous allez effectuer les opérations suivantes :
-
Créez votre projet — Créez un CDK projet à l'aide du CDK CLI
cdk init
commande. -
Configuration de votre AWS environnement : configurez l' AWS environnement dans lequel vous allez déployer votre application.
-
Démarrez votre AWS environnement : préparez votre AWS environnement pour le déploiement en le démarrant à l'aide du CDK CLI
cdk bootstrap
commande. -
Développez votre application : utilisez les constructions de la bibliothèque AWS Construct pour définir votre fonction Lambda et les ressources de la fonction Lambda. URL
-
Préparez votre application pour le déploiement : utilisez le CDK CLI pour créer votre application et synthétiser un AWS CloudFormation modèle.
-
Déployez votre application : utilisez le CDK CLI
cdk deploy
commande pour déployer votre application et provisionner vos AWS ressources. -
Interagissez avec votre application : interagissez avec votre fonction Lambda déployée AWS en l'invoquant et en recevant une réponse.
-
Modifiez votre application : modifiez votre fonction Lambda et déployez-la pour implémenter vos modifications.
-
Supprimer votre application : supprimez toutes les ressources que vous avez créées à l'aide du CDK CLI
cdk destroy
commande.
Étape 1 : Créez votre CDK projet
Au cours de cette étape, vous allez créer un nouveau CDK projet. Un CDK projet doit se trouver dans son propre répertoire, avec ses propres dépendances de module locales.
Pour créer un CDK projet
-
À partir du répertoire de départ de votre choix, créez et naviguez vers un répertoire nommé
hello-cdk
:$
mkdir hello-cdk && cd hello-cdk
Important
Assurez-vous de nommer le répertoire de votre projet
hello-cdk
, exactement comme indiqué ici. Le CDK CLI utilise ce nom de répertoire pour nommer les éléments de votre CDK code. Si vous utilisez un autre nom de répertoire, vous rencontrerez des problèmes au cours de ce didacticiel. -
Dans le
hello-cdk
répertoire, initialisez un nouveau CDK projet à l'aide du CDK CLIcdk init
commande. Spécifiez leapp
modèle et votre langage de programmation préféré à l'aide de l'--language
option suivante :
La cdk init
commande crée une structure de fichiers et de dossiers dans le hello-cdk
répertoire pour aider à organiser le code source de votre CDK application. Cette structure de fichiers et de dossiers s'appelle votre CDK projet. Prenez le temps d'explorer votre CDK projet.
Si vous avez Git installé, chaque projet que vous créez à l'aide cdk init
est également initialisé en tant que Git repository.
Lors de l'initialisation du projet, CDK CLI crée une CDK application contenant une seule CDK pile. L'instance de CDK l'application est créée à l'aide de la App
construction. Voici une partie de ce code provenant de votre dossier de CDK candidature :
La CDK pile est créée à l'aide de la Stack
construction. Voici une partie de ce code provenant de votre fichier de CDK pile :
Étape 2 : Configuration de votre AWS environnement
Au cours de cette étape, vous configurez l' AWS environnement de votre CDK stack. Ce faisant, vous spécifiez l'environnement dans lequel votre CDK stack sera déployé.
Déterminez d'abord l' AWS environnement que vous souhaitez utiliser. Un AWS environnement se compose d'un Compte AWS et Région AWS.
Lorsque vous utilisez le AWS CLI pour configurer les informations d'identification de sécurité sur votre machine locale, vous pouvez ensuite utiliser le AWS CLI pour obtenir des informations d' AWS environnement pour un profil spécifique.
Pour utiliser le AWS CLI pour obtenir votre Compte AWS identifiant
-
Exécutez la AWS CLI commande suivante pour obtenir l' Compte AWS identifiant de votre
default
profil :$
aws sts get-caller-identity --query "Account" --output text
-
Si vous préférez utiliser un profil nommé, indiquez le nom de votre profil à l'aide de l'
--profile
option suivante :$
aws sts get-caller-identity --profile
your-profile-name
--query "Account" --output text
Pour utiliser le AWS CLI pour obtenir votre Région AWS
-
Exécutez la AWS CLI commande suivante pour obtenir la région que vous avez configurée pour votre
default
profil :$
aws configure get region
-
Si vous préférez utiliser un profil nommé, indiquez le nom de votre profil à l'aide de l'
--profile
option suivante :$
aws configure get region --profile
your-profile-name
Vous allez ensuite configurer l' AWS environnement de votre CDK stack en modifiant l'HelloCdkStack
instance dans votre fichier d'application. Dans le cadre de ce didacticiel, vous allez coder en dur les informations relatives à votre AWS environnement. Cela est recommandé pour les environnements de production. Pour plus d'informations sur les autres méthodes de configuration des environnements, consultezConfigurer les environnements à utiliser avec AWS CDK.
Pour configurer l'environnement de votre CDK stack
-
Dans votre fichier d'application, utilisez la
env
propriété de laStack
construction pour configurer votre environnement. Voici un exemple :
Étape 3 : Bootstrap votre environnement AWS
Au cours de cette étape, vous allez démarrer l' AWS environnement que vous avez configuré à l'étape précédente. Cela prépare votre environnement aux CDK déploiements.
Pour démarrer votre environnement, exécutez ce qui suit depuis la racine de votre CDK projet :
$
cdk bootstrap
En démarrant depuis la racine de votre CDK projet, vous n'avez pas à fournir d'informations supplémentaires. Le CDK CLI obtient des informations sur l'environnement à partir de votre projet. Lorsque vous démarrez en dehors d'un CDK projet, vous devez fournir des informations sur l'environnement avec la cdk bootstrap
commande. Pour de plus amples informations, veuillez consulter Démarrez votre environnement pour l'utiliser avec AWS CDK.
Étape 4 : Créez votre CDK application
Dans la plupart des environnements de programmation, vous créez ou compilez du code après avoir apporté des modifications. Cela n'est pas nécessaire AWS CDK étant donné que CDK CLI exécutera automatiquement cette étape. Cependant, vous pouvez toujours créer manuellement lorsque vous souhaitez détecter des erreurs de syntaxe et de type. Voici un exemple :
Étape 5 : Répertoriez les CDK piles dans votre application
À ce stade, vous devriez avoir une CDK application contenant une seule CDK pile. Pour vérifier, utilisez CDK CLI cdk list
commande pour afficher vos piles. La sortie doit afficher une seule pile nommée HelloCdkStack
:
$
cdk list
HelloCdkStack
Si ce résultat ne s'affiche pas, vérifiez que vous vous trouvez dans le bon répertoire de travail de votre projet et réessayez. Si vous ne voyez toujours pas votre pile, répétez l'opération Étape 1 : Créez votre CDK projet et réessayez.
Étape 6 : Définissez votre fonction Lambda
Au cours de cette étape, vous importez le aws_lambda
module depuis la AWS bibliothèque de constructions et vous utilisez la construction Function
L2.
Modifiez votre fichier de CDK pile comme suit :
Regardons la Function
construction de plus près. Comme toutes les constructions, la Function
classe prend trois paramètres :
-
scope — Définit votre
Stack
instance en tant que parent de laFunction
construction. Toutes les constructions qui définissent les AWS ressources sont créées dans le cadre d'une pile. Vous pouvez définir des constructions à l'intérieur des constructions, en créant une hiérarchie (arbre). Ici, et dans la plupart des cas, le champ d'application estthis
(self
en Python). -
Id — L'ID de construction du
Function
dans votre AWS CDK application. Cet identifiant, associé à un hachage basé sur l'emplacement de la fonction dans la pile, identifie de manière unique la fonction lors du déploiement. AWS CDK Il fait également référence à cet ID lorsque vous mettez à jour la structure dans votre application et que vous la redéployez pour mettre à jour la ressource déployée. Ici, votre identifiant de construction estHelloWorldFunction
. Les fonctions peuvent également avoir un nom, spécifié avec lafunctionName
propriété. Ceci est différent de l'ID de construction. -
props — Ensemble de valeurs qui définissent les propriétés de la fonction. Vous définissez ici les
code
propriétésruntime
handler
,, et.Les accessoires sont représentés différemment dans les langues prises en charge par le AWS CDK.
-
Entrée TypeScript and JavaScript,
props
est un argument unique et vous transmettez un objet contenant les propriétés souhaitées. -
Entrée Python, les accessoires sont transmis sous forme d'arguments de mots clés.
-
Entrée Java, un constructeur est fourni pour faire passer les accessoires. Il y en a deux : une pour
FunctionProps
, et une secondeFunction
pour vous permettre de construire la construction et ses accessoires en une seule étape. Ce code utilise ce dernier. -
Entrée C#, vous instanciez un
FunctionProps
objet à l'aide d'un initialiseur d'objet et vous le transmettez comme troisième paramètre.
Si les accessoires d'une construction sont facultatifs, vous pouvez omettre complètement le
props
paramètre. -
Toutes les constructions utilisent ces trois mêmes arguments, il est donc facile de rester orienté lorsque vous en découvrez de nouveaux. Et comme vous pouvez vous y attendre, vous pouvez sous-classer n'importe quelle construction pour l'étendre en fonction de vos besoins, ou si vous souhaitez modifier ses valeurs par défaut.
Étape 7 : Définissez votre fonction Lambda URL
Dans cette étape, vous allez utiliser la méthode addFunctionUrl
auxiliaire de la Function
construction pour définir une fonction URL Lambda. Pour en afficher la valeur URL lors du déploiement, vous allez créer une AWS CloudFormation sortie à l'aide de la CfnOutput
construction.
Ajoutez ce qui suit à votre fichier de CDK pile :
Avertissement
Pour simplifier ce didacticiel, votre fonction Lambda URL est définie sans authentification. Une fois déployé, cela crée un point de terminaison accessible au public qui peut être utilisé pour appeler votre fonction. Lorsque vous aurez terminé ce didacticiel, suivez Étape 12 : Supprimer votre application pour supprimer ces ressources.
Étape 8 : Synthétiser un modèle CloudFormation
Au cours de cette étape, vous préparez le déploiement en synthétisant un CloudFormation modèle avec CDK CLI cdk
synth
commande. Cette commande effectue une validation de base de votre CDK code, exécute votre CDK application et génère un CloudFormation modèle à partir de votre CDK pile.
Si votre application contient plusieurs piles, vous devez spécifier les piles à synthétiser. Étant donné que votre application ne contient qu'une seule pile, le CDK CLI détecte automatiquement la pile à synthétiser.
Si vous ne synthétisez pas de modèle, CDK CLI exécutera automatiquement cette étape lors du déploiement. Toutefois, nous vous recommandons d'exécuter cette étape avant chaque déploiement afin de vérifier les erreurs de synthèse.
Avant de synthétiser un modèle, vous pouvez éventuellement créer votre application pour détecter les erreurs de syntaxe et de type. Pour obtenir des instructions, consultez Étape 4 : Créez votre CDK application.
Pour synthétiser un CloudFormation modèle, exécutez ce qui suit depuis la racine de votre projet :
$
cdk synth
Note
Si le message d'erreur suivant s'affiche, vérifiez que vous êtes bien dans le hello-cdk
répertoire et réessayez :
--app is required either in command-line, in cdk.json or in ~/.cdk.json
En cas de succès, le CDK CLI produira un YAML: CloudFormation modèle formaté vers stdout
et enregistrement d'un JSON: modèle formaté dans le cdk.out
répertoire de votre projet.
Voici un exemple de sortie du CloudFormation modèle :
Resources: HelloWorldFunctionServiceRole
unique-identifier
: Type: AWS::IAM::Role Properties: AssumeRolePolicyDocument: Statement: - Action: sts:AssumeRole Effect: Allow Principal: Service: lambda.amazonaws.com Version: "2012-10-17" ManagedPolicyArns: - Fn::Join: - "" - - "arn:" - Ref: AWS::Partition - :iam::aws:policy/service-role/AWSLambdaBasicExecutionRole Metadata: aws:cdk:path: HelloCdkStack/HelloWorldFunction/ServiceRole/Resource HelloWorldFunctionunique-identifier
: Type: AWS::Lambda::Function Properties: Code: ZipFile: " \ exports.handler = async function(event) { \ return { \ statusCode: 200, \ body: JSON.stringify('Hello World!'), \ }; \ }; \ " Handler: index.handler Role: Fn::GetAtt: - HelloWorldFunctionServiceRoleunique-identifier
- Arn Runtime: nodejs20.x DependsOn: - HelloWorldFunctionServiceRoleunique-identifier
Metadata: aws:cdk:path: HelloCdkStack/HelloWorldFunction/Resource HelloWorldFunctionFunctionUrlunique-identifier
: Type: AWS::Lambda::Url Properties: AuthType: NONE TargetFunctionArn: Fn::GetAtt: - HelloWorldFunctionunique-identifier
- Arn Metadata: aws:cdk:path: HelloCdkStack/HelloWorldFunction/FunctionUrl/Resource HelloWorldFunctioninvokefunctionurlunique-identifier
: Type: AWS::Lambda::Permission Properties: Action: lambda:InvokeFunctionUrl FunctionName: Fn::GetAtt: - HelloWorldFunctionunique-identifier
- Arn FunctionUrlAuthType: NONE Principal: "*" Metadata: aws:cdk:path: HelloCdkStack/HelloWorldFunction/invoke-function-url CDKMetadata: Type: AWS::CDK::Metadata Properties: Analytics: v2:deflate64:unique-identifier
Metadata: aws:cdk:path: HelloCdkStack/CDKMetadata/Default Condition: CDKMetadataAvailable Outputs: myFunctionUrlOutput: Value: Fn::GetAtt: - HelloWorldFunctionFunctionUrlunique-identifier
- FunctionUrl Parameters: BootstrapVersion: Type: AWS::SSM::Parameter::Value<String> Default: /cdk-bootstrap/unique-identifier
/version Description: Version of the CDK Bootstrap resources in this environment, automatically retrieved from SSM Parameter Store. [cdk:skip] Rules: CheckBootstrapVersion: Assertions: - Assert: Fn::Not: - Fn::Contains: - - "1" - "2" - "3" - "4" - "5" - Ref: BootstrapVersion AssertDescription: CDK bootstrap stack version 6 required. Please run 'cdk bootstrap' with a recent version of the CDK CLI.
Note
Chaque modèle généré contient une AWS::CDK::Metadata
ressource par défaut. L' AWS CDK équipe utilise ces métadonnées pour mieux comprendre AWS CDK l'utilisation et trouver des moyens de l'améliorer. Pour plus de détails, notamment pour savoir comment désactiver les rapports de version, consultezRapport sur les versions.
En définissant une seule construction L2, vous AWS CDK créez un CloudFormation modèle complet contenant vos ressources Lambda, ainsi que les autorisations et la logique de collage requises pour que vos ressources interagissent au sein de votre application.
Étape 9 : Déployez votre CDK stack
Au cours de cette étape, vous utilisez CDK CLI cdk deploy
commande pour déployer votre CDK stack. Cette commande récupère le CloudFormation modèle que vous avez généré et le déploie AWS CloudFormation, ce qui permet de provisionner vos ressources dans le cadre d'une CloudFormation pile.
À partir de la racine de votre projet, exécutez ce qui suit. Confirmez les modifications si vous y êtes invité :
$
cdk deploy
✨ Synthesis time: 2.69s HelloCdkStack: start: Buildingunique-identifier
:current_account-current_region HelloCdkStack: success: Builtunique-identifier
:current_account-current_region HelloCdkStack: start: Publishingunique-identifier
:current_account-current_region HelloCdkStack: success: Publishedunique-identifier
:current_account-current_region This deployment will make potentially sensitive changes according to your current security approval level (--require-approval broadening). Please confirm you intend to make the following modifications: IAM Statement Changes ┌───┬───────────────────────────────────────┬────────┬──────────────────────────┬──────────────────────────────┬───────────┐ │ │ Resource │ Effect │ Action │ Principal │ Condition │ ├───┼───────────────────────────────────────┼────────┼──────────────────────────┼──────────────────────────────┼───────────┤ │ + │ ${HelloWorldFunction.Arn} │ Allow │ lambda:InvokeFunctionUrl │ * │ │ ├───┼───────────────────────────────────────┼────────┼──────────────────────────┼──────────────────────────────┼───────────┤ │ + │ ${HelloWorldFunction/ServiceRole.Arn} │ Allow │ sts:AssumeRole │ Service:lambda.amazonaws.com │ │ └───┴───────────────────────────────────────┴────────┴──────────────────────────┴──────────────────────────────┴───────────┘ IAM Policy Changes ┌───┬───────────────────────────────────┬────────────────────────────────────────────────────────────────────────────────┐ │ │ Resource │ Managed Policy ARN │ ├───┼───────────────────────────────────┼────────────────────────────────────────────────────────────────────────────────┤ │ + │ ${HelloWorldFunction/ServiceRole} │ arn:${AWS::Partition}:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole │ └───┴───────────────────────────────────┴────────────────────────────────────────────────────────────────────────────────┘ (NOTE: There may be security-related changes not in this list. See https://github.com/aws/aws-cdk/issues/1299) Do you wish to deploy these changes (y/n)?y
De mêmecdk synth
, il n'est pas nécessaire de spécifier la AWS CDK pile puisque l'application ne contient qu'une seule pile.
Au cours du déploiement, CDK CLI affiche les informations de progression au fur et à mesure du déploiement de votre stack. Lorsque vous avez terminé, vous pouvez accéder à la AWS CloudFormation consoleHelloCdkStack
pile. Vous pouvez également accéder à la console Lambda pour consulter votre HelloWorldFunction
ressource.
Une fois le déploiement terminé, CDK CLI affichera votre point de terminaisonURL. Copiez-le URL pour l'étape suivante. Voici un exemple :
... HelloCdkStack: deploying... [1/1] HelloCdkStack: creating CloudFormation changeset... ✅ HelloCdkStack ✨ Deployment time: 41.65s Outputs: HelloCdkStack.myFunctionUrlOutput = https://
<api-id>
.lambda-url.<Region>
.on.aws/ Stack ARN: arn:aws:cloudformation:Region
:account-id
:stack/HelloCdkStack/unique-identifier
✨ Total time: 44.34s
Étape 10 : Interagissez avec votre application sur AWS
Au cours de cette étape, vous interagissez avec votre application AWS en invoquant votre fonction Lambda par le biais de cette fonction. URL Lorsque vous accédez auURL, votre fonction Lambda renvoie le Hello World!
message.
Pour appeler votre fonction, accédez-y par le URL biais de votre navigateur ou de la ligne de commande. Voici un exemple :
$
curl https://
"Hello World!"%<api-id>
.lambda-url.<Region>
.on.aws/
Étape 11 : Modifiez votre candidature
Au cours de cette étape, vous modifiez le message renvoyé par la fonction Lambda lorsqu'elle est invoquée. Vous effectuez une différence à l'aide du CDK CLI cdk diff
commande pour prévisualiser vos modifications et déployer pour mettre à jour votre application. Vous interagissez ensuite avec votre application AWS pour voir votre nouveau message.
Modifiez l'myFunction
instance dans votre fichier de CDK pile comme suit :
À l'heure actuelle, vos modifications de code n'ont entraîné aucune mise à jour directe de votre ressource Lambda déployée. Votre code définit l'état souhaité pour votre ressource. Pour modifier votre ressource déployée, vous allez utiliser CDK CLI pour synthétiser l'état souhaité dans un nouveau AWS CloudFormation modèle. Vous déploierez ensuite votre nouveau CloudFormation modèle sous forme d'ensemble de modifications. Les ensembles de modifications apportent uniquement les modifications nécessaires pour atteindre le nouvel état souhaité.
Pour prévisualiser vos modifications, exécutez la cdk diff
commande. Voici un exemple :
$
cdk diff
Stack HelloCdkStack Hold on while we create a read-only change set to get a diff with accurate replacement information (use --no-change-set to use a less accurate but faster template-only diff) Resources [~] AWS::Lambda::Function HelloWorldFunction HelloWorldFunctionunique-identifier
└─ [~] Code └─ [~] .ZipFile: ├─ [-] exports.handler = async function(event) { return { statusCode: 200, body: JSON.stringify('Hello World!'), }; }; └─ [+] exports.handler = async function(event) { return { statusCode: 200, body: JSON.stringify('Hello CDK!'), }; }; ✨ Number of stacks with differences: 1
Pour créer cette différence, CDK CLI interroge votre Compte AWS compte pour obtenir le dernier AWS CloudFormation modèle de la HelloCdkStack
pile. Ensuite, il compare le dernier modèle avec le modèle qu'il vient de synthétiser à partir de votre application.
Pour implémenter vos modifications, exécutez la cdk deploy
commande. Voici un exemple :
$
cdk deploy
✨ Synthesis time: 2.12s HelloCdkStack: start: Buildingunique-identifier
:current_account-current_region HelloCdkStack: success: Builtunique-identifier
:current_account-current_region HelloCdkStack: start: Publishingunique-identifier
:current_account-current_region HelloCdkStack: success: Publishedunique-identifier
:current_account-current_region HelloCdkStack: deploying... [1/1] HelloCdkStack: creating CloudFormation changeset... ✅ HelloCdkStack ✨ Deployment time: 26.96s Outputs: HelloCdkStack.myFunctionUrlOutput = https://unique-identifier
.lambda-url.<Region>
.on.aws/ Stack ARN: arn:aws:cloudformation:Region
:account-id
:stack/HelloCdkStack/unique-identifier
✨ Total time: 29.07s
Pour interagir avec votre application, répétez l'opérationÉtape 10 : Interagissez avec votre application sur AWS. Voici un exemple :
$
curl https://
"Hello CDK!"%<api-id>
.lambda-url.<Region>
.on.aws/
Étape 12 : Supprimer votre application
Au cours de cette étape, vous utilisez CDK CLI cdk destroy
commande pour supprimer votre application. Cette commande supprime la CloudFormation pile associée à votre CDK pile, qui inclut les ressources que vous avez créées.
Pour supprimer votre application, exécutez la cdk destroy
commande et confirmez votre demande de suppression de l'application. Voici un exemple :
$
cdk destroy
Are you sure you want to delete: HelloCdkStack (y/n)?y
HelloCdkStack: destroying... [1/1] ✅ HelloCdkStack: destroyed
Étapes suivantes
Félicitations ! Vous avez terminé ce didacticiel et vous avez utilisé le AWS CDK pour créer, modifier et supprimer avec succès des ressources dans le AWS Cloud. Vous êtes maintenant prêt à commencer à utiliser le AWS CDK.
Pour en savoir plus sur l'utilisation du AWS CDK dans votre langage de programmation préféré, consultezCollaborez avec la AWS CDK bibliothèque.
Pour des ressources supplémentaires, consultez les rubriques suivantes :
-
Essayez l'CDKatelier
pour une visite plus approfondie impliquant un projet plus complexe. -
Consultez la APIréférence pour commencer à explorer les CDK constructions disponibles pour vos AWS services préférés.
-
Visitez Construct Hub
pour découvrir les constructions créées par AWS et d'autres. -
Découvrez des exemples
d'utilisation du AWS CDK.
AWS CDK Il s'agit d'un projet open source. Pour contribuer, voir Contribuer au AWS Cloud Development Kit (AWS CDK)