文档章节

kubernetes 1.8.7 国内安装(kubeadm)

andylo25
 andylo25
发布于 02/05 01:04
字数 1156
阅读 904
收藏 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
厦门
高级程序员
部署 k8s Cluster(上)- 每天5分钟玩转 Docker 容器技术(118)

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

CloudMAN
01/12
0
0
在阿里云创建Kubernetetes-1.11.0镜像服务(高速)

在阿里云创建Kubernetetes-1.11.0镜像服务(高速) Kubernetetes镜像在国内无法直接访问,导致安装费时、容易出错、难以排查。可以将其抓取到阿里云上面,提前拉取(docker pull)到本地,然...

openthings
07/09
0
0
手工离线部署k8s(v1.9)

手工离线部署k8s(v1.9) 1. 环境准备(采用一个master节点+两个node节点) master 192.168.2.40 node-1 192.168.2.41 node-2 192.168.2.42 绑定hosts 2.将master和node-1、node-2绑定hosts #vi......

yikayi
04/20
0
0
一步步打造专属于自己的Kubernetes-1.8.4集群环境

一 kubernetes kubernetes 以下介绍摘自Wiki Kubernetes (通常称为K8s) 是用于自动部署、扩展和管理容器化(containerized)应用程序的开源系统。Google设计并捐赠给Cloud Native Computing ...

胖宝宝王
2017/12/08
0
0
使用Kubeadm Upgrade更新Kubernetes集群的过程

操作系统用的Ubuntu18.04,装了JupyterHub,启动 Notebook镜像后自动退出。经过排查,发现是因为使用的Notebook镜像不对,后来更新了下,就可以用了。 不过,在此之前,怀疑是Kubernetes版本...

openthings
09/05
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Win10内部更新:警告用户别用chrome和Firefox

简评:别和 Chrome 和 Firefox 约行不,我 Edge 明明更美、屁股更翘、更性感。。。 微软正在测试 Windows 10 的一个更新:警告用户不要安装 Chrome 和 Firefox。是测试人员发现的这个新警告,...

极光推送
31分钟前
2
0
Java并发编程高阶技术 高性能并发框架源码解析与实战

全网唯一深度解析并发编程框架disruptor底层源码课程,助你成为并发编程高手,拿下高薪 网盘地址下载

qq__2304636824
今天
1
0
day92-20180918-英语流利阅读-待学习

健身最大的敌人不是懒惰,而是逞强 Daniel 2018-09-19 1.今日导读 还记得 2008 年北京奥运会运动员刘翔的退赛风波吗?那天几乎所有中国人都将视线聚焦在了鸟巢体育馆 110 米栏的项目上,迫不...

飞鱼说编程
今天
8
0
70.shell的函数 数组 告警系统需求分析

20.16/20.17 shell中的函数 20.18 shell中的数组 20.19 告警系统需求分析 20.16/20.17 shell中的函数: ~1. 函数就是把一段代码整理到了一个小单元中,并给这个小单元起一个名字,当用到这段...

王鑫linux
今天
3
0
分布式框架spring-session实现session一致性使用问题

前言:项目中使用到spring-session来缓存用户信息,保证服务之间session一致性,但是获取session信息为什么不能再服务层获取? 一、spring-session实现session一致性方式 用户每一次请求都会...

WALK_MAN
今天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部