mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-23 03:41:45 +00:00
Merge pull request #35503 from wojtek-t/fix_migration
Automatic merge from submit-queue Fix migration script to make it sh-friendly Ref #22448 There is no bash in etcd image, so the script needs to be "sh-friendly". Also, few fixes to the script.
This commit is contained in:
commit
f11d01076e
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/sh
|
||||||
|
|
||||||
# Copyright 2016 The Kubernetes Authors.
|
# Copyright 2016 The Kubernetes Authors.
|
||||||
#
|
#
|
||||||
@ -59,7 +59,9 @@ fi
|
|||||||
|
|
||||||
# NOTE: SUPPORTED_VERSION has to match release binaries present in the
|
# NOTE: SUPPORTED_VERSION has to match release binaries present in the
|
||||||
# etcd image (to make this script work correctly).
|
# etcd image (to make this script work correctly).
|
||||||
SUPPORTED_VERSIONS=("2.2.1" "2.3.7" "3.0.12")
|
# We cannot use array since sh doesn't support it.
|
||||||
|
SUPPORTED_VERSIONS_STRING="2.2.1 2.3.7 3.0.12"
|
||||||
|
SUPPORTED_VERSIONS=$(echo "${SUPPORTED_VERSIONS_STRING}" | tr " " "\n")
|
||||||
|
|
||||||
VERSION_FILE="version.txt"
|
VERSION_FILE="version.txt"
|
||||||
CURRENT_STORAGE="etcd2"
|
CURRENT_STORAGE="etcd2"
|
||||||
@ -82,7 +84,7 @@ fi
|
|||||||
if [ -z "$(ls -A ${DATA_DIRECTORY})" ]; then
|
if [ -z "$(ls -A ${DATA_DIRECTORY})" ]; then
|
||||||
echo "${DATA_DIRECTORY} is empty - skipping migration"
|
echo "${DATA_DIRECTORY} is empty - skipping migration"
|
||||||
echo "${TARGET_VERSION}/${TARGET_STORAGE}" > "${DATA_DIRECTORY}/${VERSION_FILE}"
|
echo "${TARGET_VERSION}/${TARGET_STORAGE}" > "${DATA_DIRECTORY}/${VERSION_FILE}"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Starts 'etcd' version ${START_VERSION} and writes to it:
|
# Starts 'etcd' version ${START_VERSION} and writes to it:
|
||||||
@ -96,7 +98,8 @@ start_etcd() {
|
|||||||
ETCD_PEER_PORT=18630
|
ETCD_PEER_PORT=18630
|
||||||
local ETCD_CMD="${ETCD:-/usr/local/bin/etcd-${START_VERSION}}"
|
local ETCD_CMD="${ETCD:-/usr/local/bin/etcd-${START_VERSION}}"
|
||||||
local ETCDCTL_CMD="${ETCDCTL:-/usr/local/bin/etcdctl-${START_VERSION}}"
|
local ETCDCTL_CMD="${ETCDCTL:-/usr/local/bin/etcdctl-${START_VERSION}}"
|
||||||
if [ "${START_VERSION:0:2}" == "2." ]; then
|
local API_VERSION="$(echo ${START_STORAGE} | cut -c5-5)"
|
||||||
|
if [ "${API_VERSION}" = "2" ]; then
|
||||||
ETCDCTL_CMD="${ETCDCTL_CMD} --endpoint=http://127.0.0.1:${ETCD_PORT} set"
|
ETCDCTL_CMD="${ETCDCTL_CMD} --endpoint=http://127.0.0.1:${ETCD_PORT} set"
|
||||||
else
|
else
|
||||||
ETCDCTL_CMD="${ETCDCTL_CMD} --endpoints=http://127.0.0.1:${ETCD_PORT} put"
|
ETCDCTL_CMD="${ETCDCTL_CMD} --endpoints=http://127.0.0.1:${ETCD_PORT} put"
|
||||||
@ -108,7 +111,6 @@ start_etcd() {
|
|||||||
--initial-advertise-peer-urls http://127.0.0.1:${ETCD_PEER_PORT} \
|
--initial-advertise-peer-urls http://127.0.0.1:${ETCD_PEER_PORT} \
|
||||||
1>>/dev/null 2>&1 &
|
1>>/dev/null 2>&1 &
|
||||||
ETCD_PID=$!
|
ETCD_PID=$!
|
||||||
local API_VERSION="${START_STORAGE:4:4}"
|
|
||||||
# Wait until we can write to etcd.
|
# Wait until we can write to etcd.
|
||||||
for i in $(seq 240); do
|
for i in $(seq 240); do
|
||||||
ETCDCTL_API="${API_VERSION}" ${ETCDCTL_CMD} 'etcd_version' ${START_VERSION}
|
ETCDCTL_API="${API_VERSION}" ${ETCDCTL_CMD} 'etcd_version' ${START_VERSION}
|
||||||
@ -132,8 +134,18 @@ ATTACHLEASE="${ATTACHLEASE:-/usr/local/bin/attachlease}"
|
|||||||
ROLLBACK="${ROLLBACK:-/usr/local/bin/rollback}"
|
ROLLBACK="${ROLLBACK:-/usr/local/bin/rollback}"
|
||||||
|
|
||||||
# Do the roll-forward migration if needed.
|
# Do the roll-forward migration if needed.
|
||||||
for step in "${SUPPORTED_VERSIONS[@]}"; do
|
# The migration goes as following:
|
||||||
if [ "${step}" == "${CURRENT_VERSION}" -a "${CURRENT_VERSION}" != "${TARGET_VERSION}" ]; then
|
# 1. for all versions starting one after the current version of etcd
|
||||||
|
# we do "start, wait until healthy and stop etcd". This is the
|
||||||
|
# procedure that etcd documentation suggests for upgrading binaries.
|
||||||
|
# 2. For the first 3.0.x version that we encounter, if we are still in
|
||||||
|
# v2 API, we do upgrade to v3 API using the "etcdct migrate" and
|
||||||
|
# attachlease commands.
|
||||||
|
SKIP_STEP=true
|
||||||
|
for step in ${SUPPORTED_VERSIONS}; do
|
||||||
|
if [ "${step}" = "${CURRENT_VERSION}" ]; then
|
||||||
|
SKIP_STEP=false
|
||||||
|
elif [ "${SKIP_STEP}" != "true" ]; then
|
||||||
# Do the migration step, by just starting etcd in this version.
|
# Do the migration step, by just starting etcd in this version.
|
||||||
START_VERSION="${step}"
|
START_VERSION="${step}"
|
||||||
START_STORAGE="${CURRENT_STORAGE}"
|
START_STORAGE="${CURRENT_STORAGE}"
|
||||||
@ -147,7 +159,7 @@ for step in "${SUPPORTED_VERSIONS[@]}"; do
|
|||||||
fi
|
fi
|
||||||
CURRENT_VERSION=${step}
|
CURRENT_VERSION=${step}
|
||||||
echo "${CURRENT_VERSION}/${CURRENT_STORAGE}" > "${DATA_DIRECTORY}/${VERSION_FILE}"
|
echo "${CURRENT_VERSION}/${CURRENT_STORAGE}" > "${DATA_DIRECTORY}/${VERSION_FILE}"
|
||||||
if [ "${CURRENT_VERSION:0:2}" == "3." -a "${CURRENT_STORAGE}" == "etcd2" -a "${TARGET_STORAGE}" == "etcd3" ]; then
|
if [ "$(echo ${CURRENT_VERSION} | cut -c1-2)" = "3." -a "${CURRENT_STORAGE}" = "etcd2" -a "${TARGET_STORAGE}" = "etcd3" ]; then
|
||||||
# If it is the first 3.x release in the list and we are migrating
|
# If it is the first 3.x release in the list and we are migrating
|
||||||
# also from 'etcd2' to 'etcd3', do the migration now.
|
# also from 'etcd2' to 'etcd3', do the migration now.
|
||||||
echo "Performing etcd2 -> etcd3 migration"
|
echo "Performing etcd2 -> etcd3 migration"
|
||||||
@ -173,7 +185,7 @@ for step in "${SUPPORTED_VERSIONS[@]}"; do
|
|||||||
CURRENT_STORAGE="etcd3"
|
CURRENT_STORAGE="etcd3"
|
||||||
echo "${CURRENT_VERSION}/${CURRENT_STORAGE}" > "${DATA_DIRECTORY}/${VERSION_FILE}"
|
echo "${CURRENT_VERSION}/${CURRENT_STORAGE}" > "${DATA_DIRECTORY}/${VERSION_FILE}"
|
||||||
fi
|
fi
|
||||||
if [ "${CURRENT_VERSION}" == "${TARGET_VERSION}" -a "${CURRENT_STORAGE}" == "${TARGET_STORAGE}" ]; then
|
if [ "${CURRENT_VERSION}" = "${TARGET_VERSION}" -a "${CURRENT_STORAGE}" = "${TARGET_STORAGE}" ]; then
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
@ -181,8 +193,8 @@ done
|
|||||||
# Do the rollback of needed.
|
# Do the rollback of needed.
|
||||||
# NOTE: Rollback is only supported from "3.0.x" version in 'etcd3' mode to
|
# NOTE: Rollback is only supported from "3.0.x" version in 'etcd3' mode to
|
||||||
# "2.3.7" version in 'etcd2' mode.
|
# "2.3.7" version in 'etcd2' mode.
|
||||||
if [ "${CURRENT_STORAGE}" == "etcd3" -a "${TARGET_STORAGE}" == "etcd2" ]; then
|
if [ "${CURRENT_STORAGE}" = "etcd3" -a "${TARGET_STORAGE}" = "etcd2" ]; then
|
||||||
if [ "${CURRENT_VERSION:0:4}" != "3.0." -o "${TARGET_VERSION}" != "2.3.7" ]; then
|
if [ "$(echo ${CURRENT_VERSION} | cut -c1-4)" != "3.0." -o "${TARGET_VERSION}" != "2.3.7" ]; then
|
||||||
echo "etcd3 -> etcd2 downgrade is supported only between 3.0.x and 2.3.7"
|
echo "etcd3 -> etcd2 downgrade is supported only between 3.0.x and 2.3.7"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
@ -160,7 +160,7 @@ killApiServer
|
|||||||
|
|
||||||
kube::etcd::stop
|
kube::etcd::stop
|
||||||
TARGET_STORAGE="etcd3" \
|
TARGET_STORAGE="etcd3" \
|
||||||
TARGET_VERSION="3.0.10" \
|
TARGET_VERSION="3.0.12" \
|
||||||
DATA_DIRECTORY="${ETCD_DIR}" \
|
DATA_DIRECTORY="${ETCD_DIR}" \
|
||||||
ETCD=$(which etcd) \
|
ETCD=$(which etcd) \
|
||||||
ETCDCTL=$(which etcdctl) \
|
ETCDCTL=$(which etcdctl) \
|
||||||
|
Loading…
Reference in New Issue
Block a user