Tutorial: Crear una canalización que publica una aplicación sin servidor en AWS Serverless Application Repository
Puede utilizar AWS CodePipeline para distribuir de manera continua una aplicación sin servidor de AWS SAM al AWS Serverless Application Repository.
importante
Como parte de la creación de una canalización, CodePipeline utilizará un bucket de artefactos de S3 proporcionado por el cliente para los artefactos. (Es diferente del bucket que se usa para una acción de origen de S3). Si el bucket de artefactos de S3 se encuentra en una cuenta diferente a la cuenta de su canalización, asegúrese de que el bucket de artefactos de S3 pertenezca a Cuentas de AWS que sean seguras y fiables.
Este tutorial muestra cómo crear y configurar una canalización para compilar una aplicación sin servidor alojada en GitHub y publicarla en el AWS Serverless Application Repository forma automática. La canalización utiliza como GitHub como proveedor de origen y CodeBuild como proveedor de compilación. Para publicar una aplicación sin servidor en el AWS Serverless Application Repository, debe implementar una aplicación
importante
Muchas de las acciones que agrega a su canalización en este procedimiento implican recursos de AWS que debe crear antes de crear la canalización. Los recursos de AWSpara las acciones de origen siempre deben crearse en la misma región de AWS en la que se creó la canalización. Por ejemplo, si crea la canalización en la región Este de EE. UU. (Ohio) , el repositorio de CodeCommit debe estar en la región Este de EE. UU. (Ohio).
Puede añadir acciones entre regiones al crear su canalización. Los recursos de AWS para las acciones entre regiones deben estar en la misma región de AWS en la que planea ejecutar la acción. Para obtener más información, consulte Agregar una acción entre regiones en CodePipeline.
Antes de empezar
En este tutorial, se presupone lo siguiente.
-
Está familiarizado con AWS Serverless Application Model (AWS SAM) y con el AWS Serverless Application Repository.
-
Dispone de una aplicación sin servidor alojada en GitHub que ha publicado en el AWS Serverless Application Repository mediante la CLI de AWS SAM. Para publicar una aplicación de ejemplo en el AWS Serverless Application Repository, consulte Inicio rápido: Publicación de aplicaciones en la Guía para desarrolladores de AWS Serverless Application Repository. Para publicar su propia aplicación en el AWS Serverless Application Repository, consulte Publicación de aplicaciones mediante la CLI de AWS SAM en la Guía para desarrolladores de AWS Serverless Application Model.
Paso 1: Crear un archivo buildspec.yml
Cree un archivo buildspec.yml
con el siguiente contenido y añádalo al repositorio de GitHub de la aplicación sin servidor. Sustituya template.yml
por la plantilla de AWS SAM de la aplicación y bucketname
por el bucket de S3 en el que está almacenada la aplicación empaquetada.
version: 0.2 phases: install: runtime-versions: python: 3.8 build: commands: - sam package --template-file
template.yml
--s3-bucketbucketname
--output-template-file packaged-template.yml artifacts: files: - packaged-template.yml
Paso 2: Crear y configurar la canalización
Siga estos pasos para crear la canalización en la Región de AWS en la que desea publicar la aplicación sin servidor.
Inicie sesión en la AWS Management Console y abra la consola de CodePipeline en https://console.aws.amazon.com/codepipeline/
. -
Si es necesario, cambie a la Región de AWS en la que desea publicar la aplicación sin servidor.
-
En la página Bienvenido, Introducción o Canalizaciones, elija Crear canalización.
-
En la página Paso 1: Elegir la opción de creación, en Opciones de creación, seleccione la opción Crear una canalización personalizada. Elija Siguiente.
-
Seleccione Create pipeline. En la página Paso 2: Elegir la configuración de la canalización, en Nombre de la canalización, escriba el nombre de la canalización.
-
En Tipo de canalización, seleccione V2. Para obtener más información, consulte Tipos de canalización. Elija Siguiente.
-
En Rol de servicio, elija Nuevo rol de servicio para permitir que CodePipeline cree un rol de servicio en IAM.
-
En Advanced settings (Configuración avanzada), deje los valores predeterminados y elija Next (Siguiente).
-
En la página Añadir fase de origen, en Proveedor de origen, elija GitHub.
-
En Conexión, seleccione una conexión existente o cree una nueva. Para crear o administrar una conexión para su acción de origen de GitHub, consulte Conexiones de GitHub.
-
En Repository (Repositorio), elija el repositorio de código fuente de GitHub.
-
En Branch (Ramificación), elija la ramificación de GitHub.
-
Deje los valores predeterminados restantes para la acción de origen. Elija Siguiente.
-
En la página Add build stage (Añadir etapa de compilación), añada una etapa de compilación:
-
En Build provider (Proveedor de compilación), elija AWS CodeBuild. En Region (Región), utilice la región de la canalización.
-
Elija Crear proyecto.
-
En Project name (Nombre de proyecto), escriba un nombre para este proyecto de compilación.
-
En Environment image (Imagen de entorno), elija Managed image (Imagen administrada). En Operating system (Sistema operativo), elija Ubuntu.
-
En Runtime (Tiempo de ejecución) y Runtime version (Versión de tiempo de ejecución), elija el tiempo de ejecución y la versión necesarios para la aplicación sin servidor.
-
En Service role (Rol de servicio), elija New service role (Nuevo rol de servicio).
-
En Build specifications (Especificaciones de compilación), elija Use a buildspec file (Usar un archivo buildspec).
-
Elija Continue to CodePipeline (Continuar en CodePipeline). Esto abre la consola de CodePipeline y crea un proyecto de CodeBuild que utiliza el archivo
buildspec.yml
del repositorio para la configuración. El proyecto de compilación utiliza un rol de servicio para administrar los permisos del Servicio de AWS. Es posible que este paso tarde un par de minutos. -
Elija Siguiente.
-
-
En la página Add deploy stage (Añadir etapa de implementación), elija Skip deploy stage (Omitir etapa de implementación) y, a continuación, acepte el mensaje de advertencia eligiendo Skip (Omitir) una vez más. Elija Siguiente.
-
Seleccione Create pipeline. Debe ver un diagrama que muestra las etapas de código fuente y de compilación.
-
Conceda al rol de servicio de CodeBuild permiso para obtener acceso al bucket de S3 en el que está almacenada la aplicación empaquetada.
-
En la etapa Compilación de la canalización nueva, elija CodeBuild.
-
Elija la pestaña Build details (Detalles de compilación).
-
En Entorno, elija el rol de servicio de CodeBuild para abrir la consola de IAM.
-
Amplíe la selección para
CodeBuildBasePolicy
y elija Edit policy (Editar política). -
Elija JSON.
-
Añada una instrucción de política nueva con el siguiente contenido. La instrucción permite a CodeBuild colocar objetos en el bucket de S3 en el que está almacenada la aplicación empaquetada. Sustituya
bucketname
por el nombre del bucket de S3.{ "Effect": "Allow", "Resource": [ "arn:aws:s3:::
bucketname
/*" ], "Action": [ "s3:PutObject" ] } -
Elija Revisar política.
-
Elija Guardar cambios.
-
Paso 3: Implementar la aplicación de publicación
Siga estos pasos para implementar la aplicación que contiene la función de Lambda que lleva a cabo la publicación en el AWS Serverless Application Repository. Esta aplicación es aws-serverless-codepipeline-serverlessrepo-publish.
nota
Debe implementar la aplicación en la misma Región de AWS que la canalización.
-
Vaya a la página de la aplicación
y elija Deploy (Implementar). -
Seleccione I acknowledge that this app creates custom IAM roles (Confirmo que esta aplicación puede crear roles de IAM personalizados).
-
Elija Implementar.
-
Elija Ver pila de AWS CloudFormation para abrir la consola de AWS CloudFormation.
-
Amplíe la sección Resources (Recursos). Podrá ver ServerlessRepoPublish, que es del tipo AWS::Lambda::Function. Anote el ID físico de este recurso para el siguiente paso. Lo utilizará al crear la acción de publicación nueva en CodePipeline.
Paso 4: Crear la acción de publicación
Siga estos pasos para crear la acción de publicación en la canalización.
-
Abra la consola de CodePipeline en https://console.aws.amazon.com/codepipeline/
. -
En la sección de navegación izquierda, elija la canalización que desea editar.
-
Elija Editar.
-
Después de la última etapa de la canalización actual, elija + Add stage (Añadir etapa). En Stage name (Nombre de etapa), escriba un nombre, por ejemplo
Publish
, y elija Add stage (Añadir etapa). -
En la nueva etapa, elija +Add action group (+Añadir grupo de acciones).
-
Introduzca un nombre para la acción. En Action provider (Proveedor de acción), en Invoke (Invocar), elija AWS Lambda.
-
En Input artifacts (Artefactos de entrada), elija BuildArtifact.
-
En Nombre de función, elija el ID físico de la función de Lambda que ha anotado en el paso anterior.
-
Elija Save (Guardar) para la acción.
-
Elija Done (Listo) para la etapa.
-
En la parte superior derecha, elija Save (Guardar).
-
Para verificar la canalización, realice un cambio en la aplicación en GitHub. Por ejemplo, cambie la descripción de la aplicación en la sección
Metadata
del archivo de plantilla de AWS SAM. Confirme el cambio y envíelo a la ramificación de GitHub. Esto desencadena la ejecución de la canalización. Cuando la canalización esté completa, compruebe que la aplicación se ha actualizado con el cambio en el AWS Serverless Application Repository.