Add 'auto' option for MASTER_RESERVED_IP. No ElasticIP allocation by default.

Default behaviour when setting up a cluster is using the Amazon-assigned public ip.
It will change between reboots. If MASTER_RESERVED_IP is set to 'auto', new Elastic
IP will be allocated & assigned to master. If MASTER_RESERVED_IP is set to an existing
Elastic IP, it will be used. When something fails, original Amazon-given IP will be used.
This commit is contained in:
Madis Nõmme 2015-05-13 10:41:51 +03:00
parent eb220f05a6
commit 15643a2c72
2 changed files with 10 additions and 5 deletions

View File

@ -44,7 +44,8 @@ POLL_SLEEP_INTERVAL=3
PORTAL_NET="10.0.0.0/16" PORTAL_NET="10.0.0.0/16"
MASTER_IP_RANGE="${MASTER_IP_RANGE:-10.246.0.0/24}" MASTER_IP_RANGE="${MASTER_IP_RANGE:-10.246.0.0/24}"
# If set to Elastic IP, master instance will be associated with this IP. # If set to Elastic IP, master instance will be associated with this IP.
# Otherwise new Elastic IP will be aquired # If set to auto, a new Elastic IP will be aquired
# Otherwise amazon-given public ip will be used (it'll change with reboot).
MASTER_RESERVED_IP="${MASTER_RESERVED_IP:-}" MASTER_RESERVED_IP="${MASTER_RESERVED_IP:-}"
# When set to true, Docker Cache is enabled by default as part of the cluster bring up. # When set to true, Docker Cache is enabled by default as part of the cluster bring up.

View File

@ -386,17 +386,21 @@ function assign-ip-to-instance {
fi fi
} }
# Assigns elastic ip to a Amazon EC2 instance. If assigned public IP is empty, # If MASTER_RESERVED_IP looks like IP address, will try to assign it to master instance
# then will request new one. # If MASTER_RESERVED_IP is "auto", will allocate new elastic ip and assign that
# If none of the above or something fails, will output originally assigne IP
# Output: assigned IP address # Output: assigned IP address
function assign-elastic-ip { function assign-elastic-ip {
local assigned_public_ip=$1 local assigned_public_ip=$1
local master_instance_id=$2 local master_instance_id=$2
if [[ -n "${MASTER_RESERVED_IP}" ]]; then # Check that MASTER_RESERVED_IP looks like an IPv4 address
if [[ "${MASTER_RESERVED_IP}" =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
assign-ip-to-instance "${MASTER_RESERVED_IP}" "${master_instance_id}" "${assigned_public_ip}" assign-ip-to-instance "${MASTER_RESERVED_IP}" "${master_instance_id}" "${assigned_public_ip}"
else elif [[ "${MASTER_RESERVED_IP}" = "auto" ]]; then
assign-ip-to-instance $(allocate-elastic-ip) "${master_instance_id}" "${assigned_public_ip}" assign-ip-to-instance $(allocate-elastic-ip) "${master_instance_id}" "${assigned_public_ip}"
else
echo "${assigned_public_ip}"
fi fi
} }