mirror of
https://github.com/minio/minio.git
synced 2024-12-25 22:55:54 -05:00
Report healthy status for initial 120s, then switch to healthcheck (#4799)
Swarm routes traffic only to containers that report healthy status, while Minio in distributed mode needs to talk to other peers before it can respond to healthcheck probe. As the Minio containers are not able to talk to each other, distributed Minio is not getting started on Docker Swarm. With this PR, Minio Healthcheck report healthy status for initial 120s enough for distributed Minio to start. After that normal Healthcheck resumes. Also changed the healthcheck method name in accordance with Google shell styleguide. Fixes: https://github.com/minio/minio/issues/4761
This commit is contained in:
parent
d864e00e24
commit
53f84d6084
@ -19,25 +19,40 @@ _init () {
|
|||||||
scheme="http://"
|
scheme="http://"
|
||||||
address="127.0.0.1:9000"
|
address="127.0.0.1:9000"
|
||||||
resource="/minio/index.html"
|
resource="/minio/index.html"
|
||||||
|
start=$(stat -c "%Y" /proc/1)
|
||||||
}
|
}
|
||||||
|
|
||||||
HealthCheckMain () {
|
healthcheck_main () {
|
||||||
|
# In distributed environment like Swarm, traffic is routed
|
||||||
|
# to a container only when it reports a `healthy` status. So, we exit
|
||||||
|
# with 0 to ensure healthy status till distributed Minio starts (120s).
|
||||||
|
#
|
||||||
|
# Refer: https://github.com/moby/moby/pull/28938#issuecomment-301753272
|
||||||
|
if [ $(( $(date +%s) - start )) -lt 120 ]; then
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
# Get the http response code
|
# Get the http response code
|
||||||
http_response=$(curl -s -k -o /dev/null -I -w "%{http_code}" ${scheme}${address}${resource})
|
http_response=$(curl -s -k -o /dev/null -I -w "%{http_code}" \
|
||||||
|
${scheme}${address}${resource})
|
||||||
|
|
||||||
# Get the http response body
|
# Get the http response body
|
||||||
http_response_body=$(curl -k -s ${scheme}${address}${resource})
|
http_response_body=$(curl -k -s ${scheme}${address}${resource})
|
||||||
|
|
||||||
# server returns response 403 and body "SSL required" if non-TLS connection is attempted on a TLS-configured server.
|
# server returns response 403 and body "SSL required" if non-TLS
|
||||||
# change the scheme and try again
|
# connection is attempted on a TLS-configured server. Change
|
||||||
if [ "$http_response" = "403" ] && [ "$http_response_body" = "SSL required" ]; then
|
# the scheme and try again
|
||||||
|
if [ "$http_response" = "403" ] && \
|
||||||
|
[ "$http_response_body" = "SSL required" ]; then
|
||||||
scheme="https://"
|
scheme="https://"
|
||||||
http_response=$(curl -s -k -o /dev/null -I -w "%{http_code}" ${scheme}${address}${resource})
|
http_response=$(curl -s -k -o /dev/null -I -w "%{http_code}" \
|
||||||
|
${scheme}${address}${resource})
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# If http_repsonse is 200 - server is up.
|
# If http_repsonse is 200 - server is up. When MINIO_BROWSER is
|
||||||
# When MINIO_BROWSER is set to off, curl responds with 404. We assume that the the server is up
|
# set to off, curl responds with 404. We assume that the server
|
||||||
|
# is up
|
||||||
[ "$http_response" = "200" ] || [ "$http_response" = "404" ]
|
[ "$http_response" = "200" ] || [ "$http_response" = "404" ]
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
_init && HealthCheckMain
|
_init && healthcheck_main
|
||||||
|
Loading…
Reference in New Issue
Block a user