Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Jérome Perrin
gitlab-ce
Commits
54fc574e
Commit
54fc574e
authored
Nov 17, 2016
by
Achilleas Pipinellis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Finish dynamic environments and URLs sections
[ci skip]
parent
ff97de61
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
156 additions
and
4 deletions
+156
-4
doc/ci/environments.md
doc/ci/environments.md
+156
-4
doc/ci/img/environments_link_url.png
doc/ci/img/environments_link_url.png
+0
-0
doc/ci/img/environments_link_url_deployments.png
doc/ci/img/environments_link_url_deployments.png
+0
-0
doc/ci/img/environments_link_url_mr.png
doc/ci/img/environments_link_url_mr.png
+0
-0
doc/ci/img/environments_mr_review_app.png
doc/ci/img/environments_mr_review_app.png
+0
-0
No files found.
doc/ci/environments.md
View file @
54fc574e
...
@@ -221,6 +221,11 @@ Clicking on the play button in either of these places will trigger the
...
@@ -221,6 +221,11 @@ Clicking on the play button in either of these places will trigger the
`deploy_prod`
job, and the deployment will be recorded under a new
`deploy_prod`
job, and the deployment will be recorded under a new
environment named
`production`
.
environment named
`production`
.
>**Note:**
Remember that if your environment's name is
`production`
(all lowercase), then
it will get recorded in
[
Cycle Analytics
](
../user/project/cycle_analytics.md
)
.
Double the benefit!
While this is fine for deploying to some stable environments like staging or
While this is fine for deploying to some stable environments like staging or
production, what happens for branches? So far we haven't defined anything
production, what happens for branches? So far we haven't defined anything
regarding deployments for branches other than
`master`
. Dynamic environments
regarding deployments for branches other than
`master`
. Dynamic environments
...
@@ -229,21 +234,162 @@ will help us achieve that.
...
@@ -229,21 +234,162 @@ will help us achieve that.
## Dynamic environments
## Dynamic environments
As the name suggests, it is possible to create environments on the fly by just
As the name suggests, it is possible to create environments on the fly by just
declaring their names dynamically in
`.gitlab-ci.yml`
.
declaring their names dynamically in
`.gitlab-ci.yml`
. Dynamic environments is
the base of
[
Review apps
](
review_apps.md
)
.
GitLab Runner exposes various
[
environment variables
][
variables
]
when a job runs,
GitLab Runner exposes various
[
environment variables
][
variables
]
when a job runs,
and as such you can use them
and as such, you can use them as environment names. Let's add another job in
our example which will deploy to all branches except
`master`
:
```
yaml
deploy_review
:
stage
:
deploy
script
:
-
echo "Deploy a review app"
environment
:
name
:
review/$CI_BUILD_REF_NAME
url
:
https://$CI_BUILD_REF_NAME.example.com
only
:
-
branches
except
:
-
master
```
```
review:
Let's break it down in pieces. The job's name is
`deploy_review`
and it runs
on the
`deploy`
stage. The
`script`
at this point is fictional, you'd have to
use your own based on your deployment. Then, we set the
`environment`
with the
`environment:name`
being
`review/$CI_BUILD_REF_NAME`
. Now that's an interesting
one. Since the
[
environment name
][
env-name
]
can contain also slashes (
`/`
), we
can use this pattern to distinguish between dynamic environments and the regular
ones.
So, the first part is
`review`
, followed by a
`/`
and then
`$CI_BUILD_REF_NAME`
which takes the value of the branch name. We also use the same
`$CI_BUILD_REF_NAME`
value in the
`environment:url`
so that the environment
can get a specific and distinct URL for each branch. Again, the way you set up
the webserver to serve these requests is based on your setup.
Last but not least, we tell the job to run
[
`only`
][
only
]
on branches
[
`except`
][
only
]
master.
>**Note:**
You are not bound to use only slashes in the dynamic environments' names (
`/`
),
but as we will see later, this will enable the "grouping similar environments"
feature.
The whole
`.gitlab-ci.yml`
looks like this so far:
```
yaml
stages
:
-
test
-
build
-
deploy
test
:
stage
:
test
script
:
echo "Running tests"
build
:
stage
:
build
script
:
echo "Building the app"
deploy_review
:
stage
:
deploy
stage
:
deploy
script
:
script
:
- rsync -av --delete public /srv/nginx/pages/$CI_BUILD_REF_NAME
-
echo "Deploy a review app"
environment
:
name
:
review/$CI_BUILD_REF_NAME
url
:
https://$CI_BUILD_REF_NAME.example.com
only
:
-
branches
except
:
-
master
deploy_staging
:
stage
:
deploy
script
:
-
echo "Deploy to staging server"
environment
:
name
:
staging
url
:
https://staging.example.com
only
:
-
master
deploy_prod
:
stage
:
deploy
script
:
-
echo "Deploy to production server"
environment
:
name
:
production
url
:
https://example.com
when
:
manual
only
:
-
master
```
A more realistic example would include copying files to a location where a
webserver (NGINX) could then read and serve. The example below will copy the
`public`
directory to
`/srv/nginx/$CI_BUILD_REF_NAME/public`
:
```
yaml
review_app
:
stage
:
deploy
script
:
-
rsync -av --delete public /srv/nginx/$CI_BUILD_REF_NAME
environment
:
environment
:
name
:
review/$CI_BUILD_REF_NAME
name
:
review/$CI_BUILD_REF_NAME
url
:
https://$CI_BUILD_REF_NAME.example.com
url
:
https://$CI_BUILD_REF_NAME.example.com
```
```
It is assumed that the user has already setup NGINX and GitLab Runner in the
server this job will run on.
---
The development workflow would now be:
-
Developer creates a branch locally
-
Developer makes changes, commits and pushes the branch to GitLab
-
Developer creates a merge request
Behind the scenes:
-
GitLab Runner picks up the changes and starts running the jobs
-
The jobs run sequentially as defined in
`stages`
-
First, the tests pass
-
Then, the build begins and successfully also passes
-
Lastly, the app is deployed to an environment with a name specific to the
branch
So now, every branch gets its own environment and is deployed to its own place
with the added benefit of having a
[
history of deployments
](
#viewing-the-deployment-history-of-an-environment
)
and also being able to
[
rollback changes
](
#rolling-back-changes
)
if needed.
Let's briefly see where URL that's defined in the environments is exposed.
## Making use of the environment URL
The environment URL is exposed in a few places within GitLab.
| In a merge request widget as a link | In the Environments view as a button | In the Deployments view as a button |
| -------------------- | ------------ | ----------- |
| !
[
Environment URL in merge request
](
img/environments_mr_review_app.png
)
| !
[
Environment URL in environments
](
img/environments_link_url.png
)
| !
[
Environment URL in deployments
](
img/environments_link_url_deployments.png
)
|
If a merge request is eventually merged to the default branch (in our case
`master`
) and that branch also deploys to an environment (in our case
`staging`
and/or
`production`
) you can see this information in the merge request itself.
![
Environment URLs in merge request
](
img/environments_link_url_mr.png
)
---
We now have a full development cycle, where our app is tested, built, deployed
as a Review app, deployed to a staging server once the merge request is merged,
and finally manually deployed to the production server. What we just described
is a single workflow, but imagine tens of developers working on a project
at the same time. They each push to their branches, and dynamic environments are
created all the time. In that case, we probably need to do some clean up. Read
next how environments can be closed.
## Closing an environment
## Closing an environment
```
```
...
@@ -264,6 +410,10 @@ stop_review:
...
@@ -264,6 +410,10 @@ stop_review:
action: stop
action: stop
```
```
## Grouping similar environments
folders in environments page
## Checkout deployments locally
## Checkout deployments locally
Since 8.13, a reference in the git repository is saved for each deployment. So
Since 8.13, a reference in the git repository is saved for each deployment. So
...
@@ -308,3 +458,5 @@ Actions
...
@@ -308,3 +458,5 @@ Actions
[
deployments
]:
#deployments
[
deployments
]:
#deployments
[
permissions
]:
../user/permissions.md
[
permissions
]:
../user/permissions.md
[
variables
]:
variables/README.md
[
variables
]:
variables/README.md
[
env-name
]:
yaml/README.md#environment-name
[
only
]:
yaml/README.md#only-and-except
doc/ci/img/environments_link_url.png
0 → 100644
View file @
54fc574e
32.8 KB
doc/ci/img/environments_link_url_deployments.png
0 → 100644
View file @
54fc574e
19.2 KB
doc/ci/img/environments_link_url_mr.png
0 → 100644
View file @
54fc574e
46.2 KB
doc/ci/img/environments_mr_review_app.png
0 → 100644
View file @
54fc574e
38.8 KB
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment