K8S-1.15.1版本部署

K8S-1.15.1版本部署

准备好几台机器,最好准备至少2台机器
这里准备了3台机器,一台做master,2台做node
1.机器基本设置
1.1 设置主机名

hostnamectl set-hostname master  #在master机器上执行
hostnamectl set-hostname node1   #在node1机器上执行
hostnamectl set-hostname node2   #在node2机器上执行

1.2 设置三台机器时区,保证后续事件准确,如果每台机器的时间不一样,后续出现很多莫名其妙的问题

timedatectl set-timezone Asia/Shanghai   #在三台上都执行

1.3 添加主机至hosts文件

vim /etc/hosts  #三台机器都执行
#在打开的文件添加三行内容,内容为机器ip+名称,本文直接以master+node命名,实际可按照需求更改
#192.168.1.181 matser
#192.168.1.182 node1
#192.168.1.183 node2

1.4 关闭swap分区,很重要,swap分区不关闭,会直接导致部署失败,三台全部需要执行

swapoff -a  
vim /etc/fstab  #将swap所在行注释掉

1.5 修改iptables信息

 echo 1 > /proc/sys/net/bridge/bridge-nf-call-iptables
 echo 1 > /proc/sys/net/bridge/bridge-nf-call-ip6tables

1.6 关闭所有节点的seliux以及firewalld

sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
setenforce 0 
systemctl disable firewalld
systemctl stop firewalld

2.安装docker

yum install docker -y   #或者使用yum install -y docker-ce安装docker-ce版本也可
systemctl start docker && systemctl enable docker

查看docker cgroup

docker info
1
docker与K8S两者必须要保持一致,否则会报错,本文统一使用cgroup
在这里插入图片描述
如果查看到的cgroup不为cgroupfs,需要修改

vim /usr/lib/systemd/system/docker.service

在这里插入图片描述
修改完成后重载配置,重启docker

systemctl daemon-reload && systemctl restart docker

3.安装kubeadm
3.1 配置yum文件,使用国内源,三台均执行

cat << EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
EOF

3.2 安装kubeadm,三台均执行

yum -y install kubeadm-1.15.1 kubectl-1.15.1 kubelet-1.15.1
systemctl enable kubelet

3.3 导入本地镜像,避免初始化一直卡在下载镜像步骤
镜像下载地址:(包括flannel文件)后面可能wget不到

链接:https://pan.baidu.com/s/12HmZ08IKP7ptHOw1BEuzkg
提取码:0a2q
复制这段内容后打开百度网盘手机App,操作更方便哦

本文将文件均放置在/home/k8s目录下

cd /home/k8s
tar xf kubeadm-basic.images.tar.gz

可以手动进入解压的文件夹一个一个导入镜像,也可以使用脚本

cd /home/k8s
vim loadimages.sh
#脚本内容
#!/bin/bash
ls /home/k8s/kubeadm-basic.images > /root/docker-load-list.txt
cd /home/k8s/kubeadm-basic.images
for i in $(cat /root/docker-load-list.txt)
do
docker load -i $i
done
rm -f /root/docker-load-list.txt
# 保存退出脚本
sh loadimages.sh  #执行脚本

3.4 初始化master节点,此步只在master节点上执行
导出kubeadm-config.yaml配置文件

kubeadm config print init-defaults > /etc/kubernetes/kubeadm-config.yaml

编辑kubeadm-config.yaml文件

vim /etc/kubernetes/kubeadm-config.yaml
第12行:advertiseAddress:[master ip]34行:kubernetesVersion: v1.15.136行下增加:podSubnet: "10.244.0.0/16" #pod网段

执行初始化

kubeadm init --config=/etc/kubernetes/kubeadm-config.yaml --experimental-upload-certs | tee kubeadm-init.log


初始化成功后,执行提示命令

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

3.5 安装flannel,此步只在master接上执行

wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
## wget报错的话就把百度网盘中的flannel文件导入
kubectl create -f kube-flannel.yml

3.6 使用初始化成功生成的命令,复制到node机器上执行,将node机器添加到master机器
在这里插入图片描述
tab快捷键安装

yum -y  install bash-completion && source /usr/share/bash-completion/bash_completion && source <(kubectl completion bash) && echo "source <(kubectl completion bash)" >> ~/.bashrc
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101898.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • php header 404写法 php header函数用法

    php header 404写法 php header函数用法header("HTTP/1.1404NotFound");exit;

    2022年7月1日
    22
  • drupal教程 Drupal安装指南

    drupal教程 Drupal安装指南译者:老葛从开始学习Drupal到现在,安装的都是5.1,5.2的版本,由于使用的是wdp开发工具,所以安装基本上不需要做什么的,大概都是建立数据库名,修改一下settings.php配置文件,在浏览器里面敲入install.php,就可以自动完成安装了。所以说,drupal的安装是极其简单的,而且很容易上手。  但是由于客户的要求,需要使用drupal4.7的版本,由于用过5.1+的版

    2022年5月2日
    42
  • 【Qt】Qt的线程(两种QThread类的详细使用方式)「建议收藏」

    【Qt】Qt的线程(两种QThread类的详细使用方式)「建议收藏」Qt提供QThread类以进行多任务处理。与多任务处理一样,Qt提供的线程可以做到单个线程做不到的事情。例如,网络应用程序中,可以使用线程处理多种连接器。QThread继承自QObject类,且提供QMutex类以实现同步。线程和进程共享全局变量,可以使用互斥体对改变后的全局变量值实现同步。因此,必须编辑全局数据时,使用互斥体实现同步,其它进程则不能改变或浏览全局变量值。什么是互斥体?…

    2022年5月28日
    207
  • 常见的MIME类型

    常见的MIME类型

    2021年9月20日
    75
  • 苹果电脑(Mac mini或Macbook或iMac)恢复出厂设置「建议收藏」

    苹果电脑(Mac mini或Macbook或iMac)恢复出厂设置「建议收藏」苹果电脑(Macmini或Macbook或iMac)恢复出厂设置,首先要做好如下的准备:第一:数据的备份;第二:保证正常的wifi连接;第三:有线的鼠标键盘连接;具体恢复操作步骤:步骤一:电脑启动时,按下键盘组合键(option+command+R,或alt+command+R);然后显示器屏幕上会显示小地球,且出现倒计时;步骤二:倒计时结束后,出现macOS实用工具,选择第四个…

    2022年6月16日
    572
  • java scanner怎么用_Java中Scanner类的用法及使用步骤分享!「建议收藏」

    java scanner怎么用_Java中Scanner类的用法及使用步骤分享!「建议收藏」Scanner是Java中的一个新特征,Java程序员可以通过Scanner类来获取用户的输入,帮助程序员接收从键盘输入的数据,对于程序员而言非常有帮助。当程序需要从键盘获取用户输入的命令或数据时,例如:获取用户输入的计算表达式。可以通过Scanner类方便地获取用户输入。通过Scanner类获取用户输入时,控制台会一直等待用户的输入,直到用户敲回车键结束,把所输入的内容传给Scanner,程序要…

    2022年7月7日
    23

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号