github.com/enmand/kubernetes@v1.2.0-alpha.0/docs/getting-started-guides/docker-multinode/worker.sh (about)

     1  #!/bin/bash
     2  
     3  # Copyright 2015 The Kubernetes Authors All rights reserved.
     4  #
     5  # Licensed under the Apache License, Version 2.0 (the "License");
     6  # you may not use this file except in compliance with the License.
     7  # You may obtain a copy of the License at
     8  #
     9  #     http://www.apache.org/licenses/LICENSE-2.0
    10  #
    11  # Unless required by applicable law or agreed to in writing, software
    12  # distributed under the License is distributed on an "AS IS" BASIS,
    13  # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    14  # See the License for the specific language governing permissions and
    15  # limitations under the License.
    16  
    17  # A scripts to install k8s worker node.
    18  # Author @wizard_cxy @reouser
    19  
    20  set -e
    21  
    22  # Make sure docker daemon is running
    23  if ( ! ps -ef | grep "/usr/bin/docker" | grep -v 'grep' &> /dev/null  ); then
    24      echo "Docker is not running on this machine!"
    25      exit 1
    26  fi
    27  
    28  # Make sure k8s version env is properly set
    29  if [ -z ${K8S_VERSION} ]; then
    30      K8S_VERSION="1.0.3"
    31      echo "K8S_VERSION is not set, using default: ${K8S_VERSION}"
    32  else
    33      echo "k8s version is set to: ${K8S_VERSION}"
    34  fi
    35  
    36  
    37  
    38  # Run as root
    39  if [ "$(id -u)" != "0" ]; then
    40      echo >&2 "Please run as root"
    41      exit 1
    42  fi
    43  
    44  # Make sure master ip is properly set
    45  if [ -z ${MASTER_IP} ]; then
    46      echo "Please export MASTER_IP in your env"
    47      exit 1
    48  else
    49      echo "k8s master is set to: ${MASTER_IP}"
    50  fi
    51  
    52  # Check if a command is valid
    53  command_exists() {
    54      command -v "$@" > /dev/null 2>&1
    55  }
    56  
    57  lsb_dist=""
    58  
    59  # Detect the OS distro, we support ubuntu, debian, mint, centos, fedora dist
    60  detect_lsb() {
    61      case "$(uname -m)" in
    62      *64)
    63          ;;
    64      *)
    65  	echo "Error: We currently only support 64-bit platforms."	    
    66  	exit 1
    67  	;;
    68      esac
    69  
    70      if command_exists lsb_release; then
    71          lsb_dist="$(lsb_release -si)"
    72      fi
    73      if [ -z ${lsb_dist} ] && [ -r /etc/lsb-release ]; then
    74          lsb_dist="$(. /etc/lsb-release && echo "$DISTRIB_ID")"
    75      fi
    76      if [ -z ${lsb_dist} ] && [ -r /etc/debian_version ]; then
    77          lsb_dist='debian'
    78      fi
    79      if [ -z ${lsb_dist} ] && [ -r /etc/fedora-release ]; then
    80          lsb_dist='fedora'
    81      fi
    82      if [ -z ${lsb_dist} ] && [ -r /etc/os-release ]; then
    83          lsb_dist="$(. /etc/os-release && echo "$ID")"
    84      fi
    85  
    86      lsb_dist="$(echo ${lsb_dist} | tr '[:upper:]' '[:lower:]')"
    87  }
    88  
    89  
    90  # Start the bootstrap daemon
    91  bootstrap_daemon() {
    92      sudo -b 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
    93  
    94      sleep 5
    95  }
    96  
    97  DOCKER_CONF=""
    98  
    99  # Start k8s components in containers
   100  start_k8s() {
   101      # Start flannel
   102      flannelCID=$(sudo docker -H unix:///var/run/docker-bootstrap.sock run -d --restart=always --net=host --privileged -v /dev/net:/dev/net quay.io/coreos/flannel:0.5.0 /opt/bin/flanneld --etcd-endpoints=http://${MASTER_IP}:4001 -iface="eth0")
   103  
   104      sleep 8
   105  
   106      # Copy flannel env out and source it on the host
   107      sudo docker -H unix:///var/run/docker-bootstrap.sock cp ${flannelCID}:/run/flannel/subnet.env .
   108      source subnet.env
   109  
   110      # Configure docker net settings, then restart it
   111      case "$lsb_dist" in
   112          fedora|centos|amzn)
   113              DOCKER_CONF="/etc/sysconfig/docker"
   114          ;;
   115          ubuntu|debian|linuxmint)
   116              DOCKER_CONF="/etc/default/docker"
   117          ;;
   118      esac
   119  
   120      echo "DOCKER_OPTS=\"\$DOCKER_OPTS --mtu=${FLANNEL_MTU} --bip=${FLANNEL_SUBNET}\"" | sudo tee -a ${DOCKER_CONF}
   121  
   122      ifconfig docker0 down
   123  
   124      case "$lsb_dist" in
   125          fedora|centos)
   126              yum install bridge-utils && brctl delbr docker0 && systemctl restart docker
   127          ;;
   128          ubuntu|debian|linuxmint)
   129              apt-get install bridge-utils && brctl delbr docker0 && service docker restart
   130          ;;
   131      esac
   132  
   133      # sleep a little bit
   134      sleep 5
   135      
   136      # Start kubelet & proxy in container
   137      docker run \
   138          --net=host \
   139          --privileged \
   140          --restart=always \
   141          -d \
   142          -v /sys:/sys:ro \
   143          -v /var/run:/var/run:rw  \
   144          -v /dev:/dev \
   145          -v /var/lib/docker/:/var/lib/docker:ro \
   146          -v /var/lib/kubelet/:/var/lib/kubelet:rw \
   147          gcr.io/google_containers/hyperkube:v${K8S_VERSION} \
   148          /hyperkube kubelet --api-servers=http://${MASTER_IP}:8080 \
   149          --v=2 --address=0.0.0.0 --enable-server \
   150          --hostname-override=$(hostname -i) \
   151          --cluster-dns=10.0.0.10 \
   152          --cluster-domain=cluster.local
   153      
   154      docker run \
   155          -d \
   156          --net=host \
   157          --privileged \
   158          --restart=always \
   159          gcr.io/google_containers/hyperkube:v${K8S_VERSION} \
   160          /hyperkube proxy --master=http://${MASTER_IP}:8080 \
   161          --v=2
   162  }
   163  
   164  echo "Detecting your OS distro ..."
   165  detect_lsb
   166  
   167  echo "Starting bootstrap docker ..."
   168  bootstrap_daemon
   169  
   170  echo "Starting k8s ..."
   171  start_k8s
   172  
   173  echo "Worker done!"