Commit 383107b5 authored by Lee Tickett's avatar Lee Tickett Committed by Amy Qualls

Clarify UI CI variables are'nt available to services

parent ee30c750
...@@ -24,10 +24,9 @@ tests access to the GitLab API. ...@@ -24,10 +24,9 @@ tests access to the GitLab API.
GITLAB_ROOT_PASSWORD: "password" # to access the api with user root:password GITLAB_ROOT_PASSWORD: "password" # to access the api with user root:password
``` ```
1. To set values for the `GITLAB_HTTPS` and `GITLAB_ROOT_PASSWORD`, NOTE:
[assign them to a variable in the user interface](../variables/index.md#add-a-cicd-variable-to-a-project). Variables set in the GitLab UI are not passed down to the service containers.
Then assign that variable to the corresponding variable in your [Learn more](../variables/index.md#).
`.gitlab-ci.yml` file.
Then, commands in `script:` sections in your `.gitlab-ci.yml` file can access the API at `http://gitlab/api/v4`. Then, commands in `script:` sections in your `.gitlab-ci.yml` file can access the API at `http://gitlab/api/v4`.
......
...@@ -16,11 +16,9 @@ If you want to use a MySQL container, you can use [GitLab Runner](../runners/ind ...@@ -16,11 +16,9 @@ If you want to use a MySQL container, you can use [GitLab Runner](../runners/ind
This example shows you how to set a username and password that GitLab uses to access the MySQL container. If you do not set a username and password, you must use `root`. This example shows you how to set a username and password that GitLab uses to access the MySQL container. If you do not set a username and password, you must use `root`.
1. [Create CI/CD variables](../variables/index.md#custom-cicd-variables) for your NOTE:
MySQL database and password by going to **Settings > CI/CD**, expanding **Variables**, Variables set in the GitLab UI are not passed down to the service containers.
and clicking **Add Variable**. [Learn more](../variables/index.md).
This example uses `$MYSQL_DB` and `$MYSQL_PASS` as the keys.
1. To specify a MySQL image, add the following to your `.gitlab-ci.yml` file: 1. To specify a MySQL image, add the following to your `.gitlab-ci.yml` file:
...@@ -39,8 +37,8 @@ This example shows you how to set a username and password that GitLab uses to ac ...@@ -39,8 +37,8 @@ This example shows you how to set a username and password that GitLab uses to ac
```yaml ```yaml
variables: variables:
# Configure mysql environment variables (https://hub.docker.com/_/mysql/) # Configure mysql environment variables (https://hub.docker.com/_/mysql/)
MYSQL_DATABASE: $MYSQL_DB MYSQL_DATABASE: $MYSQL_DATABASE
MYSQL_ROOT_PASSWORD: $MYSQL_PASS MYSQL_ROOT_PASSWORD: $MYSQL_ROOT_PASSWORD
``` ```
The MySQL container uses `MYSQL_DATABASE` and `MYSQL_ROOT_PASSWORD` to connect to the database. The MySQL container uses `MYSQL_DATABASE` and `MYSQL_ROOT_PASSWORD` to connect to the database.
......
...@@ -16,6 +16,10 @@ do this with the Docker and Shell executors of GitLab Runner. ...@@ -16,6 +16,10 @@ do this with the Docker and Shell executors of GitLab Runner.
If you're using [GitLab Runner](../runners/index.md) with the Docker executor, If you're using [GitLab Runner](../runners/index.md) with the Docker executor,
you basically have everything set up already. you basically have everything set up already.
NOTE:
Variables set in the GitLab UI are not passed down to the service containers.
[Learn more](../variables/index.md).
First, in your `.gitlab-ci.yml` add: First, in your `.gitlab-ci.yml` add:
```yaml ```yaml
...@@ -23,25 +27,19 @@ services: ...@@ -23,25 +27,19 @@ services:
- postgres:12.2-alpine - postgres:12.2-alpine
variables: variables:
POSTGRES_DB: nice_marmot POSTGRES_DB: $POSTGRES_DB
POSTGRES_USER: runner POSTGRES_USER: $POSTGRES_USER
POSTGRES_PASSWORD: "" POSTGRES_PASSWORD: $POSTGRES_PASSWORD
POSTGRES_HOST_AUTH_METHOD: trust POSTGRES_HOST_AUTH_METHOD: trust
``` ```
To set values for the `POSTGRES_DB`, `POSTGRES_USER`,
`POSTGRES_PASSWORD` and `POSTGRES_HOST_AUTH_METHOD`,
[assign them to a CI/CD variable in the user interface](../variables/index.md#custom-cicd-variables),
then assign that variable to the corresponding variable in your
`.gitlab-ci.yml` file.
And then configure your application to use the database, for example: And then configure your application to use the database, for example:
```yaml ```yaml
Host: postgres Host: postgres
User: runner User: $PG_USER
Password: '' Password: $PG_PASSWORD
Database: nice_marmot Database: $PG_DB
``` ```
If you're wondering why we used `postgres` for the `Host`, read more at If you're wondering why we used `postgres` for the `Host`, read more at
......
...@@ -20,6 +20,15 @@ You can use [predefined CI/CD variables](#predefined-cicd-variables) or define c ...@@ -20,6 +20,15 @@ You can use [predefined CI/CD variables](#predefined-cicd-variables) or define c
- [Group CI/CD variables](#add-a-cicd-variable-to-a-group). - [Group CI/CD variables](#add-a-cicd-variable-to-a-group).
- [Instance CI/CD variables](#add-a-cicd-variable-to-an-instance). - [Instance CI/CD variables](#add-a-cicd-variable-to-an-instance).
NOTE:
Variables set in the GitLab UI are **not** passed down to [service containers](../docker/using_docker_images.md).
To set them, assign them to variables in the UI, then re-assign them in your `.gitlab-ci.yml`:
```yaml
variables:
SA_PASSWORD: $SA_PASSWORD
```
> For more information about advanced use of GitLab CI/CD: > For more information about advanced use of GitLab CI/CD:
> >
> - <i class="fa fa-youtube-play youtube" aria-hidden="true"></i>&nbsp;Get to productivity faster with these [7 advanced GitLab CI workflow hacks](https://about.gitlab.com/webcast/7cicd-hacks/) > - <i class="fa fa-youtube-play youtube" aria-hidden="true"></i>&nbsp;Get to productivity faster with these [7 advanced GitLab CI workflow hacks](https://about.gitlab.com/webcast/7cicd-hacks/)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment