Como administrador de Automation Pipelines, puede compartir canalizaciones para que los usuarios de una organización puedan ejecutarlas en cualquier otro proyecto o agregarlas como tareas anidadas dentro de una canalización en otro proyecto.
Por qué es útil una canalización compartida
Cuando se comparte una canalización, no es necesario crear la misma canalización para diferentes proyectos dentro de una organización. Además, si se actualiza una canalización compartida, todos los usuarios de la canalización tendrán la misma actualización.
También se puede utilizar una canalización compartida en Automation Service Broker. Un administrador de Automation Service Broker puede agregar la canalización compartida como un elemento del catálogo para que los usuarios la soliciten y la ejecuten en varios proyectos.
Solo los administradores de Automation Pipelines pueden compartir o dejar de compartir canalizaciones.
Cómo compartir una canalización
Para compartir una canalización, haga clic en Canalizaciones y seleccione la canalización que desea compartir.
- Haga clic en
- Si la canalización está desactivada, haga clic en .
- (opcional) Para que la canalización compartida esté disponible en Automation Service Broker, haga clic en .
Después de publicar la canalización, un administrador de Automation Service Broker puede agregarla a Automation Service Broker. Consulte Agregar canalizaciones al catálogo de Automation Service Broker.
Cómo ejecutar una canalización compartida
Para ejecutar una canalización compartida, seleccione la canalización y seleccione un proyecto.
La canalización se ejecuta en el contexto del proyecto que seleccione y solo se comparte el modelo de canalización. No se comparte ninguna infraestructura, como los endpoints o las variables que se utilizan en la canalización. Si una canalización compartida que utiliza endpoints o variables se ejecuta en un proyecto diferente, dichos endpoints y variables deben estar disponibles en ese proyecto.
Por ejemplo, supongamos que jenkinsPipeline
utiliza projectA
e incluye una tarea con un endpoint denominado jenkinsEndpoint
.
Si comparte jenkinsPipeline
y desea ejecutarla en el contexto de projectB
, debe haber un jenkinsEndpoint
en projectB
. Si no existe jenkinsEndpoint
, cree el endpoint en projectB
antes de ejecutar la canalización compartida.
El siguiente procedimiento muestra cómo duplicar un endpoint en otro proyecto. Se siguen pasos similares para una variable.
- Haga clic en Endpoints. En el endpoint que desea duplicar, por ejemplo,
jenkinsEndpoint
, haga clic en . - Haga clic en el botón Importar y seleccione el archivo YAML para
jenkinsEndpoint
. - Edite el archivo para cambiar el proyecto, como
projectB
en el siguiente código YAML de ejemplo.--- project: projectB kind: ENDPOINT name: jenkinsEndpoint ...
- Haga clic en Importar.
Para ejecutar jenkinsPipeline
en projectB
, haga clic en Ejecutar en la tarjeta de canalización y seleccione projectB
como el proyecto.
projectB
, debe tener la función de administrador, desarrollador o ejecutor de
Automation Pipelines. Si es usuario o visor de
Automation Pipelines, no puede ejecutar la canalización a menos que un administrador de
Automation Pipelines lo convierta en administrador del proyecto o miembro del proyecto
projectB
. Para obtener más información acerca de las funciones en
Automation Pipelines, consulte
Cómo se administran las autorizaciones y el acceso de los usuarios en Automation Pipelines.
Cómo agregar una canalización compartida a otra canalización
El uso de canalizaciones compartidas como tareas anidadas dentro de otra canalización permite ampliar la funcionalidad de la canalización más allá de las canalizaciones que se incluyen en un proyecto. Las canalizaciones compartidas pueden estar en proyectos diferentes entre sí y de la canalización en la que se incluyen como tareas anidadas.
El siguiente ejemplo muestra una canalización denominada master-shared-pipeline-demo
con dos tareas de canalización anidadas.
Para especificar la canalización de Task0
, selecciónela de una lista de canalizaciones compartidas. Cada nombre de canalización incluye el nombre del proyecto. Si varias canalizaciones compartidas tienen el mismo nombre, puede utilizar el nombre del proyecto para seleccionar la que desee.
Cómo utilizar una canalización compartida para la reversión
Si desea utilizar una canalización compartida para la reversión, selecciónela en una lista de canalizaciones cuando configure la reversión para la tarea. Automation Pipelines filtra la lista y muestra solo las canalizaciones en el mismo proyecto o las canalizaciones compartidas en diferentes proyectos.
Cómo utilizar una plantilla compartida en una canalización
Puede utilizar una plantilla compartida en Automation Assembler como origen de plantilla para una tarea en una canalización. El uso de plantillas compartidas proporciona acceso a más plantillas que las que se incluyen en un proyecto.
Antes de definir la tarea en Automation Pipelines, compruebe que la plantilla se comparte en Automation Assembler y que conoce el nombre y la versión. Cuando se comparte una plantilla, se muestra un icono junto al nombre del proyecto en la lista de plantillas de nube.
- En Tipo de tarea, seleccione Plantilla de Automation.
- En Acción, seleccione Crear implementación o Actualizar implementación.
- Si va a actualizar una implementación, seleccione el nombre de la implementación.
- En Origen de plantilla de nube, seleccione Plantilla de Automation.
- En Nombre de plantilla de nube, seleccione una opción de la lista de plantillas o escriba un nombre. Si no ve la plantilla en la lista, esto se debe a que la plantilla se encuentra en un proyecto diferente de la canalización, y Automation Pipelines solo muestra las plantillas que se encuentran en el mismo proyecto.
- En Versión de plantilla de nube, escriba la versión de la plantilla.
En el siguiente ejemplo, shared-bp
es la plantilla compartida que comprobó en Automation Assembler y que desea utilizar, pero no aparece como una selección, por lo que debe escribir el nombre.
Cómo eliminar o dejar de compartir una canalización
Si agrega una canalización compartida como una tarea anidada o para revertir una tarea, la canalización en la que se utiliza hace referencia a esa canalización. Si desea eliminar o dejar de compartir la canalización, debe eliminarla de cualquier canalización que haga referencia a ella.
Por ejemplo, si master-shared-pipeline-demo
incluye Shared-Pipeline
como una tarea anidada, se hace referencia a Shared-Pipeline
. No se puede eliminar o dejar de compartir Shared-Pipeline
hasta que se quite de master-shared-pipeline-demo
.
O si TestRollback
utiliza Shared-Pipeline
para revertir una tarea, se hace referencia a Shared-Pipeline
. No puede eliminar ni dejar de compartir Shared-Pipeline
hasta que lo quite de la reversión de la tarea en TestRollback
.
El siguiente procedimiento muestra cómo comprobar las referencias de una canalización y eliminarla de la canalización que hace referencia a ella antes de eliminarla o dejar de compartirla.
- Compruebe las referencias y actualice las referencias de la canalización si las encuentra.
- Haga clic en Canalizaciones. En la canalización compartida que desea comprobar, haga clic en .
- Anote los nombres de las canalizaciones de referencia.
- Abra las canalizaciones que hacen referencia a la canalización compartida. Elimine la canalización compartida que se utiliza como tarea anidada o para revertir una tarea, y guarde la canalización.
- Eliminar o dejar de compartir una canalización.
- En la canalización que desea eliminar, haga clic en .
- En la canalización que desea dejar de compartir, haga clic en .