阳光下灿烂 發表於 2019-10-9 20:07:00

使用 kubeadm 安装 kubernetes v1.16.0

<p>近日通过kubeadm 安装 kubernetes v1.16.0,踩过不少坑,现记录下安装过程。</p>
<p><strong>安装环境:</strong></p>
<ul>
<li>系&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;统:CentOS Linux release 7.6</li>
<li>Docker版本:18.09.7</li>
<li>所有服务器都能连接外网</li>
</ul>
<h2>一、环境准备</h2>
<p>三台虚拟机信息如下:</p>
<table style="height: 124px; width: 435px" border="1" align="left">
<tbody>
<tr>
<td style="text-align: left"><span style="background-color: rgba(255, 255, 255, 1)"><strong>IP</strong></span></td>
<td><span style="background-color: rgba(255, 255, 255, 1)"><strong>节点角色</strong></span></td>
<td><span style="background-color: rgba(255, 255, 255, 1)"><strong>Hostname</strong></span></td>
</tr>
<tr>
<td>172.21.23.146</td>
<td style="text-align: left">master  </td>
<td>master</td>
</tr>
<tr>
<td>172.21.23.147</td>
<td>worker</td>
<td>node1</td>
</tr>
<tr>
<td>172.21.23.148</td>
<td>worker</td>
<td>node2</td>
</tr>
</tbody>
</table>
<p style="text-align: left">&nbsp;</p>
<h2>&nbsp;</h2>
<h2>&nbsp;</h2>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>在所有节点上进行如下操作:</p>
<p>1、设置主机名</p>
<div class="cnblogs_code">
<pre>hostnamectl <span style="color: rgba(0, 0, 255, 1)">set</span>-<span style="color: rgba(0, 0, 0, 1)">hostname master

echo </span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">127.0.0.1   $(hostname)</span><span style="color: rgba(128, 0, 0, 1)">"</span> &gt;&gt; /etc/hosts</pre>
</div>
<p>设置其他两台worker节点主机名称时,可将 master 替换为正确的主机名node1、node2即可。</p>
<p>2、卸载docker旧版本</p>
<div class="cnblogs_code">
<pre>yum remove -<span style="color: rgba(0, 0, 0, 1)">y docker \
docker</span>-<span style="color: rgba(0, 0, 0, 1)">client \
docker</span>-client-<span style="color: rgba(0, 0, 0, 1)">latest \
docker</span>-<span style="color: rgba(0, 0, 0, 1)">common \
docker</span>-<span style="color: rgba(0, 0, 0, 1)">latest \
docker</span>-latest-<span style="color: rgba(0, 0, 0, 1)">logrotate \
docker</span>-<span style="color: rgba(0, 0, 0, 1)">logrotate \
docker</span>-<span style="color: rgba(0, 0, 0, 1)">selinux \
docker</span>-engine-<span style="color: rgba(0, 0, 0, 1)">selinux \
docker</span>-engine</pre>
</div>
<p>3、设置 yum repository</p>
<div class="cnblogs_code">
<pre>yum install -y yum-<span style="color: rgba(0, 0, 0, 1)">utils \
device</span>-mapper-persistent-<span style="color: rgba(0, 0, 0, 1)">data \
lvm2


yum</span>-config-manager --add-repo http:<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo</span></pre>
</div>
<p>4、安装并启动 docker</p>
<div class="cnblogs_code">
<pre>yum install -y docker-ce-<span style="color: rgba(128, 0, 128, 1)">18.09</span>.<span style="color: rgba(128, 0, 128, 1)">7</span> docker-ce-cli-<span style="color: rgba(128, 0, 128, 1)">18.09</span>.<span style="color: rgba(128, 0, 128, 1)">7</span><span style="color: rgba(0, 0, 0, 1)"> containerd.io
systemctl enable docker
systemctl start docker</span></pre>
</div>
<p>5、安装 nfs-utils</p>
<div class="cnblogs_code">
<pre>yum install -y nfs-utils</pre>
</div>
<p>6、关闭防火墙</p>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 0, 1)">systemctl stop firewalld

systemctl disable firewalld
<br></span></pre>
</div>
<p>7、关闭 SeLinux</p>
<div class="cnblogs_code">
<pre>setenforce <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">

sed </span>-i <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">s/SELINUX=enforcing/SELINUX=disabled/g</span><span style="color: rgba(128, 0, 0, 1)">"</span> /etc/selinux/config</pre>
</div>
<p>8、关闭 swap</p>
<div class="cnblogs_code">
<pre>swapoff -<span style="color: rgba(0, 0, 0, 1)">a

