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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
a90f12f7
Commit
a90f12f7
authored
May 23, 2019
by
Rémy Coutable
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Let Helm handle the cleanup and print logs when deployment fails
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
cc5c9670
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
51 deletions
+57
-51
.gitlab/ci/review.gitlab-ci.yml
.gitlab/ci/review.gitlab-ci.yml
+9
-6
scripts/review_apps/review-apps.sh
scripts/review_apps/review-apps.sh
+48
-45
No files found.
.gitlab/ci/review.gitlab-ci.yml
View file @
a90f12f7
...
@@ -96,10 +96,16 @@ schedule:review-build-cng:
...
@@ -96,10 +96,16 @@ schedule:review-build-cng:
-
install_api_client_dependencies_with_apk
-
install_api_client_dependencies_with_apk
-
source scripts/review_apps/review-apps.sh
-
source scripts/review_apps/review-apps.sh
script
:
script
:
-
perform_review_app_deployment
-
check_kube_domain
-
ensure_namespace
-
install_tiller
-
install_external_dns
-
download_chart
-
deploy || display_deployment_debug
-
wait_for_review_app_to_be_accessible
-
add_license
artifacts
:
artifacts
:
paths
:
paths
:
[
review_app_url.txt
]
-
review_app_url.txt
expire_in
:
2 days
expire_in
:
2 days
when
:
always
when
:
always
...
@@ -109,8 +115,6 @@ review-deploy:
...
@@ -109,8 +115,6 @@ review-deploy:
schedule:review-deploy:
schedule:review-deploy:
<<
:
*review-deploy-base
<<
:
*review-deploy-base
<<
:
*review-schedules-only
<<
:
*review-schedules-only
script
:
-
perform_review_app_deployment
review-stop
:
review-stop
:
<<
:
*review-base
<<
:
*review-base
...
@@ -125,7 +129,6 @@ review-stop:
...
@@ -125,7 +129,6 @@ review-stop:
script
:
script
:
-
source scripts/review_apps/review-apps.sh
-
source scripts/review_apps/review-apps.sh
-
delete
-
delete
-
cleanup
.review-qa-base
:
&review-qa-base
.review-qa-base
:
&review-qa-base
<<
:
*review-docker
<<
:
*review-docker
...
...
scripts/review_apps/review-apps.sh
View file @
a90f12f7
[[
"
$TRACE
"
]]
&&
set
-x
[[
"
$TRACE
"
]]
&&
set
-x
export
TILLER_NAMESPACE
=
"
$KUBE_NAMESPACE
"
export
TILLER_NAMESPACE
=
"
$KUBE_NAMESPACE
"
function
deploy
E
xists
()
{
function
deploy
_e
xists
()
{
local
namespace
=
"
${
1
}
"
local
namespace
=
"
${
1
}
"
local
deploy
=
"
${
2
}
"
local
deploy
=
"
${
2
}
"
echoinfo
"Checking if
${
deploy
}
exists in the
${
namespace
}
namespace..."
true
echoinfo
"Checking if
${
deploy
}
exists in the
${
namespace
}
namespace..."
true
...
@@ -13,8 +13,7 @@ function deployExists() {
...
@@ -13,8 +13,7 @@ function deployExists() {
return
$deploy_exists
return
$deploy_exists
}
}
function
previousDeployFailed
()
{
function
previous_deploy_failed
()
{
set
+e
local
deploy
=
"
${
1
}
"
local
deploy
=
"
${
1
}
"
echoinfo
"Checking for previous deployment of
${
deploy
}
"
true
echoinfo
"Checking for previous deployment of
${
deploy
}
"
true
...
@@ -34,7 +33,6 @@ function previousDeployFailed() {
...
@@ -34,7 +33,6 @@ function previousDeployFailed() {
else
else
echoerr
"Previous deployment NOT found."
echoerr
"Previous deployment NOT found."
fi
fi
set
-e
return
$status
return
$status
}
}
...
@@ -51,49 +49,35 @@ function delete() {
...
@@ -51,49 +49,35 @@ function delete() {
helm delete
--purge
"
$name
"
helm delete
--purge
"
$name
"
}
}
function
cleanup
()
{
if
[
-z
"
$CI_ENVIRONMENT_SLUG
"
]
;
then
echoerr
"No release given, aborting the delete!"
return
fi
echoinfo
"Cleaning up '
$CI_ENVIRONMENT_SLUG
'..."
true
kubectl
-n
"
$KUBE_NAMESPACE
"
delete
\
ingress,svc,pdb,hpa,deploy,statefulset,job,pod,secret,configmap,pvc,secret,clusterrole,clusterrolebinding,role,rolebinding,sa
\
--now
--ignore-not-found
--include-uninitialized
\
-l
release
=
"
$CI_ENVIRONMENT_SLUG
"
}
function
get_pod
()
{
function
get_pod
()
{
local
app_name
=
"
${
1
}
"
local
app_name
=
"
${
1
}
"
local
status
=
"
${
2
-Running
}
"
local
status
=
"
${
2
-Running
}
"
get_pod_cmd
=
"kubectl get pods -n
${
KUBE_NAMESPACE
}
--field-selector=status.phase=
${
status
}
-lapp=
${
app_name
}
,release=
${
CI_ENVIRONMENT_SLUG
}
--no-headers -o=custom-columns=NAME:.metadata.name"
get_pod_cmd
=
"kubectl get pods -n
${
KUBE_NAMESPACE
}
--field-selector=status.phase=
${
status
}
-lapp=
${
app_name
}
,release=
${
CI_ENVIRONMENT_SLUG
}
--no-headers -o=custom-columns=NAME:.metadata.name"
echoinfo
"Running '
${
get_pod_cmd
}
'"
true
echoinfo
"Waiting till '
${
app_name
}
' pod is ready"
true
echoinfo
"Running '
${
get_pod_cmd
}
'"
local
interval
=
5
local
elapsed_seconds
=
0
local
max_seconds
=
$((
2
*
60
))
while
true
;
do
while
true
;
do
local
pod_name
local
pod_name
pod_name
=
"
$(
eval
"
${
get_pod_cmd
}
"
)
"
pod_name
=
"
$(
eval
"
${
get_pod_cmd
}
"
)
"
[[
"
${
pod_name
}
"
==
""
]]
||
break
[[
"
${
pod_name
}
"
==
""
]]
||
break
echoinfo
"Waiting till '
${
app_name
}
' pod is ready"
;
if
[[
"
${
elapsed_seconds
}
"
-gt
"
${
max_seconds
}
"
]]
;
then
sleep
5
;
echoerr
"The pod name couldn't be found after
${
elapsed_seconds
}
seconds, aborting."
echo
""
&&
return
0
fi
printf
"."
let
"elapsed_seconds+=interval"
sleep
${
interval
}
done
done
echoinfo
"The pod name is '
${
pod_name
}
'."
echoinfo
"The pod name is '
${
pod_name
}
'."
echo
"
${
pod_name
}
"
echo
"
${
pod_name
}
"
}
}
function
perform_review_app_deployment
()
{
check_kube_domain
ensure_namespace
install_tiller
install_external_dns
time
deploy
wait_for_review_app_to_be_accessible
add_license
}
function
check_kube_domain
()
{
function
check_kube_domain
()
{
echoinfo
"Checking that Kube domain exists..."
true
echoinfo
"Checking that Kube domain exists..."
true
...
@@ -137,7 +121,7 @@ function install_external_dns() {
...
@@ -137,7 +121,7 @@ function install_external_dns() {
domain
=
$(
echo
"
${
REVIEW_APPS_DOMAIN
}
"
|
awk
-F
.
'{printf "%s.%s", $(NF-1), $NF}'
)
domain
=
$(
echo
"
${
REVIEW_APPS_DOMAIN
}
"
|
awk
-F
.
'{printf "%s.%s", $(NF-1), $NF}'
)
echoinfo
"Installing external DNS for domain
${
domain
}
..."
true
echoinfo
"Installing external DNS for domain
${
domain
}
..."
true
if
!
deploy
Exists
"
${
KUBE_NAMESPACE
}
"
"
${
release_name
}
"
||
previousDeployF
ailed
"
${
release_name
}
"
;
then
if
!
deploy
_exists
"
${
KUBE_NAMESPACE
}
"
"
${
release_name
}
"
||
previous_deploy_f
ailed
"
${
release_name
}
"
;
then
echoinfo
"Installing external-dns Helm chart"
echoinfo
"Installing external-dns Helm chart"
helm repo update
helm repo update
helm
install
stable/external-dns
\
helm
install
stable/external-dns
\
...
@@ -156,7 +140,7 @@ function install_external_dns() {
...
@@ -156,7 +140,7 @@ function install_external_dns() {
fi
fi
}
}
function
create_secret
()
{
function
create_
application_
secret
()
{
echoinfo
"Creating the
${
CI_ENVIRONMENT_SLUG
}
-gitlab-initial-root-password secret in the
${
KUBE_NAMESPACE
}
namespace..."
true
echoinfo
"Creating the
${
CI_ENVIRONMENT_SLUG
}
-gitlab-initial-root-password secret in the
${
KUBE_NAMESPACE
}
namespace..."
true
kubectl create secret generic
-n
"
$KUBE_NAMESPACE
"
\
kubectl create secret generic
-n
"
$KUBE_NAMESPACE
"
\
...
@@ -165,7 +149,7 @@ function create_secret() {
...
@@ -165,7 +149,7 @@ function create_secret() {
--dry-run
-o
json | kubectl apply
-f
-
--dry-run
-o
json | kubectl apply
-f
-
}
}
function
download_
gitlab_
chart
()
{
function
download_chart
()
{
echoinfo
"Downloading the GitLab chart..."
true
echoinfo
"Downloading the GitLab chart..."
true
curl
-o
gitlab.tar.bz2
"https://gitlab.com/charts/gitlab/-/archive/
${
GITLAB_HELM_CHART_REF
}
/gitlab-
${
GITLAB_HELM_CHART_REF
}
.tar.bz2"
curl
-o
gitlab.tar.bz2
"https://gitlab.com/charts/gitlab/-/archive/
${
GITLAB_HELM_CHART_REF
}
/gitlab-
${
GITLAB_HELM_CHART_REF
}
.tar.bz2"
...
@@ -194,14 +178,12 @@ function deploy() {
...
@@ -194,14 +178,12 @@ function deploy() {
gitlab_workhorse_image_repository
=
"
${
IMAGE_REPOSITORY
}
/gitlab-workhorse-
${
IMAGE_VERSION
}
"
gitlab_workhorse_image_repository
=
"
${
IMAGE_REPOSITORY
}
/gitlab-workhorse-
${
IMAGE_VERSION
}
"
# Cleanup and previous installs, as FAILED and PENDING_UPGRADE will cause errors with `upgrade`
# Cleanup and previous installs, as FAILED and PENDING_UPGRADE will cause errors with `upgrade`
if
[
"
$CI_ENVIRONMENT_SLUG
"
!=
"production"
]
&&
previous
DeployF
ailed
"
$CI_ENVIRONMENT_SLUG
"
;
then
if
[
"
$CI_ENVIRONMENT_SLUG
"
!=
"production"
]
&&
previous
_deploy_f
ailed
"
$CI_ENVIRONMENT_SLUG
"
;
then
echo
"Deployment in bad state, cleaning up
$CI_ENVIRONMENT_SLUG
"
echo
"Deployment in bad state, cleaning up
$CI_ENVIRONMENT_SLUG
"
delete
delete
cleanup
fi
fi
create_secret
create_application_secret
download_gitlab_chart
HELM_CMD
=
$(
cat
<<
EOF
HELM_CMD
=
$(
cat
<<
EOF
helm upgrade --install
\
helm upgrade --install
\
...
@@ -216,7 +198,7 @@ HELM_CMD=$(cat << EOF
...
@@ -216,7 +198,7 @@ HELM_CMD=$(cat << EOF
--set prometheus.install=false
\
--set prometheus.install=false
\
--set global.ingress.configureCertmanager=false
\
--set global.ingress.configureCertmanager=false
\
--set global.ingress.tls.secretName=tls-cert
\
--set global.ingress.tls.secretName=tls-cert
\
--set global.ingress.annotations."external-dns
\.
alpha
\.
kubernetes
\.
io/ttl"="10"
--set global.ingress.annotations."external-dns
\.
alpha
\.
kubernetes
\.
io/ttl"="10"
\
--set nginx-ingress.controller.service.enableHttp=false
\
--set nginx-ingress.controller.service.enableHttp=false
\
--set nginx-ingress.defaultBackend.resources.requests.memory=7Mi
\
--set nginx-ingress.defaultBackend.resources.requests.memory=7Mi
\
--set nginx-ingress.controller.resources.requests.memory=440M
\
--set nginx-ingress.controller.resources.requests.memory=440M
\
...
@@ -252,14 +234,35 @@ EOF
...
@@ -252,14 +234,35 @@ EOF
echoinfo
"Deploying with:"
echoinfo
"Deploying with:"
echoinfo
"
${
HELM_CMD
}
"
echoinfo
"
${
HELM_CMD
}
"
eval
$HELM_CMD
||
true
eval
"
${
HELM_CMD
}
"
}
function
display_deployment_debug
()
{
migrations_pod
=
$(
get_pod
"migrations"
)
;
if
[
-z
"
${
migrations_pod
}
"
]
;
then
echoerr
"Migrations pod not found."
else
echoinfo
"Logs tail of the
${
migrations_pod
}
pod..."
kubectl logs
-n
"
$KUBE_NAMESPACE
"
"
${
migrations_pod
}
"
|
sed
"s/
${
REVIEW_APPS_ROOT_PASSWORD
}
/[REDACTED]/g"
fi
unicorn_pod
=
$(
get_pod
"unicorn"
)
;
if
[
-z
"
${
unicorn_pod
}
"
]
;
then
echoerr
"Unicorn pod not found."
else
echoinfo
"Logs tail of the
${
unicorn_pod
}
pod..."
kubectl logs
-n
"
$KUBE_NAMESPACE
"
-c
unicorn
"
${
unicorn_pod
}
"
|
sed
"s/
${
REVIEW_APPS_ROOT_PASSWORD
}
/[REDACTED]/g"
fi
}
}
function
wait_for_review_app_to_be_accessible
()
{
function
wait_for_review_app_to_be_accessible
()
{
# In case the Review App isn't completely available yet. Keep trying for 5 minutes.
echoinfo
"Waiting for the Review App at
${
CI_ENVIRONMENT_URL
}
to be accessible..."
true
local
interval
=
5
local
interval
=
5
local
elapsed_seconds
=
0
local
elapsed_seconds
=
0
local
max_seconds
=
$((
5
*
60
))
local
max_seconds
=
$((
2
*
60
))
while
true
;
do
while
true
;
do
local
review_app_http_code
local
review_app_http_code
review_app_http_code
=
$(
curl
--silent
--output
/dev/null
--max-time
5
--write-out
"%{http_code}"
"
${
CI_ENVIRONMENT_URL
}
/users/sign_in"
)
review_app_http_code
=
$(
curl
--silent
--output
/dev/null
--max-time
5
--write-out
"%{http_code}"
"
${
CI_ENVIRONMENT_URL
}
/users/sign_in"
)
...
@@ -272,10 +275,10 @@ function wait_for_review_app_to_be_accessible() {
...
@@ -272,10 +275,10 @@ function wait_for_review_app_to_be_accessible() {
sleep
${
interval
}
sleep
${
interval
}
done
done
if
[[
"
${
review_app_http_code
}
"
==
"200"
]]
;
then
if
[[
"
${
review_app_http_code
}
"
-eq
"200"
]]
;
then
echoinfo
"The Review App at
${
CI_ENVIRONMENT_URL
}
is ready!"
echoinfo
"The Review App at
${
CI_ENVIRONMENT_URL
}
is ready
after
${
elapsed_seconds
}
seconds
!"
else
else
echoerr
"The Review App at
${
CI_ENVIRONMENT_URL
}
isn't ready after
5 minute
s of polling..."
echoerr
"The Review App at
${
CI_ENVIRONMENT_URL
}
isn't ready after
${
max_seconds
}
second
s of polling..."
exit
1
exit
1
fi
fi
}
}
...
...
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