mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-26 02:55:32 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			223 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			223 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| # Copyright 2015 The Kubernetes Authors All rights reserved.
 | |
| #
 | |
| # 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.
 | |
| 
 | |
| # A script to the k8s worker in docker containers.
 | |
| # Authors @wizard_cxy @resouer
 | |
| 
 | |
| set -e
 | |
| 
 | |
| # Make sure docker daemon is running
 | |
| if ( ! ps -ef | grep "/usr/bin/docker" | grep -v 'grep' &> /dev/null  ); then
 | |
|     echo "Docker is not running on this machine!"
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| # Make sure k8s version env is properly set
 | |
| K8S_VERSION=${K8S_VERSION:-"1.2.0-alpha.6"}
 | |
| FLANNEL_VERSION=${FLANNEL_VERSION:-"0.5.5"}
 | |
| FLANNEL_IFACE=${FLANNEL_IFACE:-"eth0"}
 | |
| ARCH=${ARCH:-"amd64"}
 | |
| 
 | |
| # Run as root
 | |
| if [ "$(id -u)" != "0" ]; then
 | |
|     echo >&2 "Please run as root"
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| # Make sure master ip is properly set
 | |
| if [ -z ${MASTER_IP} ]; then
 | |
|     echo "Please export MASTER_IP in your env"
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| echo "K8S_VERSION is set to: ${K8S_VERSION}"
 | |
| echo "FLANNEL_VERSION is set to: ${FLANNEL_VERSION}"
 | |
| echo "FLANNEL_IFACE is set to: ${FLANNEL_IFACE}"
 | |
| echo "MASTER_IP is set to: ${MASTER_IP}"
 | |
| echo "ARCH is set to: ${ARCH}"
 | |
| 
 | |
| # Check if a command is valid
 | |
| command_exists() {
 | |
|     command -v "$@" > /dev/null 2>&1
 | |
| }
 | |
| 
 | |
| lsb_dist=""
 | |
| 
 | |
| # Detect the OS distro, we support ubuntu, debian, mint, centos, fedora dist
 | |
| detect_lsb() {
 | |
|     case "$(uname -m)" in
 | |
|         *64)
 | |
|             ;;
 | |
|         *)
 | |
| 	        echo "Error: We currently only support 64-bit platforms."	    
 | |
| 	        exit 1
 | |
| 	        ;;
 | |
|     esac
 | |
| 
 | |
|     if command_exists lsb_release; then
 | |
|         lsb_dist="$(lsb_release -si)"
 | |
|     fi
 | |
|     if [ -z ${lsb_dist} ] && [ -r /etc/lsb-release ]; then
 | |
|         lsb_dist="$(. /etc/lsb-release && echo "$DISTRIB_ID")"
 | |
|     fi
 | |
|     if [ -z ${lsb_dist} ] && [ -r /etc/debian_version ]; then
 | |
|         lsb_dist='debian'
 | |
|     fi
 | |
|     if [ -z ${lsb_dist} ] && [ -r /etc/fedora-release ]; then
 | |
|         lsb_dist='fedora'
 | |
|     fi
 | |
|     if [ -z ${lsb_dist} ] && [ -r /etc/os-release ]; then
 | |
|         lsb_dist="$(. /etc/os-release && echo "$ID")"
 | |
|     fi
 | |
| 
 | |
|     lsb_dist="$(echo ${lsb_dist} | tr '[:upper:]' '[:lower:]')"
 | |
| 
 | |
|     case "${lsb_dist}" in
 | |
|         amzn|centos|debian|ubuntu)
 | |
|             ;;
 | |
|         *)
 | |
|             echo "Error: We currently only support ubuntu|debian|amzn|centos."
 | |
|             exit 1
 | |
|             ;;
 | |
|     esac
 | |
| }
 | |
| 
 | |
| 
 | |
| # Start the bootstrap daemon
 | |
| bootstrap_daemon() {
 | |
|     docker -d \
 | |
|         -H unix:///var/run/docker-bootstrap.sock \
 | |
|         -p /var/run/docker-bootstrap.pid \
 | |
|         --iptables=false \
 | |
|         --ip-masq=false \
 | |
|         --bridge=none \
 | |
|         --graph=/var/lib/docker-bootstrap \
 | |
|             2> /var/log/docker-bootstrap.log \
 | |
|             1> /dev/null &
 | |
| 
 | |
|     sleep 5
 | |
| }
 | |
| 
 | |
| DOCKER_CONF=""
 | |
| 
 | |
| # Start k8s components in containers
 | |
