文档章节

kubernetes 1.8.7 国内安装(kubeadm)

andylo25
 andylo25
发布于 2018/02/05 01:04
字数 1156
阅读 1251
收藏 1

kubernetes 1.8.7 国内安装(kubeadm)

kubernetes 简称k8s,简单来说就是一个容器编排部署集群工具,你只要做好一个应用镜像,剩下的什么部署、调度、扩容、缩容,就她来了。换句话说,就是你只要写好应用代码,其他运维的事你就别管了。

1. 国内安装的几个问题

一直没时间看看这个东西,最近越来越火,不得不抽点时间瞜一眼,毕竟容器云的天下,k8s也是占了好大一席。 折腾了几天,安装教程倒不少,只是要么比较老,要么得翻墙,下载速度慢得要命,想顺利的安装一个集群还真不那么简单。 不过也好,久病成良医,填的坑多了生的也变熟了。
国内因为Google相关的网站被墙,所以安装并没官网所说的那样一帆风顺。主要有这么几个问题:

  1. k8s的相关安装包,需要引用国内下载镜像,或者直接下载安装包进行手工安装。
  2. k8s的应用pod docker镜像,国内无法直接下载。需要通过dockerhub中转。

2. 安装前准备

为了解决上面几个问题,需要先做一些准备工作。

  1. 下载安装包:
    Ubuntu安装包可以通过中科大的镜像进行下载,当然也可以直接到我的github下进行下载.
  2. docker镜像准备:
    dockerhub上支持通过Dockerfile进行自动构建,在github上建立对应的Dockerfile,通过dockerhub的创建镜像引用github目录,进行自动构建。可参考我的github,还有douckerhub镜像,dockerhub镜像可以直接使用,一会我们安装的时候就是用的这个镜像。

3. 开始安装

192.138.129.133 k8s-master
192.138.129.134 k8s-node01

1. 安装docker

master上执行:

#!/bin/bash
#SET UP THE REPOSITORY
apt-get remove docker docker-engine docker.io
apt-get update
apt-get install -y -q \
    apt-transport-https \
    ca-certificates \
    curl \
    software-properties-common
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | apt-key add -
add-apt-repository \
   "deb [arch=amd64] https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu \
   $(lsb_release -cs) \
   stable"

#INSTALL DOCKER CE
apt-get install -y -q docker-ce

2. 安装kubernetes

将下载的zip包解压:

unzip k8s_ubuntu_deb.zip

执行安装脚本:

#!/bin/bash
apt-get install -y -q socat ebtables ethtool
dpkg -i kubernetes-cni_0.5.1-00_amd64.deb
dpkg -i kubelet_1.8.7-00_amd64.deb
dpkg -i kubectl_1.8.7-00_amd64.deb
dpkg -i kubeadm_1.8.7-00_amd64.deb
systemctl enable kubelet
systemctl start kubelet

3. 安装前准备

执行脚本:

#!/bin/bash
ufw disable
# 关闭swap,重启后会失效,可加入到启动脚本rc.local里
swapoff -a
cat <<EOF >  /etc/sysctl.d/k8s.conf
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl -p /etc/sysctl.d/k8s.conf
# pull镜像重新标记tag
images=(kube-scheduler-amd64:v1.8.7 \
kube-apiserver-amd64:v1.8.7 \
etcd-amd64:3.0.17 \
pause-amd64:3.0 \
k8s-dns-sidecar-amd64:1.14.5 \
k8s-dns-kube-dns-amd64:1.14.5 \
k8s-dns-dnsmasq-nanny-amd64:1.14.5 \
kubernetes-dashboard-amd64:v1.8.1)
for imageName in ${images[@]} ; do
  docker pull andylo25/$imageName
  docker tag andylo25/$imageName gcr.io/google_containers/$imageName
  docker rmi andylo25/$imageName
done

这里拉取镜像的时候可能会比较慢,可以用docker镜像加速

4. 启动集群

#!/bin/bash
kubeadm init --kubernetes-version=v1.8.7 --pod-network-cidr 10.244.0.0/16
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config
# 安装cni插件flannel
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

初始化正常后会在最后的地方一个加入集群的提示命令:
如下:

kubeadm join --token 34fb5a.87ec418b32857c65 192.168.129.133:6443 --discovery-token-ca-cert-hash sha256:da4765f5721db7ed2130c265a71e849005f0334aeb821cd05ec9c9020e036919

5. 加入集群

在新的节点执行安装docker命令,启动docker,将之前下载的安装包上传到该节点:
将下载的zip包解压:

unzip k8s_ubuntu_deb.zip

然后执行如下脚本:

