kops/docs/calico_cidr_migration/create_migration_manifest.sh

53 lines
2.1 KiB
Bash
Executable File

#!/bin/bash
# Copyright 2017 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
###############################################################################
#
# create_migration_manifest.sh
#
# Script that returns a templated Calico CIDR migration manifest file.
#
###############################################################################
set -e
command -v jq >/dev/null 2>&1 || { echo >&2 "jq is required to run this script."; exit 1; }
command -v kops >/dev/null 2>&1 || { echo >&2 "kops is required to run this script."; exit 1; }
[ -z "$NAME" ] && echo "Please set NAME to the name of your cluster you wish to perform this migration against." && exit 1;
export MIGRATION_TEMPLATE="jobs.yaml.template"
export MIGRATION_MANIFEST="jobs.yaml"
export NON_MASQUERADE_CIDR="`kops get cluster $NAME -o json --full | jq .spec.nonMasqueradeCIDR --raw-output`"
export POD_CIDR="`kops get cluster $NAME -o json --full | jq .spec.kubeControllerManager.clusterCIDR --raw-output`"
export IS_CROSS_SUBNET="`kops get cluster $NAME -o json --full | jq .spec.networking.calico.crossSubnet --raw-output`"
cp ${MIGRATION_TEMPLATE} ${MIGRATION_MANIFEST}
if [ "$IS_CROSS_SUBNET" = "true" ]; then
echo "ipip mode is set to 'cross-subnet'. Honouring in migration manifest."
else
echo "ipip mode is set to 'Always'. Honouring in migration manifest."
sed -i "/mode: cross-subnet/d" ${MIGRATION_MANIFEST}
fi
sed -i -e "s@{{NON_MASQUERADE_CIDR}}@${NON_MASQUERADE_CIDR}@g" ${MIGRATION_MANIFEST}
sed -i -e "s@{{POD_CIDR}}@${POD_CIDR}@g" ${MIGRATION_MANIFEST}
echo "jobs.yaml created. Please run: "
echo "kubectl apply -f jobs.yaml"