| start_k8s() {
 | |
|     # Start flannel
 | |
|     flannelCID=$(docker -H unix:///var/run/docker-bootstrap.sock run \
 | |
|         -d \
 | |
|         --restart=always \
 | |
|         --net=host \
 | |
|         --privileged \
 | |
|         -v /dev/net:/dev/net \
 | |
|         quay.io/coreos/flannel:${FLANNEL_VERSION} \
 | |
|         /opt/bin/flanneld \
 | |
|             --ip-masq \
 | |
|             --etcd-endpoints=http://${MASTER_IP}:4001 \
 | |
|             --iface="${FLANNEL_IFACE}")
 | |
| 
 | |
|     sleep 10
 | |
| 
 | |
|     # Copy flannel env out and source it on the host
 | |
|     docker -H unix:///var/run/docker-bootstrap.sock \
 | |
|         cp ${flannelCID}:/run/flannel/subnet.env .
 | |
|     source subnet.env
 | |
| 
 | |
|     # Configure docker net settings, then restart it
 | |
|     case "${lsb_dist}" in
 | |
|         centos)
 | |
|             DOCKER_CONF="/etc/sysconfig/docker"
 | |
|             echo "OPTIONS=\"\$OPTIONS --mtu=${FLANNEL_MTU} --bip=${FLANNEL_SUBNET}\"" | tee -a ${DOCKER_CONF}
 | |
|             if ! command_exists ifconfig; then
 | |
|                 yum -y -q install net-tools
 | |
|             fi
 | |
|             ifconfig docker0 down
 | |
|             yum -y -q install bridge-utils && brctl delbr docker0 && systemctl restart docker
 | |
|             ;;
 | |
|         amzn)
 | |
|             DOCKER_CONF="/etc/sysconfig/docker"
 | |
|             echo "OPTIONS=\"\$OPTIONS --mtu=${FLANNEL_MTU} --bip=${FLANNEL_SUBNET}\"" | tee -a ${DOCKER_CONF}
 | |
|             ifconfig docker0 down
 | |
|             yum -y -q install bridge-utils && brctl delbr docker0 && service docker restart
 | |
|             ;;
 | |
|         ubuntu|debian) # TODO: today ubuntu uses systemd. Handle that too
 | |
|             DOCKER_CONF="/etc/default/docker"
 | |
|             echo "DOCKER_OPTS=\"\$DOCKER_OPTS --mtu=${FLANNEL_MTU} --bip=${FLANNEL_SUBNET}\"" | tee -a ${DOCKER_CONF}
 | |
|             ifconfig docker0 down
 | |
|             apt-get install bridge-utils
 | |
|             brctl delbr docker0
 | |
|             service docker stop
 | |
|             while [ `ps aux | grep /usr/bin/docker | grep -v grep | wc -l` -gt 0 ]; do
 | |
|                 echo "Waiting for docker to terminate"
 | |
|                 sleep 1
 | |
|             done
 | |
|             service docker start
 | |
|             ;;
 | |
|         *)
 | |
|             echo "Unsupported operations system ${lsb_dist}"
 | |
|             exit 1
 | |
|             ;;
 | |
|     esac
 | |
| 
 | |
|     # sleep a little bit
 | |
|     sleep 5
 | |
|     
 | |
|     # Start kubelet & proxy in container
 | |
|     # TODO: Use secure port for communication
 | |
|     docker run \
 | |
|         --net=host \
 | |
|         --pid=host \
 | |
|         --privileged \
 | |
|         --restart=always \
 | |
|         -d \
 | |
|         -v /sys:/sys:ro \
 | |
|         -v /var/run:/var/run:rw  \
 | |
|         -v /:/rootfs:ro \
 | |
|         -v /dev:/dev \
 | |
|         -v /var/lib/docker/:/var/lib/docker:rw \
 | |
|         -v /var/lib/kubelet/:/var/lib/kubelet:rw \
 | |
|         gcr.io/google_containers/hyperkube-${ARCH}:v${K8S_VERSION} \
 | |
|         /hyperkube kubelet \
 | |
|             --allow-privileged=true \
 | |
|             --api-servers=http://${MASTER_IP}:8080 \
 | |
|             --address=0.0.0.0 \
 | |
|             --enable-server \
 | |
|             --cluster-dns=10.0.0.10 \
 | |
|             --cluster-domain=cluster.local \
 | |
|             --containerized \
 | |
|             --v=2
 | |
|     
 | |
|     docker run \
 | |
|         -d \
 | |
|         --net=host \
 | |
|         --privileged \
 | |
|         --restart=always \
 | |
|         gcr.io/google_containers/hyperkube-${ARCH}:v${K8S_VERSION} \
 | |
|         /hyperkube proxy \
 | |
|             --master=http://${MASTER_IP}:8080 \
 | |
|             --v=2
 | |
| }
 | |
| 
 | |
| echo "Detecting your OS distro ..."
 | |
| detect_lsb
 | |
| 
 | |
| echo "Starting bootstrap docker ..."
 | |
| bootstrap_daemon
 | |
| 
 | |
| echo "Starting k8s ..."
 | |
| start_k8s
 | |
| 
 | |
| echo "Worker done!"
 |