#!/bin/bash
ufw disable
# 关闭swap,重启后会失效,可加入到启动脚本rc.local里
swapoff -a
cat >> /etc/sysctl.d/k8s.conf <<EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
vm.swappiness=0
EOF
sysctl -p /etc/sysctl.d/k8s.conf
# 安装k8s相关软件
apt-get install -y -q socat ebtables ethtool
dpkg -i kubernetes-cni_0.5.1-00_amd64.deb
dpkg -i kubelet_1.8.7-00_amd64.deb
dpkg -i kubectl_1.8.7-00_amd64.deb
dpkg -i kubeadm_1.8.7-00_amd64.deb
systemctl enable kubelet
systemctl start kubelet
# pull镜像重新标记tag
images=(kube-proxy-amd64:v1.8.7 \
pause-amd64:3.0 \
kubernetes-dashboard-amd64:1.8.1)
for imageName in ${images[@]} ; do
  docker pull andylo25/$imageName
  docker tag andylo25/$imageName gcr.io/google_containers/$imageName
  docker rmi andylo25/$imageName
done
# 执行加入集群命令
kubeadm join --token 34fb5a.87ec418b32857c65 192.168.129.133:6443 --discovery-token-ca-cert-hash sha256:da4765f5721db7ed2130c265a71e849005f0334aeb821cd05ec9c9020e036919

等待一段时间,在master上执行:

kubectl get node
NAME         STATUS    ROLES     AGE       VERSION
k8s-master   Ready     master    8d        v1.8.7
k8s-node01   Ready     <none>    7d        v1.8.7

如果状态一直NotReady,可以重启一下主机,有可能是网络插件安装的时候初始化失败,重启后会自动重新初始化。

6. 安装kubernetes-dashboard

wget https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/recommended/kubernetes-dashboard.yaml
kubectl create -f  kubernetes-dashboard.yaml
# 启动代理
kubectl proxy

通过代理访问dashboard,只能在master上访问:

curl 127.0.0.1:8001/ui

好了,可以通过kubectl执行相关命令来体验k8s的强大了,比如部署应用,自动扩容,灰度发布等等。。。

4.相关附件

我的github之kubernetes

© 著作权归作者所有

共有 人打赏支持
andylo25
粉丝 0
博文 2
码字总数 2894
作品 0
厦门
高级程序员
私信 提问
使用kubeadm一键部署kubernetes集群

使用kubeadm一键部署kubernetes集群 k8s-deploy使用kubeadm一键部署kubernetes集群,让你完美避过各种坑。 特点: 一键部署,避免踩坑 不需要翻墙,不需要设置代理 使用国内的Yum源、Docker镜...

信志
2018/10/06
0
0
使用Kubeadm搭建Kubernetes(1.12.2)集群

Kubeadm是Kubernetes官方提供的用于快速安装Kubernetes集群的工具,伴随Kubernetes每个版本的发布都会同步更新,在2018年将进入GA状态,说明离生产环境中使用的距离越来越近了。 使用Kubeadm...

雨夜朦胧
2018/11/10
0
0
Kubernetes 1.13.1快速升级

Kubernetes 1.13.1已经正式发布,快速升级(含国内镜像快速下载链接)包括升级kubeadm/kubectl/kubelet版本、拉取镜像、升级Kubernetes集群三个主要步骤。注意Kubernetes 1.12.3版本暂时不支...

openthings
2018/12/14
0
0
部署 k8s Cluster(上)- 每天5分钟玩转 Docker 容器技术(118)

我们将部署三个节点的 Kubernetes Cluster。 k8s-master 是 Master,k8s-node1 和 k8s-node2 是 Node。 所有节点的操作系统均为 Ubuntu 16.04,当然其他 Linux 也是可以的。 官方安装文档可以...

CloudMAN
2018/01/12
0
0
Kubernetes 1.12.3快速升级

Kubernetes 1.12.3已经正式发布,快速升级(含国内镜像快速下载链接)包括升级kubeadm/kubectl/kubelet版本、拉取镜像、升级Kubernetes集群三个主要步骤。注意Kubernetes 1.12.3版本暂时不支...

openthings
2018/11/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Cookie 显示用户上次访问的时间

import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServlet;import javax.serv......

gwl_
今天
1
0
网络编程

第14天 网络编程 今日内容介绍  网络通信协议  UDP通信  TCP通信 今日学习目标  能够辨别UDP和TCP协议特点  能够说出UDP协议下两个常用类名称  能够说出TCP协议下两个常用类名称...

stars永恒
今天
1
0
二进制相关

二进制 众所周知计算机使用的是二进制,数字的二进制是如何表示的呢? 实际就是逢二进一。比如 2 用二进制就是 10。那么根据此可以推算出 5的二进制等于 10*10+1 即为 101。 在计算机中,负数以...

NotFound403
昨天
3
0
day22:

1、写一个getinterface.sh 脚本可以接受选项[i,I],完成下面任务: 1)使用格式:getinterface.sh [-i interface | -I ip] 2)当用户使用-i选项时,显示指定网卡的IP地址;当用户使用-I选项...

芬野de博客
昨天
2
0
Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现

自Spring Cloud Alibaba发布第一个Release以来,就备受国内开发者的高度关注。虽然Spring Cloud Alibaba还没能纳入Spring Cloud的主版本管理中,但是凭借阿里中间件团队的背景,还是得到不少...

程序猿DD
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部