Las variables de Gitlab se pueden establecer en varios lugares:
- En configuraciones grupales
- En la configuración del proyecto
- Dentro de .gitlab-ci.yml
En este caso, las variables en la configuración de los grupos y el proyecto se pueden establecer como "archivo" o "variable ordinaria" y marque las casillas "protegido" y "máscara".
![](https://habrastorage.org/webt/iu/2f/d2/iu2fd2ums7tmrkyqb4hrbhuenzg.png)
Comencemos con una herencia simple y gradualmente se volverá más compleja.
Se puede encontrar una lista final de niveles de prioridad al final del documento.
, , .
![Grupos con variables](https://habrastorage.org/webt/4b/wl/qj/4bwlqj-g_cztown5ks5znmiqgl8.png)
image: busybox:latest
variables:
GIT_STRATEGY: none
echo:
stage: test
script:
- echo $MSG
$ echo $MSG
B
B, .
.gitlab-ci.yml []
: , .
c
![](https://habrastorage.org/webt/ze/em/ih/zeemihn1rerz65eb_hgmejkx0iw.png)
2 , $MSG.
image: busybox:latest
variables:
GIT_STRATEGY: none
MSG: "Custom in global .gitlab-ci.yml"
echo:
stage: test
script:
- echo $MSG
echo with var:
stage: test
variables:
MSG: "Custom in job .gitlab-ci.yml"
script:
- echo $MSG
.gitlab-ci.yml []
2 . .gitlab-ci.yml.
c
![](https://habrastorage.org/webt/wv/ke/3o/wvke3o9zni565rug1kegmkorxha.png)
image: busybox:latest
variables:
GIT_STRATEGY: none
MSG: "Custom in global .gitlab-ci.yml"
echo:
stage: test
script:
- echo $MSG
echo with var:
stage: test
variables:
MSG: "Custom in job .gitlab-ci.yml"
script:
- echo $MSG
! , .gitlab-ci.yml .
c
.
![](https://habrastorage.org/webt/by/ni/zb/bynizbno7obalix_sxmgiz0dggm.png)
. , , .gitlab-ci.yml, .
image: busybox:latest
variables:
GIT_STRATEGY: none
MSG: "Custom in global .gitlab-ci.yml"
echo:
stage: test
script:
- echo $MSG
echo with var:
stage: test
variables:
MSG: "Custom in job .gitlab-ci.yml"
script:
- echo $MSG
–
– Null
c
![](https://habrastorage.org/webt/vs/mv/gq/vsmvgqrc4q9eh_zpevibj3tqa8u.png)
image: busybox:latest
variables:
GIT_STRATEGY: none
MSG: "Custom in global .gitlab-ci.yml"
echo:
stage: test
script:
- echo $MSG
echo with var:
stage: test
variables:
MSG: "Custom in job .gitlab-ci.yml"
script:
- echo $MSG
project-2 project-3
.
c
![](https://habrastorage.org/webt/lc/vg/19/lcvg19w1dkgdqlkennmeta1awcu.png)
.gitlab-ci.yml
variables:
MSG: "With include .gitlab-ci.yml"
include:
- project: how-is-gitlab-ci-inherit-environment-variables/z/y/project-3
file: '.gitlab-ci.yml'
project-2 project-3.
C : , .
c
![](https://habrastorage.org/webt/mp/bv/e1/mpbve1krliedbl7j3wb3md2ecjk.png)
variables:
MSG: "With include .gitlab-ci.yml"
include:
- project: how-is-gitlab-ci-inherit-environment-variables/z/y/project-3
file: '.gitlab-ci.yml'
:
- ( )
- .gitlab-ci.yml
El punto más obvio es que la regla "cuanto más cerca esté la variable del código, más importante es" funciona primero para los grupos, y luego la misma regla para las variables dentro de .gitlab-ci.yml, pero solo con la condición de que las variables en los grupos no estén definidas. .
Además, un lugar importante es la comprensión de que el espacio global para el núcleo y el .gitlab-ci.yml excluido es común. Y el archivo en el que se produce la inclusión tiene prioridad.