mirror of https://github.com/k3s-io/k3s
AWS kube-up: Reboot support with ephemeral storage
If the ephemeral volume is present and mounted, don't try to reinitialize them. Don't block the boot if the ephemeral volume is corrupt / missing - this enables us to cope with a stop/start & presumably also corruption. In this case, we'll reformat the ephemeral storage. Fix #21157pull/6/head
parent
b5c12d10b8
commit
69300c51b3
|
@ -18,6 +18,12 @@
|
||||||
|
|
||||||
function ensure-local-disks() {
|
function ensure-local-disks() {
|
||||||
|
|
||||||
|
# Skip if already mounted (a reboot)
|
||||||
|
if ( grep "/mnt/ephemeral" /proc/mounts ); then
|
||||||
|
echo "Found /mnt/ephemeral in /proc/mounts; skipping local disk initialization"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
block_devices=()
|
block_devices=()
|
||||||
|
|
||||||
ephemeral_devices=$(curl --silent http://169.254.169.254/2014-11-05/meta-data/block-device-mapping/ | grep ephemeral)
|
ephemeral_devices=$(curl --silent http://169.254.169.254/2014-11-05/meta-data/block-device-mapping/ | grep ephemeral)
|
||||||
|
@ -61,10 +67,14 @@ else
|
||||||
# Remove any existing mounts
|
# Remove any existing mounts
|
||||||
for block_device in ${block_devices}; do
|
for block_device in ${block_devices}; do
|
||||||
echo "Unmounting ${block_device}"
|
echo "Unmounting ${block_device}"
|
||||||
/bin/umount ${block_device}
|
/bin/umount ${block_device} || echo "Ignoring failure umounting ${block_device}"
|
||||||
sed -i -e "\|^${block_device}|d" /etc/fstab
|
sed -i -e "\|^${block_device}|d" /etc/fstab
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# Remove any existing /mnt/ephemeral entry in /etc/fstab
|
||||||
|
sed -i -e "\|/mnt/ephemeral|d" /etc/fstab
|
||||||
|
|
||||||
|
# Mount the storage
|
||||||
if [[ ${docker_storage} == "btrfs" ]]; then
|
if [[ ${docker_storage} == "btrfs" ]]; then
|
||||||
apt-get-install btrfs-tools
|
apt-get-install btrfs-tools
|
||||||
|
|
||||||
|
@ -75,7 +85,7 @@ else
|
||||||
echo "Found multiple ephemeral block devices, formatting with btrfs as RAID-0"
|
echo "Found multiple ephemeral block devices, formatting with btrfs as RAID-0"
|
||||||
mkfs.btrfs -f --data raid0 ${block_devices[@]}
|
mkfs.btrfs -f --data raid0 ${block_devices[@]}
|
||||||
fi
|
fi
|
||||||
echo "${block_devices[0]} /mnt/ephemeral btrfs noatime 0 0" >> /etc/fstab
|
echo "${block_devices[0]} /mnt/ephemeral btrfs noatime,nofail 0 0" >> /etc/fstab
|
||||||
mkdir -p /mnt/ephemeral
|
mkdir -p /mnt/ephemeral
|
||||||
mount /mnt/ephemeral
|
mount /mnt/ephemeral
|
||||||
|
|
||||||
|
@ -89,7 +99,7 @@ else
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkfs -t ext4 ${block_devices[0]}
|
mkfs -t ext4 ${block_devices[0]}
|
||||||
echo "${block_devices[0]} /mnt/ephemeral ext4 noatime 0 0" >> /etc/fstab
|
echo "${block_devices[0]} /mnt/ephemeral ext4 noatime,nofail 0 0" >> /etc/fstab
|
||||||
mkdir -p /mnt/ephemeral
|
mkdir -p /mnt/ephemeral
|
||||||
mount /mnt/ephemeral
|
mount /mnt/ephemeral
|
||||||
|
|
||||||
|
@ -129,7 +139,7 @@ else
|
||||||
lvcreate -l 100%FREE -n kubernetes vg-ephemeral
|
lvcreate -l 100%FREE -n kubernetes vg-ephemeral
|
||||||
mkfs -t ext4 /dev/vg-ephemeral/kubernetes
|
mkfs -t ext4 /dev/vg-ephemeral/kubernetes
|
||||||
mkdir -p /mnt/ephemeral/kubernetes
|
mkdir -p /mnt/ephemeral/kubernetes
|
||||||
echo "/dev/vg-ephemeral/kubernetes /mnt/ephemeral/kubernetes ext4 noatime 0 0" >> /etc/fstab
|
echo "/dev/vg-ephemeral/kubernetes /mnt/ephemeral/kubernetes ext4 noatime,nofail 0 0" >> /etc/fstab
|
||||||
mount /mnt/ephemeral/kubernetes
|
mount /mnt/ephemeral/kubernetes
|
||||||
|
|
||||||
move_kubelet="/mnt/ephemeral/kubernetes"
|
move_kubelet="/mnt/ephemeral/kubernetes"
|
||||||
|
@ -146,7 +156,7 @@ else
|
||||||
lvcreate -l 100%VG -n ephemeral vg-ephemeral
|
lvcreate -l 100%VG -n ephemeral vg-ephemeral
|
||||||
mkfs -t ext4 /dev/vg-ephemeral/ephemeral
|
mkfs -t ext4 /dev/vg-ephemeral/ephemeral
|
||||||
mkdir -p /mnt/ephemeral
|
mkdir -p /mnt/ephemeral
|
||||||
echo "/dev/vg-ephemeral/ephemeral /mnt/ephemeral ext4 noatime 0 0" >> /etc/fstab
|
echo "/dev/vg-ephemeral/ephemeral /mnt/ephemeral ext4 noatime,nofail 0 0" >> /etc/fstab
|
||||||
mount /mnt/ephemeral
|
mount /mnt/ephemeral
|
||||||
|
|
||||||
mkdir -p /mnt/ephemeral/kubernetes
|
mkdir -p /mnt/ephemeral/kubernetes
|
||||||
|
@ -183,7 +193,9 @@ if [[ -n "${move_docker}" ]]; then
|
||||||
mv /var/lib/docker ${move_docker}/
|
mv /var/lib/docker ${move_docker}/
|
||||||
fi
|
fi
|
||||||
mkdir -p ${move_docker}/docker
|
mkdir -p ${move_docker}/docker
|
||||||
ln -s ${move_docker}/docker /var/lib/docker
|
if [[ ! -e /var/lib/docker ]]; then
|
||||||
|
ln -s ${move_docker}/docker /var/lib/docker
|
||||||
|
fi
|
||||||
DOCKER_ROOT="${move_docker}/docker"
|
DOCKER_ROOT="${move_docker}/docker"
|
||||||
DOCKER_OPTS="${DOCKER_OPTS:-} -g ${DOCKER_ROOT}"
|
DOCKER_OPTS="${DOCKER_OPTS:-} -g ${DOCKER_ROOT}"
|
||||||
fi
|
fi
|
||||||
|
@ -195,7 +207,9 @@ if [[ -n "${move_kubelet}" ]]; then
|
||||||
mv /var/lib/kubelet ${move_kubelet}/
|
mv /var/lib/kubelet ${move_kubelet}/
|
||||||
fi
|
fi
|
||||||
mkdir -p ${move_kubelet}/kubelet
|
mkdir -p ${move_kubelet}/kubelet
|
||||||
ln -s ${move_kubelet}/kubelet /var/lib/kubelet
|
if [[ ! -e /var/lib/kubelet ]]; then
|
||||||
|
ln -s ${move_kubelet}/kubelet /var/lib/kubelet
|
||||||
|
fi
|
||||||
KUBELET_ROOT="${move_kubelet}/kubelet"
|
KUBELET_ROOT="${move_kubelet}/kubelet"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue