-
Notifications
You must be signed in to change notification settings - Fork 8
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add healthcheck and release ip if not successful #6
base: master
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,9 +2,9 @@ | |
|
||
# cleanup when the container is stopped or ucarp exits | ||
cleanup () { | ||
kill -USR2 $(pidof ucarp) | ||
kill -USR2 "$(pidof ucarp)" | ||
sleep 1 | ||
$KARP_DOWNSCRIPT $KARP_INTERFACE $KARP_VIRTUAL_IP $KARP_SUBNET | ||
$KARP_DOWNSCRIPT "$KARP_INTERFACE" "$KARP_VIRTUAL_IP" "$KARP_SUBNET" | ||
} | ||
trap "cleanup" SIGINT | ||
trap "cleanup" SIGTERM | ||
|
@@ -27,6 +27,7 @@ fi | |
|
||
# start up the service and put it into background | ||
/usr/sbin/ucarp \ | ||
--daemonize \ | ||
--interface=${KARP_INTERFACE} \ | ||
--srcip=${KARP_HOST_IP} \ | ||
--vhid=${KARP_SERVER_ID} \ | ||
|
@@ -35,10 +36,27 @@ fi | |
--upscript=${KARP_UPSCRIPT} \ | ||
--downscript=${KARP_DOWNSCRIPT} \ | ||
--xparam=${KARP_SUBNET} \ | ||
${KARP_EXTRA_FLAGS} & | ||
${KARP_EXTRA_FLAGS} | ||
|
||
# wait for the last process sent to background to finish (ucarp) | ||
wait $! | ||
demote_ucarp() { | ||
kill -USR2 "$(pidof ucarp)" | ||
sleep 1 | ||
$KARP_DOWNSCRIPT "$KARP_INTERFACE" "$KARP_VIRTUAL_IP" "$KARP_SUBNET" | ||
} | ||
Comment on lines
+41
to
+45
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This function seems to be the same as |
||
|
||
do_healthcheck() { | ||
[ "$(wget --no-check-certificate -q -O - "$KARP_HEALTHCHECK_URL")" = ok ] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This / # wget --no-check-certificate -q -O - https://localhost:6443/livez
wget: server returned error: HTTP/1.1 401 Unauthorized There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That's strange. OpenShift allows this URI without authorization. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm using RKE (Rancher Kubernetes Engine), so this is a nice implicit test case but a truly blocker one if it doesn't pass |
||
} | ||
|
||
# periodically check | ||
if [ "$KARP_DISABLE_HEALTHCHECK" = yes ]; then | ||
sleep infinity | ||
else | ||
while true; do | ||
do_healthcheck || demote_ucarp | ||
sleep 1 | ||
done | ||
fi | ||
|
||
# cleanup even if the process exits by itself | ||
# otherwise, the traps handle container stops initiated by the user | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since the container is running with host networking, this is the Kubernetes API server. If we check its health, the IP is released to another node that might hold a working API server. This is why you've introduced this PR, am I right?
If yes, the
KARP_HEALTHCHECK_URL
could beKARP_K8S_HEALTHCHECK_URL
to be more descriptive. At first, I was thinking for a moment this is some kind of built-in Ucarp feature :)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes. I can, of course, change the environment name. But I personally prefer
KARP_HEALTHCHECK_URL
because it might check any other Service as well.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe
KARP_CHECK_URL
to make it more explicit? Naming is hard.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can't think of any better name than
KARP_APICHECK_URL
if this is a general API health check to release the IP. I just want to separate the term health from uCarp's own health - that's what caused me the confusion in the first place.