yes </span>| cp /etc/fstab /etc/<span style="color: rgba(0, 0, 0, 1)">fstab_bak

cat </span>/etc/fstab_bak |grep -v swap &gt; /etc/fstab</pre>
</div>
<p>9、配置内核参数</p>
<div class="cnblogs_code">
<pre>echo <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">net.ipv4.ip_forward = 1</span><span style="color: rgba(128, 0, 0, 1)">"</span> &gt;&gt; /etc/<span style="color: rgba(0, 0, 0, 1)">sysctl.conf

echo </span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">net.bridge.bridge-nf-call-ip6tables = 1</span><span style="color: rgba(128, 0, 0, 1)">"</span> &gt;&gt; /etc/<span style="color: rgba(0, 0, 0, 1)">sysctl.conf

echo </span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">net.bridge.bridge-nf-call-iptables = 1</span><span style="color: rgba(128, 0, 0, 1)">"</span> &gt;&gt; /etc/<span style="color: rgba(0, 0, 0, 1)">sysctl.conf<br>
# 执行命令以生效
sysctl </span>-p</pre>
</div>
<p>&nbsp;</p>
<p>10、配置国内Kubernetes源</p>
<div class="cnblogs_code">
<pre>cat &lt;&lt;EOF &gt; /etc/yum.repos.d/<span style="color: rgba(0, 0, 0, 1)">kubernetes.repo

name</span>=<span style="color: rgba(0, 0, 0, 1)">Kubernetes
baseurl</span>=http:<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64</span>
enabled=<span style="color: rgba(128, 0, 128, 1)">1</span><span style="color: rgba(0, 0, 0, 1)">
gpgcheck</span>=<span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">
repo_gpgcheck</span>=<span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">
gpgkey</span>=http:<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg</span>
       http:<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg</span>
EOF</pre>
</div>
<p>11、安装kubelet、kubeadm、kubectl</p>
<div class="cnblogs_code">
<pre>yum install -y kubelet-<span style="color: rgba(128, 0, 128, 1)">1.16</span>.<span style="color: rgba(128, 0, 128, 1)">0</span> kubeadm-<span style="color: rgba(128, 0, 128, 1)">1.16</span>.<span style="color: rgba(128, 0, 128, 1)">0</span> kubectl-<span style="color: rgba(128, 0, 128, 1)">1.16</span>.<span style="color: rgba(128, 0, 128, 1)">0</span></pre>
</div>
<p>12、修改docker Cgroup Driver为systemd</p>
<div class="cnblogs_code">
<pre>sed -i <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">s#^ExecStart=/usr/bin/dockerd.*#ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --exec-opt native.cgroupdriver=systemd#g</span><span style="color: rgba(128, 0, 0, 1)">"</span> /usr/lib/systemd/system/docker.service</pre>
</div>
<p>13、设置 docker 镜像,提高 docker 镜像下载速度和稳定性,&nbsp;如果您访问 https://hub.docker.io 速度非常稳定,亦可以跳过这个步骤</p>
<div class="cnblogs_code">
<pre>curl -sSL https:<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">get.daocloud.io/daotools/set_mirror.sh | sh -s </span><span style="color: rgba(0, 128, 0, 1); text-decoration: underline">http://f1361db2.m.daocloud.io</span></pre>
</div>
<p>14、重启 docker</p>
<div class="cnblogs_code">
<pre>systemctl daemon-<span style="color: rgba(0, 0, 0, 1)">reload

