mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 01:32:18 +02:00 
			
		
		
		
	* Support creation of PV(persistent volumes) in CloudStack projects * add support for snapshot APIs for project role * Add support to setup csi driver on k8s cluster creation * fix deploy script * update response * fix table name * fix linter * show if csi driver is setup in cluster * delete pvs whose reclaim policy is delete when cluster is destroyed * update ref * move changes to 4.22 * fix variables * fix eof
		
			
				
	
	
		
			187 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			187 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash -x
 | |
| # Licensed to the Apache Software Foundation (ASF) under one
 | |
| # or more contributor license agreements.  See the NOTICE file
 | |
| # distributed with this work for additional information
 | |
| # regarding copyright ownership.  The ASF licenses this file
 | |
| # to you 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.
 | |
| 
 | |
| set -e
 | |
| 
 | |
| if [ $# -lt 6 ]; then
 | |
|     echo "Invalid input. Valid usage: ./create-kubernetes-binaries-iso.sh OUTPUT_PATH KUBERNETES_VERSION CNI_VERSION CRICTL_VERSION WEAVENET_NETWORK_YAML_CONFIG DASHBOARD_YAML_CONFIG BUILD_NAME [ARCH] [ETCD_VERSION]"
 | |
|     echo "eg: ./create-kubernetes-binaries-iso.sh ./ 1.11.4 0.7.1 1.11.1 https://github.com/weaveworks/weave/releases/download/latest_release/weave-daemonset-k8s-1.11.yaml https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.0/src/deploy/recommended/kubernetes-dashboard.yaml setup-v1.11.4 amd64"
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| ARCH="amd64"
 | |
| ARCH_SUFFIX="x86_64"
 | |
| if [ -n "${8}" ]; then
 | |
|   if [ "${8}" = "x86_64" ] || [ "${8}" = "amd64" ]; then
 | |
|     ARCH="amd64"
 | |
|     ARCH_SUFFIX="x86_64"
 | |
|   elif [ "${8}" = "aarch64" ] || [ "${8}" = "arm64" ]; then
 | |
|     ARCH="arm64"
 | |
|     ARCH_SUFFIX="aarch64"
 | |
|   else
 | |
|     echo "ERROR: ARCH must be 'x86_64' or 'aarch64'. If the optional parameter ARCH is not set then 'x86_64' is used."
 | |
|     exit 1
 | |
|   fi
 | |
| fi
 | |
| 
 | |
| RELEASE="v${2}"
 | |
| VAL="1.18.0"
 | |
| output_dir="${1}"
 | |
| start_dir="$PWD"
 | |
| iso_dir="/tmp/iso"
 | |
| working_dir="${iso_dir}/"
 | |
| mkdir -p "${working_dir}"
 | |
| build_name="${7}-${ARCH_SUFFIX}.iso"
 | |
| [ -z "${build_name}" ] && build_name="setup-${RELEASE}-${ARCH_SUFFIX}.iso"
 | |
| 
 | |
| CNI_VERSION="v${3}"
 | |
| echo "Downloading CNI ${CNI_VERSION}..."
 | |
| cni_dir="${working_dir}/cni/"
 | |
| mkdir -p "${cni_dir}"
 | |
| cni_status_code=$(curl -L  --write-out "%{http_code}\n" "https://github.com/containernetworking/plugins/releases/download/${CNI_VERSION}/cni-plugins-linux-${ARCH}-${CNI_VERSION}.tgz" -o "${cni_dir}/cni-plugins-${ARCH}.tgz")
 | |
| if [[ ${cni_status_code} -eq 404 ]] ; then
 | |
|   curl -L  --write-out "%{http_code}\n" "https://github.com/containernetworking/plugins/releases/download/${CNI_VERSION}/cni-plugins-${ARCH}-${CNI_VERSION}.tgz" -o "${cni_dir}/cni-plugins-${ARCH}.tgz"
 | |
| fi
 | |
| 
 | |
| CRICTL_VERSION="v${4}"
 | |
| echo "Downloading CRI tools ${CRICTL_VERSION}..."
 | |
| crictl_dir="${working_dir}/cri-tools/"
 | |
| mkdir -p "${crictl_dir}"
 | |
| curl -L "https://github.com/kubernetes-incubator/cri-tools/releases/download/${CRICTL_VERSION}/crictl-${CRICTL_VERSION}-linux-${ARCH}.tar.gz" -o "${crictl_dir}/crictl-linux-${ARCH}.tar.gz"
 | |
| 
 | |
| echo "Downloading Kubernetes tools ${RELEASE}..."
 | |
| k8s_dir="${working_dir}/k8s"
 | |
| mkdir -p "${k8s_dir}"
 | |
| cd "${k8s_dir}"
 | |
| curl -L --remote-name-all https://dl.k8s.io/release/${RELEASE}/bin/linux/${ARCH}/{kubeadm,kubelet,kubectl}
 | |
| kubeadm_file_permissions=`stat --format '%a' kubeadm`
 | |
| chmod +x kubeadm
 | |
| 
 | |
| echo "Downloading kubelet.service ${RELEASE}..."
 | |
| cd "${start_dir}"
 | |
| kubelet_service_file="${working_dir}/kubelet.service"
 | |
| touch "${kubelet_service_file}"
 | |
| if [[ `echo "${2} $VAL" | awk '{print ($1 < $2)}'` == 1 ]]; then
 | |
|   curl -sSL "https://raw.githubusercontent.com/kubernetes/kubernetes/${RELEASE}/build/debs/kubelet.service" | sed "s:/usr/bin:/opt/bin:g" > ${kubelet_service_file}
 | |
| else
 | |
|   curl -sSL "https://raw.githubusercontent.com/shapeblue/cloudstack-nonoss/main/cks/kubelet.service" | sed "s:/usr/bin:/opt/bin:g" > ${kubelet_service_file}
 | |
| fi
 | |
| 
 | |
| echo "Downloading 10-kubeadm.conf ${RELEASE}..."
 | |
| kubeadm_conf_file="${working_dir}/10-kubeadm.conf"
 | |
| touch "${kubeadm_conf_file}"
 | |
| if [[ `echo "${2} $val" | awk '{print ($1 < $2)}'` == 1 ]]; then
 | |
|   curl -sSL "https://raw.githubusercontent.com/kubernetes/kubernetes/${RELEASE}/build/debs/10-kubeadm.conf" | sed "s:/usr/bin:/opt/bin:g" > ${kubeadm_conf_file}
 | |
| else
 | |
|   curl -sSL "https://raw.githubusercontent.com/shapeblue/cloudstack-nonoss/main/cks/10-kubeadm.conf" | sed "s:/usr/bin:/opt/bin:g" > ${kubeadm_conf_file}
 | |
| fi
 | |
| 
 | |
| NETWORK_CONFIG_URL="${5}"
 | |
| echo "Downloading network config ${NETWORK_CONFIG_URL}"
 | |
| network_conf_file="${working_dir}/network.yaml"
 | |
| curl -sSL ${NETWORK_CONFIG_URL} -o ${network_conf_file}
 | |
| 
 | |
| DASHBORAD_CONFIG_URL="${6}"
 | |
| echo "Downloading dashboard config ${DASHBORAD_CONFIG_URL}"
 | |
| dashboard_conf_file="${working_dir}/dashboard.yaml"
 | |
| curl -sSL ${DASHBORAD_CONFIG_URL} -o ${dashboard_conf_file}
 | |
| 
 | |
| # TODO : Change the url once merged
 | |
| AUTOSCALER_URL="https://raw.githubusercontent.com/kubernetes/autoscaler/master/cluster-autoscaler/cloudprovider/cloudstack/examples/cluster-autoscaler-standard.yaml"
 | |
| echo "Downloading kubernetes cluster autoscaler ${AUTOSCALER_URL}"
 | |
| autoscaler_conf_file="${working_dir}/autoscaler.yaml"
 | |
| curl -sSL ${AUTOSCALER_URL} -o ${autoscaler_conf_file}
 | |
| 
 | |
| PROVIDER_URL="https://raw.githubusercontent.com/apache/cloudstack-kubernetes-provider/main/deployment.yaml"
 | |
| echo "Downloading kubernetes cluster provider ${PROVIDER_URL}"
 | |
| provider_conf_file="${working_dir}/provider.yaml"
 | |
| curl -sSL ${PROVIDER_URL} -o ${provider_conf_file}
 | |
| 
 | |
| csi_conf_file="${working_dir}/manifest.yaml"
 | |
| echo "Including CloudStack CSI Driver manifest"
 | |
| wget https://github.com/cloudstack/cloudstack-csi-driver/releases/download/v3.0.0/snapshot-crds.yaml -O ${working_dir}/snapshot-crds.yaml
 | |
| wget https://github.com/cloudstack/cloudstack-csi-driver/releases/download/v3.0.0/manifest.yaml -O ${csi_conf_file}
 | |
| 
 | |
| echo "Fetching k8s docker images..."
 | |
| ctr -v
 | |
| if [ $? -ne 0 ]; then
 | |
|     echo "Installing containerd..."
 | |
|     if [ -f /etc/redhat-release ]; then
 | |
|       sudo yum -y remove docker-common docker container-selinux docker-selinux docker-engine
 | |
|       sudo yum -y install lvm2 device-mapper device-mapper-persistent-data device-mapper-event device-mapper-libs device-mapper-event-libs
 | |
|       sudo yum install -y http://mirror.centos.org/centos/7/extras/x86_64/Packages/container-selinux-2.107-3.el7.noarch.rpm
 | |
|       sudo yum install -y containerd.io
 | |
|     elif [ -f /etc/lsb-release ]; then
 | |
|       sudo apt update && sudo apt install containerd.io -y
 | |
|     fi
 | |
|     sudo systemctl enable containerd && sudo systemctl start containerd
 | |
| fi
 | |
| mkdir -p "${working_dir}/docker"
 | |
| output=`${k8s_dir}/kubeadm config images list --kubernetes-version=${RELEASE}`
 | |
| 
 | |
| # Don't forget about the yaml images !
 | |
| for i in ${network_conf_file} ${dashboard_conf_file}
 | |
| do
 | |
|   images=`grep "image:" $i | cut -d ':' -f2- | tr -d ' ' | tr -d "'"`
 | |
|   output=`printf "%s\n" ${output} ${images}`
 | |
| done
 | |
| 
 | |
| # Don't forget about the other image !
 | |
| autoscaler_image=`grep "image:" ${autoscaler_conf_file} | cut -d ':' -f2- | tr -d ' '`
 | |
| output=`printf "%s\n" ${output} ${autoscaler_image}`
 | |
| 
 | |
| provider_image=`grep "image:" ${provider_conf_file} | cut -d ':' -f2- | tr -d ' '`
 | |
| output=`printf "%s\n" ${output} ${provider_image}`
 | |
| 
 | |
| # Extract images from manifest.yaml and add to output
 | |
| csi_images=`grep "image:" "${csi_conf_file}" | cut -d ':' -f2- | tr -d ' ' | tr -d "'"`
 | |
| output=`printf "%s\n%s" "${output}" "${csi_images}"`
 | |
| 
 | |
| while read -r line; do
 | |
|     echo "Downloading image $line ---"
 | |
|     if [[ $line == kubernetesui* ]] || [[ $line == apache* ]] || [[ $line == weaveworks* ]]; then
 | |
|       line="docker.io/${line}"
 | |
|     fi
 | |
|     sudo ctr image pull "$line"
 | |
|     image_name=`echo "$line" | grep -oE "[^/]+$"`
 | |
|     sudo ctr image export "${working_dir}/docker/$image_name.tar" "$line"
 | |
|     sudo ctr image rm "$line"
 | |
| done <<< "$output"
 | |
| 
 | |
| echo "Restore kubeadm permissions..."
 | |
| if [ -z "${kubeadm_file_permissions}" ]; then
 | |
|     kubeadm_file_permissions=644
 | |
| fi
 | |
| chmod ${kubeadm_file_permissions} "${working_dir}/k8s/kubeadm"
 | |
| 
 | |
| echo "Updating imagePullPolicy to IfNotPresent in yaml files..."
 | |
| sed -i "s/imagePullPolicy:.*/imagePullPolicy: IfNotPresent/g" ${working_dir}/*.yaml
 | |
| 
 | |
| # Optional parameter ETCD_VERSION
 | |
| if [ -n "${9}" ]; then
 | |
|   # Install etcd dependencies
 | |
|   etcd_dir="${working_dir}/etcd"
 | |
|   mkdir -p "${etcd_dir}"
 | |
|   ETCD_VERSION=v${9}
 | |
|   wget -q --show-progress "https://github.com/etcd-io/etcd/releases/download/${ETCD_VERSION}/etcd-${ETCD_VERSION}-linux-amd64.tar.gz" -O ${etcd_dir}/etcd-linux-amd64.tar.gz
 | |
| fi
 | |
| 
 | |
| mkisofs -o "${output_dir}/${build_name}" -J -R -l "${iso_dir}"
 | |
| 
 | |
| rm -rf "${iso_dir}"
 |