k8s_master_install.sh

Posted zhj5551

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了k8s_master_install.sh相关的知识,希望对你有一定的参考价值。

 1 #!/bin/bash
 2 #by zhangjia
 3 #2019年3月30日22:17:14
 4 #k8s_master auto install
 5 ##############################################
 6 set -e
 7 apiserver_id=172.19.81.51
 8 node1_ip=172.19.81.49
 9 #node2_ip=192.168.134.133
10 setenforce 0 && sed -i "s/SELINUX=enforcing/SELINUX=disabled/g" /etc/selinux/config
11 systemctl stop firewalld && systemctl disable firewalld
12 #install ntp_server
13 yum -y install ntp && ntpdate pool.ntp.org || true
14 systemctl start ntpd && systemctl enable ntpd
15 
16 k8s_master() 
17     #network_name=eth0
18     #apiserver_id=`ifconfig $network_name | grep inet |grep netmask | awk print $2`
19     yum install kubernetes etcd flannel -y
20     for i in `ls /etc/kubernetes/`;do cp $i $i.bak ;done
21     #modify /etc/etcd/etcd.conf
22     sed -i "s#ETCD_DATA_DIR=.*#ETCD_DATA_DIR=\"/data/etcd/\"#g" /etc/etcd/etcd.conf
23     sed -i "s#ETCD_NAME=.*#ETCD_NAME=\"etcd_k8s_master\"#g" /etc/etcd/etcd.conf
24     sed -i "s#ETCD_LISTEN_CLIENT_URLS=.*#ETCD_LISTEN_CLIENT_URLS=\"http://0.0.0.0:2379,http://0.0.0.0:4001\"#g" /etc/etcd/etcd.conf
25     sed -i "s#ETCD_ADVERTISE_CLIENT_URLS=.*#ETCD_ADVERTISE_CLIENT_URLS=\"http://0.0.0.0:2379,http://0.0.0.0:4001\"#g" /etc/etcd/etcd.conf
26     [[ ! -d /data/etcd ]] && ( mkdir -p /data/etcd/;chmod 757 -R /data/etcd/ )
27     systemctl restart etcd.service
28 
29     #modify /etc/kubernetes/apiserver
30     sed -i "s#KUBE_API_ADDRESS=.*#KUBE_API_ADDRESS=\"--insecure-bind-address=0.0.0.0\"#g" /etc/kubernetes/apiserver
31     sed -i "/KUBE_API_PORT/ s/#//g" /etc/kubernetes/apiserver
32     sed -i "/KUBELET_PORT/ s/#//g" /etc/kubernetes/apiserver
33     sed -i "s#KUBE_ETCD_SERVERS=.*#KUBE_ETCD_SERVERS=\"--etcd-servers=http://$apiserver_id:2379\"#g" /etc/kubernetes/apiserver
34     sed -i "s#KUBE_ADMISSION_CONTROL=.*#KUBE_ADMISSION_CONTROL=\"--admission-control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ResourceQuota\"#g" /etc/kubernetes/apiserver
35     sed -i s/\ //g /etc/kubernetes/apiserver
36 
37     #modify /etc/kubernetes/config
38     sed -i "s#KUBE_ALLOW.*#KUBE_ALLOW_PRIV=\"--allow-privileged=true\"#g" /etc/kubernetes/config
39     sed -i "s#KUBE_MASTER=.*#KUBE_MASTER=\"--master=http://$apiserver_id:8080\"#g" /etc/kubernetes/config
40     for I in etcd kube-apiserver kube-controller-manager kube-scheduler;do systemctl restart $I;systemctl enable $I;systemctl status $I;done
41     iptables -P FORWARD ACCEPT
42     #modify /etc/sysconfig/flannel
43     sed -i "s#127.0.0.1#$apiserver_id#g" /etc/sysconfig/flanneld
44     #在Master服务器,测试Etcd集群是否正常,同时在Etcd配置中心创建flannel网络配置:
45     etcdctl  member list
46     etcdctl cluster-health
47     etcdctl  rm   /atomic.io/network/   --recursive || true
48     etcdctl  mk  /atomic.io/network/config "Network":"172.17.0.0/16"
49     etcdctl get /atomic.io/network/config
50     etcdctl -C http://$apiserver_id:2379 cluster-health
51     for I in flanneld etcd kube-apiserver kube-controller-manager kube-scheduler;do systemctl restart $I;systemctl enable $I;systemctl status $I;done
52 
53 k8s_node() 
54     uname -r
55     yum -y update
56     yum -y remove docker  docker-common docker-selinux docker-engine
57     yum install -y yum-utils device-mapper-persistent-data lvm2
58     #使用下列命令设置 stable 镜像仓库。您始终需要使用 stable 镜像仓库,即使您还需要通过 edge 或 testing 镜像仓库安装构建也是如此。
59     yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
60     yum list docker-ce --showduplicates | sort -r
61     sudo yum makecache fast
62     #yum -y install docker-ce
63     #network_name=eth0
64     #node1_ip=`ifconfig $network_name | grep inet |grep netmask|awk print $2`
65     yum install kubernetes docker flannel *rhsm* wget -y
66     wget http://mirror.centos.org/centos/7/os/x86_64/Packages/python-rhsm-certificates-1.19.10-1.el7_4.x86_64.rpm
67     rpm2cpio python-rhsm-certificates-1.19.10-1.el7_4.x86_64.rpm | cpio -iv --to-stdout ./etc/rhsm/ca/redhat-uep.pem | tee /etc/rhsm/ca/redhat-uep.pem
68     docker pull registry.access.redhat.com/rhel7/pod-infrastructure:latest
69     #配置文件/etc/kubernetes/kubelet
70     for i in `ls /etc/kubernetes/`;do cp $i $i.bak ;done
71     sed -i "/KUBELET_ADDRESS/ s/127.0.0.1/0\.0\.0\.0/g" /etc/kubernetes/kubelet
72     sed -i "/KUBELET_PORT/ s/#//g" /etc/kubernetes/kubelet 
73     sed -i "s#KUBELET_HOSTNAME.*#KUBELET_HOSTNAME=\"--hostname-override=k8s-node-$node1_ip\"#g" /etc/kubernetes/kubelet
74     sed -i "s#KUBELET_API_SERVER.*#KUBELET_API_SERVER=\"--api-servers=http://$apiserver_id:8080\"#g" /etc/kubernetes/kubelet 
75     sed -i s/\ //g /etc/kubernetes/kubelet
76     #配置文件/etc/kubernetes/config
77     sed -i "/KUBE_ALLOW_PRIV/ s/false/true/g" /etc/kubernetes/config
78     sed -i "s#KUBE_MASTER.*#KUBE_MASTER=\"--master=http://$apiserver_id:8080\"#g" /etc/kubernetes/config
79     #启动 kube-proxy  kubelet  docker
80     for  I  in  kube-proxy  kubelet  docker;do systemctl  restart  $I ;systemctl  enable  $I ;systemctl status $I;done
81     iptables -P FORWARD ACCEPT
82     #k8s_master的/etc/sysconfig/flanneld
83     sed -i "s#FLANNEL_ETCD_ENDPOINTS.*#FLANNEL_ETCD_ENDPOINTS=\"http://$apiserver_id:2379\"#g" /etc/sysconfig/flanneld
84     for  I  in flanneld kube-proxy  kubelet  docker;do systemctl  restart  $I ;systemctl  enable  $I ;systemctl status $I;done
85     #docker load < pod-infrastructure.tgz
86     #docker tag $(docker images|grep none|awk print $3) registry.access.redhat.com/rhel7/pod-infrastructure
87     #docker load < kubernetes-dashboard-amd64.tgz
88     #docker tag $(docker images|grep none|awk print $3) bestwu/kubernetes-dashboard-amd64:v1.6.3
89 
90 
91 #k8s_master
92 #k8s_node

 

以上是关于k8s_master_install.sh的主要内容,如果未能解决你的问题,请参考以下文章