systemctl restart docker</span></pre>
</div>
<p>15、启动 kubelet</p>
<div class="cnblogs_code">
<pre>systemctl enable kubelet &amp;&amp; systemctl start kubelet</pre>
</div>
<p>&nbsp;</p>
<h2>二、制作离线镜像</h2>
<p style="text-align: left">在国内没有ke xue上网的条件下,需要通过国内镜像仓库去拉取镜像。我是先拉取镜像,修改镜像名称,最后安装kubernetes 的。</p>
<p style="text-align: left">拉取镜像:</p>
<div class="cnblogs_code" style="text-align: left">
<pre>docker pull mirrorgooglecontainers/kube-apiserver-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker pull mirrorgooglecontainers</span>/kube-controller-manager-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker pull mirrorgooglecontainers</span>/etcd-amd64:<span style="color: rgba(128, 0, 128, 1)">3.3</span>.<span style="color: rgba(128, 0, 128, 1)">15</span>-<span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">
docker pull mirrorgooglecontainers</span>/kube-scheduler-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker pull mirrorgooglecontainers</span>/kube-proxy-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker pull mirrorgooglecontainers</span>/pause:<span style="color: rgba(128, 0, 128, 1)">3.1</span><span style="color: rgba(0, 0, 0, 1)">
docker pull coredns</span>/coredns:<span style="color: rgba(128, 0, 128, 1)">1.6</span>.<span style="color: rgba(128, 0, 128, 1)">2</span></pre>
</div>
<p style="text-align: left">修改镜像名称:</p>
<div class="cnblogs_code" style="text-align: left">
<pre>docker tag mirrorgooglecontainers/kube-apiserver-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span> k8s.gcr.io/kube-apiserver:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker tag mirrorgooglecontainers</span>/kube-controller-manager-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span> k8s.gcr.io/kube-controller-manager:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker tag mirrorgooglecontainers</span>/kube-scheduler-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span> k8s.gcr.io/kube-scheduler:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker tag mirrorgooglecontainers</span>/kube-proxy-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span> k8s.gcr.io/kube-proxy:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker tag mirrorgooglecontainers</span>/etcd-amd64:<span style="color: rgba(128, 0, 128, 1)">3.3</span>.<span style="color: rgba(128, 0, 128, 1)">15</span>-<span style="color: rgba(128, 0, 128, 1)">0</span> k8s.gcr.io/etcd:<span style="color: rgba(128, 0, 128, 1)">3.3</span>.<span style="color: rgba(128, 0, 128, 1)">15</span>-<span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">
docker tag mirrorgooglecontainers</span>/pause:<span style="color: rgba(128, 0, 128, 1)">3.1</span> k8s.gcr.io/pause:<span style="color: rgba(128, 0, 128, 1)">3.1</span><span style="color: rgba(0, 0, 0, 1)">
docker tag coredns</span>/coredns:<span style="color: rgba(128, 0, 128, 1)">1.6</span>.<span style="color: rgba(128, 0, 128, 1)">2</span> k8s.gcr.io/coredns:<span style="color: rgba(128, 0, 128, 1)">1.6</span>.<span style="color: rgba(128, 0, 128, 1)">2</span></pre>
</div>
<p style="text-align: left">删除重复镜像:</p>
<div class="cnblogs_code" style="text-align: left">
<pre>docker rmi mirrorgooglecontainers/kube-apiserver-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker rmi mirrorgooglecontainers</span>/kube-controller-manager-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker rmi mirrorgooglecontainers</span>/etcd-amd64:<span style="color: rgba(128, 0, 128, 1)">3.3</span>.<span style="color: rgba(128, 0, 128, 1)">15</span>-<span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">
docker rmi mirrorgooglecontainers</span>/kube-scheduler-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker rmi mirrorgooglecontainers</span>/kube-proxy-amd64:v1.<span style="color: rgba(128, 0, 128, 1)">16.0</span><span style="color: rgba(0, 0, 0, 1)">
docker rmi mirrorgooglecontainers</span>/pause:<span style="color: rgba(128, 0, 128, 1)">3.1</span><span style="color: rgba(0, 0, 0, 1)">
docker rmi coredns</span>/coredns:<span style="color: rgba(128, 0, 128, 1)">1.6</span>.<span style="color: rgba(128, 0, 128, 1)">2</span></pre>
</div>
<h2 style="text-align: left">&nbsp;三、部署Master节点</h2>
<p>1、编写了一个给 kubeadm 用的 YAML 文件(名叫:kubeadm.yaml):</p>
<div class="cnblogs_code">
<pre>apiVersion: kubeadm.k8s.io/<span style="color: rgba(0, 0, 0, 1)">v1beta2
kind: ClusterConfiguration
controllerManager:
ExtraArgs:
    horizontal</span>-pod-autoscaler-use-rest-clients: <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">true</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
    horizontal</span>-pod-autoscaler-sync-period: <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">10s</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
    node</span>-monitor-grace-period: <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">10s</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
apiServer:
ExtraArgs:
    runtime</span>-config: <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">api/all=true</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
    kubernetesVersion: </span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">v1.16.0</span><span style="color: rgba(128, 0, 0, 1)">"</span></pre>
