Esta es la guía para AWS CDK desarrolladores de la versión 2. La CDK versión anterior entró en mantenimiento el 1 de junio de 2022 y finalizó el soporte el 1 de junio de 2023.
Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.
cdk deploy
Implemente una o más pilas de AWS CDK en su entorno de AWS.
Durante la implementación, la CLI de CDK generará indicadores de progreso, similares a los que se pueden observar desde la consola AWS CloudFormation.
Si el entorno de AWS no está en fase de arranque, solo se sintetizarán correctamente las pilas sin activos y con plantillas sintetizadas de menos de 51 200 bytes.
Uso
$
cdk deploy
<arguments>
<options>
Argumentos
- ID de pila de CDK
-
El ID de constructo de la pila de CDK correspondiente a la aplicación que desea eliminar.
Tipo: cadena
Obligatorio: no
Opciones
Para obtener una lista de las opciones globales que funcionan con todos los comandos de la CLI de CDK, consulte Opciones globales.
--all
BOOLEAN
-
Implemente todas las pilas en su aplicación CDK.
Valor predeterminado:
false
--asset-parallelism
BOOLEAN
-
Especifique si desea crear y publicar activos en paralelo.
--asset-prebuild
BOOLEAN
-
Especifique si desea crear todos los activos antes de implementar la primera pila. Esta opción es útil para compilaciones Docker fallidas.
Valor predeterminado:
true
--build-exclude, -E
ARRAY
-
No reconstruya el activo con el identificador indicado.
Esta opción se puede especificar varias veces en un mismo comando.
Valor predeterminado:
[]
--change-set-name
STRING
-
El nombre del cambio de AWS CloudFormation que se va a crear.
Esta opción no es compatible con
--method='direct'
. --concurrency
NUMBER
-
Implemente múltiples pilas en paralelo y, al mismo tiempo, tenga en cuenta las dependencias entre pilas. Utilice esta opción para acelerar las implementaciones. Aún debe factorizar en AWS CloudFormation y otros límites de índices de Cuenta de AWS.
Proporcione un número para especificar el número máximo de implementaciones simultáneas (si la dependencia lo permite) que se deben realizar.
Valor predeterminado:
1
--exclusively, -e
BOOLEAN
-
Implemente solo las pilas solicitadas y no incluya las dependencias.
--force, -f
BOOLEAN
-
Cuando implemente para actualizar una pila existente, la CLI de CDK comparará la plantilla y las etiquetas de la pila implementada con las de la pila que se va a implementar. Si no se detectan cambios, la CLI de CDK se saltará la implementación.
Para anular este comportamiento e implementar siempre las pilas, incluso si no se detectan cambios, utilice esta opción.
Valor predeterminado:
false
--help, -h
BOOLEAN
-
Muestra la información de referencia del comando
cdk deploy
. --hotswap
BOOLEAN
-
Implementaciones de cambio en caliente para un desarrollo más rápido. Esta opción intenta realizar una implementación de cambio de caliente más rápida si es posible. Por ejemplo, si modifica el código de una función de Lambda en su aplicación de CDK, la CLI de CDK actualizará el recurso directamente a través de las API de servicio en lugar de realizar una implementación de CloudFormation.
Si la CLI de CDK detecta cambios que no admiten el cambio en caliente, dichos cambios se ignorarán y aparecerá un mensaje. Si prefiere realizar una implementación completa de CloudFormation como alternativa, utilice
--hotswap-fallback
en su lugar.La CLI de CDK usa sus credenciales de AWS actuales para realizar las llamadas a la API. No asume las funciones de su pila de arranque, incluso si el indicador de característica
@aws-cdk/core:newStyleStackSynthesis
está establecido entrue
. Esas funciones no tienen los permisos necesarios para actualizar los recursos de AWS directamente sin usar CloudFormation. Por ese motivo, asegúrese de que sus credenciales pertenezcan a las mismas Cuenta de AWS de las pilas que va a realizar las implementaciones de cambio en caliente y de que cuenten con los permisos de IAM necesarios para actualizar los recursos.El cambio en caliente se admite actualmente para los siguientes cambios:
-
Activos de código (incluidas imágenes Docker y código en línea), cambios de etiquetas y cambios de configuración (solo se admiten variables de descripción y entorno) de las funciones de Lambda.
-
Versiones de Lambda y cambios de alias.
-
Cambios de definición de máquinas de estado AWS Step Functions.
-
Cambios en los activos de contenedores de los servicios de Amazon ECS.
-
Cambios en los activos del sitio web de las implementaciones de bucket de Amazon S3.
-
Cambios en el origen y el entorno de los proyectos AWS CodeBuild.
-
Cambios en la plantilla de mapeo de VTL para resolutores AWS AppSync y funciones.
-
Cambios en el esquema de las API AWS AppSync GraphQL.
Se admite el uso de determinadas funciones intrínsecas de CloudFormation como parte de una implementación de cambio en caliente. Entre ellos se incluyen:
-
Ref
-
Fn::GetAtt
: solo se admite parcialmente. Consulte esta implementaciónpara conocer los recursos y atributos compatibles. -
Fn::ImportValue
-
Fn::Join
-
Fn::Select
-
Fn::Split
-
Fn::Sub
Esta opción también es compatible con las pilas anidadas.
nota
-
Esta opción introduce deliberadamente una desviación en las pilas de CloudFormation para acelerar las implementaciones. Por este motivo, utilícela únicamente con fines de desarrollo. No utilice esta opción para sus implementaciones de producción.
-
Esta opción se considera experimental y es posible que se someta a cambios importantes en el futuro.
-
Los valores predeterminados de algunos parámetros pueden ser diferentes a los del parámetro de cambio en caliente. Por ejemplo, el porcentaje mínimo de estado de un servicio Amazon ECS se establecerá actualmente en
0
. Si esto ocurre, revise la fuente en consecuencia.
Valor predeterminado:
false
-
--hotswap-fallback
BOOLEAN
-
Esta opción es similar a
--hotswap
. La diferencia es que--hotswap-fallback
recurrirá a realizar una implementación completa de CloudFormation si se detecta un cambio que lo requiera.Para obtener más información acerca de esta opción, consulte
--hotswap
.Valor predeterminado:
false
--ignore-no-stacks
BOOLEAN
-
Realice una implementación incluso si su aplicación de CDK no contiene ninguna pila.
Esta opción resulta útil en el siguiente escenario: puede que tenga una aplicación con varios entornos, como
dev
y.prod
Al iniciar el desarrollo, es posible que su aplicación de producción no tenga ningún recurso o que los recursos estén comentados. Esto provocará un error de implementación con un mensaje que indica que la aplicación no tiene pilas. Utilice--ignore-no-stacks
para evitar este error.Valor predeterminado:
false
--logs
BOOLEAN
-
Muestre el registro de Amazon CloudWatch en la salida estándar (
stdout
) para todos los eventos de todos los recursos de las pilas seleccionadas.Esta opción es únicamente compatible con
--watch
.Valor predeterminado:
true
--method, -m
STRING
-
Configure el método para ejecutar una implementación.
-
change-set
: método predeterminado. La CLI de CDK crea un conjunto de cambios de CloudFormation con los cambios que se implementarán y, a continuación, realiza la implementación. -
direct
: no cree un conjunto de cambios. En su lugar, aplique el cambio inmediatamente. Esto suele ser más rápido que crear un conjunto de cambios, pero se pierde la información de progreso. -
prepare-change-set
: cree un conjunto de cambios pero no realice la implementación. Esto resulta útil si dispone de herramientas externas que inspeccionarán el conjunto de cambios o si tiene un proceso de aprobación de los conjuntos de cambios.
Valores válidos:
change-set
,direct
,prepare-change-set
Valor predeterminado:
change-set
-
--notification-arns
ARRAY
-
Los ARN de los temas de Amazon SNS que CloudFormation notificará en caso de eventos relacionados con la pila.
--outputs-file, -O
STRING
-
La ruta en la que se escriben los resultados de la pila de las implementaciones.
Tras la implementación, los resultados de la pila se escribirán en el archivo de salida especificado en formato JSON.
Puede configurar esta opción en el archivo
cdk.json
del proyecto o en~/.cdk.json
en su máquina de desarrollo local:{ "app": "npx ts-node bin/myproject.ts", // ... "outputsFile": "outputs.json" }
Si se implementan varias pilas, los resultados se escriben en el mismo archivo de salida, organizados por claves que representan el nombre de la pila.
--parameters
ARRAY
-
Transfiera parámetros adicionales a CloudFormation durante la implementación.
Esta opción acepta una matriz con el siguiente formato:
STACK:KEY=VALUE
.-
STACK
: el nombre de la pila con la que se va a asociar el parámetro. -
KEY
: el nombre del parámetro de la pila. -
VALUE
: el valor que se transferirá en el momento de la implementación.
Si no se proporciona un nombre de pila, o si se proporciona
*
como nombre de pila, los parámetros se aplicarán a todas las pilas que se estén implementando. Si una pila no utiliza el parámetro, la implementación fallará.Los parámetros no se propagan a las pilas anidadas. Para pasar los parámetros a las pilas anidadas, utilice el constructo
NestedStack
.Valor predeterminado:
{}
-
--previous-parameters
BOOLEAN
-
Utilice los valores anteriores para los parámetros existentes.
Si esta opción está establecida en
false
, debe especificar todos los parámetros de cada implementación.Valor predeterminado:
true
--progress
STRING
-
Configure la forma en que la CLI de CDK muestra el progreso de la implementación.
-
bar
: muestra los eventos de implementación de la pila como una barra de progreso, con los eventos del recurso que se está implementando actualmente. -
events
: proporciona un historial completo, incluidos todos los eventos de CloudFormation.
También puede configurar esta opción en el archivo
cdk.json
del proyecto o en~/.cdk.json
en su máquina de desarrollo local:{ "progress": "events" }
Valores válidos:
bar
,events
Valor predeterminado:
bar
-
--require-approval
STRING
-
Especifique qué cambios importantes desde el punto de vista de la seguridad requieren aprobación manual.
-
any-change
: se requiere una aprobación manual para cualquier cambio en la pila. -
broadening
: se requiere la aprobación manual si los cambios implican una ampliación de los permisos o las reglas de los grupos de seguridad. -
never
: no se requiere aprobación.
Valores válidos:
any-change
,broadening
,never
Valor predeterminado:
broadening
-
--rollback
|--no-rollback
,-R
-
Durante la implementación, si no se puede crear o actualizar un recurso, la implementación volverá al último estado estable antes de que la CLI de CDK vuelva. Todos los cambios realizados hasta ese momento se anularán. Los recursos que se crearon se eliminarán y las actualizaciones que se hayan realizado se revertirán.
Especifique
--no-rollback
para desactivar este comportamiento. Si no se puede crear o actualizar un recurso, la CLI de CDK dejará en su lugar los cambios realizados hasta ese momento y regresará. Esto dejará la implementación en un estado fallido y pausado. Desde aquí, puede actualizar el código y volver a intentar la implementación. Esto puede resultar útil en entornos de desarrollo en los que se realiza una iteración rápida.Si falla una implementación realizada con
--no-rollback
y decide que quiere revertirla, puede usar el comandocdk rollback
. Para obtener más información, consulte cdk rollback.nota
Con
--no-rollback
, las implementaciones que provocan la sustitución de recursos siempre fallarán. Solo puede utilizar este valor de opción para las implementaciones que actualicen o creen nuevos recursos.Valor predeterminado:
--rollback
--toolkit-stack-name
STRING
-
El nombre de la pila del kit de herramientas de CDK existente.
De forma predeterminada,
cdk bootstrap
implementa una pila con un nombreCDKToolkit
en el entorno de AWS especificado. Utilice esta opción para proporcionar un nombre diferente a la pila de arranque.La CLI de CDK usa este valor para verificar la versión de la pila de arranque.
--watch
BOOLEAN
-
Observe continuamente los archivos de proyecto del CDK e implemente las pilas especificadas automáticamente cuando se detecten cambios.
Esta opción implica
--hotswap
de forma predeterminada.Esta opción tiene un comando de CLI de CDK equivalente. Para obtener más información, consulte cdk watch.
Ejemplos
Implemente la pila llamada MyStackName
$
cdk deploy MyStackName --app='node bin/main.js'
Implemente varias pilas en una aplicación
Utilice cdk list
para enumerar sus pilas:
$
cdk list
CdkHelloWorldStack CdkStack2 CdkStack3
Para implementar todas las pilas, use la opción --all
:
$
cdk deploy --all
Para elegir qué pilas implementar, proporcione los nombres de las pilas como argumentos:
$
cdk deploy CdkHelloWorldStack CdkStack3
Implemente pilas de canalizaciones
Use cdk list
para mostrar los nombres de las pilas como rutas, mostrando dónde se encuentran en la jerarquía de canalización:
$
cdk list
PipelineStack PiplelineStack/Prod PipelineStack/Prod/MyService
Usa la opción --all
o el comodín *
para implementar todas las pilas. Si tiene una jerarquía de pilas como la descrita anteriormente, --all
y *
solo coincidirán con las del nivel superior. Para hacer coincidir todas las pilas de la jerarquía, use **
.
Puede combinar estos patrones. Lo siguiente implementa todas las pilas en el escenario Prod
:
$
cdk deploy PipelineStack/Prod/**
Pase los parámetros en el momento de la implementación
Defina los parámetros en su pila de CDK. A continuación, se muestra un ejemplo de creación de un parámetro con el nombre TopicNameParam
para un tema de Amazon SNS:
new sns.Topic(this, 'TopicParameter', { topicName: new cdk.CfnParameter(this, 'TopicNameParam').value.toString() });
Para proporcionar un valor de parámetro de parameterized
, ejecute lo siguiente:
$
cdk deploy --parameters "MyStackName:TopicNameParam=parameterized"
Puede anular los valores de los parámetros mediante la opción --force
. A continuación, se muestra un ejemplo de cómo anular el nombre de tema de una implementación anterior:
$
cdk deploy --parameters "MyStackName:TopicNameParam=parameterName" --force
Escriba los resultados de la pila en un archivo después de la implementación
Defina las salidas en su archivo de pila de CDK. El siguiente es un ejemplo que crea una salida para función de ARN:
const fn = new lambda.Function(this, "fn", { handler: "index.handler", code: lambda.Code.fromInline(`exports.handler = \${handler.toString()}`), runtime: lambda.Runtime.NODEJS_LATEST }); new cdk.CfnOutput(this, 'FunctionArn', { value: fn.functionArn, });
Implemente la pila y escriba los resultados en outputs.json
:
$
cdk deploy --outputs-file outputs.json
A continuación, se muestra un ejemplo de outputs.json
luego de la implementación:
{ "MyStack": { "FunctionArn": "arn:aws:lambda:us-east-1:123456789012:function:MyStack-fn5FF616E3-G632ITHSP5HK" } }
A partir de este ejemplo, la clave FunctionArn
corresponde al identificador lógico de la instancia CfnOutput
.
A continuación, se muestra un ejemplo de outputs.json
posterior a la implementación en el que se implementan varias pilas:
{ "MyStack": { "FunctionArn": "arn:aws:lambda:us-east-1:123456789012:function:MyStack-fn5FF616E3-G632ITHSP5HK" }, "AnotherStack": { "VPCId": "vpc-z0mg270fee16693f" } }
Modifique el método de implementación
Para realizar una implementación más rápida, sin utilizar conjuntos de cambios, utilice --method='direct'
:
$
cdk deploy --method='direct'
Para crear un conjunto de cambios pero no implementarlo, utilice --method='prepare-change-set'
. De forma predeterminada, se creará un conjunto de cambios con el nombre cdk-deploy-change-set
. Si existe un conjunto de cambios anterior con este nombre, se sobrescribirá. Si no se detecta ningún cambio, se seguirá creando un conjunto de cambios vacío.
También puede asignar un nombre al conjunto de cambios. A continuación, se muestra un ejemplo:
$
cdk deploy --method='prepare-change-set' --change-set-name='MyChangeSetName'