</div>
<p>2、执行部署指令:</p>
<div class="cnblogs_code">
<pre>kubeadm init --config kubeadm.yaml</pre>
</div>
<p>&nbsp;就可以完成 Kubernetes Master 的部署了,这个过程只需要几分钟。部署完成后,kubeadm 会生成一行指令:</p>
<div class="cnblogs_code">
<pre>kubeadm join <span style="color: rgba(128, 0, 128, 1)">172.21</span>.<span style="color: rgba(128, 0, 128, 1)">23.146</span>:<span style="color: rgba(128, 0, 128, 1)">6443</span> --<span style="color: rgba(0, 0, 0, 1)">token 9uko4n.jf7d60ijcl35kz7p \
    </span>--discovery-token-ca-cert-hash sha256:c9a97e52ad4704598cbe494d879f940cfc38364ee0acda6e6f98f44d1717230c</pre>
</div>
<p>&nbsp; 这个 kubeadm join 命令,就是用来给这个 Master 节点添加更多工作节点(Worker)的命令。我们在后面部署 Worker 节点的时候马上会用到它,所以找一个地方把这条命令记录下来。</p>
<p><br>此外,kubeadm 还会提示我们第一次使用 Kubernetes 集群所需要的配置命令:</p>
<div class="cnblogs_code">
<pre>mkdir -p $HOME/<span style="color: rgba(0, 0, 0, 1)">.kube
sudo cp </span>-i /etc/kubernetes/admin.conf $HOME/.kube/<span style="color: rgba(0, 0, 0, 1)">config
sudo chown $(id </span>-u):$(id -g) $HOME/.kube/config</pre>
</div>
<p>而需要这些配置命令的原因是:Kubernetes 集群默认需要加密方式访问。所以,这几条命令,就是将刚刚部署生成的 Kubernetes 集群的安全配置文件,保存到当前用户的.kube 目录下,<br>kubectl 默认会使用这个目录下的授权信息访问 Kubernetes 集群。</p>
<p>3、部署网络插件</p>
<div class="cnblogs_code">
<pre>kubectl apply -f <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">https://cloud.weave.works/k8s/net?k8s-version=$(kubectl version | base64 | tr -d '\n')</span><span style="color: rgba(128, 0, 0, 1)">"</span></pre>
</div>
<p>等待大概2-3分钟左右,查看Pod状态</p>
<div class="cnblogs_code">
<pre># kubectl <span style="color: rgba(0, 0, 255, 1)">get</span> pods -n kube-<span style="color: rgba(0, 0, 0, 1)">system
NAME                           READY   STATUS    RESTARTS   AGE
coredns</span>-5644d7b6d9-fxx4g         <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          32m
coredns</span>-5644d7b6d9-k76m7         <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          32m
etcd</span>-master                      <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          31m
kube</span>-apiserver-master            <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          31m
kube</span>-controller-manager-master   <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          30m
kube</span>-proxy-v8d7k               <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          32m
kube</span>-scheduler-master            <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">1</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span><span style="color: rgba(0, 0, 0, 1)">          30m
weave</span>-net-xb6xs                  <span style="color: rgba(128, 0, 128, 1)">1</span>/<span style="color: rgba(128, 0, 128, 1)">2</span>   Running   <span style="color: rgba(128, 0, 128, 1)">0</span>          7m37s</pre>
</div>
<h2>五、部署Worker节点</h2>
<p>1、按照<strong>制作离线镜像</strong>的步骤制作k8s的镜像,这一步很重要,没有K8s的镜像,执行下面的kubeadm join命令后,节点一直是如下状态</p>
<p>&nbsp;</p>
<p>&nbsp;<img src="https://img2018.cnblogs.com/blog/1407275/201910/1407275-20191011172217839-322200534.png"></p>
<p>2、执行部署 Master 节点时生成的 kubeadm join 指令:</p>
<div class="cnblogs_code">
<pre>kubeadm join <span style="color: rgba(128, 0, 128, 1)">172.21</span>.<span style="color: rgba(128, 0, 128, 1)">23.146</span>:<span style="color: rgba(128, 0, 128, 1)">6443</span> --<span style="color: rgba(0, 0, 0, 1)">token 9uko4n.jf7d60ijcl35kz7p \
    </span>--discovery-token-ca-cert-hash sha256:c9a97e52ad4704598cbe494d879f940cfc38364ee0acda6e6f98f44d1717230c</pre>
</div>
<p>&nbsp;3、如果忘记&nbsp;kubeadm join命令,可以在master上执行下面一条指令获取</p>
<div class="cnblogs_code">
<pre>kubeadm token create --print-join-command</pre>
</div>
<p>&nbsp;</p><br><br>
来源:https://www.cnblogs.com/eastonliu/p/11637929.html
頁: [1]
查看完整版本: 使用 kubeadm 安装 kubernetes v1.16.0