vmvare搭建k8s集群
文章目录
- 虚拟机安装
- 新建虚拟机
- centos安装
- 环境准备
- 子网组建
- 宿主机网卡配置
- 虚拟机网卡配置
- 集群搭建
- 基础配置
- kube相关配置
虚拟机安装
新建虚拟机
自定义安装就用默认空白光盘,然后选自己将用的版本;建议centos,而且得centos7以上,我用的是CentOS-7-x86_64-Minimal-1810.iso
如果上面搜狐镜像的链接失效了,点击进入另一篇博客,选一个就行。
虚拟机名称自定义即可
下面的配置核心、内存、网络、硬盘按要求来,其他默认就可以。
核心数必须大于1,建议4核
内存4G
网络选仅主机
Host-Only模式其实就是NAT模式去除了虚拟NAT设备,然后使用VMware Network Adapter VMnet1虚拟网卡连接VMnet1虚拟交换机来与虚拟机通信的,Host-Only模式将虚拟机与外网隔开,使得虚拟机成为一个独立的系统,只与主机相互通讯。
硬盘至少100G,选择单个文件存储
centos安装
编辑虚拟机设置,选择刚刚下载的镜像
打开虚拟机,不测试直接安装
选择简体中文
所有配置默认就行
设置一下root密码
简单一点的就行,不难容易忘记,我的就是111111
之后等待完成就可以
环境准备
子网组建
宿主机网卡配置
我的win7,VMware Network Adapter VMnet1还无法访问外网,需要将宽带连接共享给VMnet1
这一步我遇到了"无法启用共享访问 错误 0×80004005",开启Windows Firewall服务服务即可解决,操作可见教程
由于共享了宽带连接,VMnet1的ip变为192.168.137.1
需要在VMvare里的虚拟网络编辑器将其子网ip也进行更改。同时取消掉DHCP
虚拟机网卡配置
编辑虚拟机的网卡
vi /etc/sysconfig/network-scripts/ifcfg-ens33
先更改这两个参数
BOOTPROTO=static
ONBOOT=yes
再根据自己的情况添加ip,网关就是VMnet1的ip,同时将其作为DNS1
IPADDR=192.168.137.10
NETMASK=255.255.255.0
GATEWAY=192.168.137.1
DNS1=192.168.137.1
保存退出后重启reboot
检查一下能否连接外网,比如ping www.baidu.com
ssh能否远程连接,比如putty、xshell访问看看
集群搭建
基础配置
以下内容来自B站上的教学视频
- 设置主机名并配置域名映射
hostnamectl set-hostname k8s-master01
接着vim /ets/hosts
192.168.137.10 k8s-master01
192.168.137.20 k8s-node01
192.168.137.21 k8s-node02
- 安装依赖包
yum install -y conntrack ntpdate ntp ipvsadm ipset jq iptables curl sysstat libseccomp wget vim net-tools git
- 关闭防火墙并为iptables设置空规则
systemctl stop firewalld && systemctl disable firewalld
yum -y install iptables-services && \
systemctl start iptables && \
systemctl enable iptables && \
iptables -F && \
service iptables save\
- 关闭SELINUX
先关闭虚拟内存,避免容器运行在虚拟内存上报错
swapoff -a && \
sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab
再关闭SELINUX
setenforce 0 && \
sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config
- 调整内核参数
我这里直接将内容保存到了目标路径,而不是先写到家目录再复制到sysctl.d下
cat > /etc/sysctl.d/kubernetes.conf << EOF
net.bridge.bridge-nf-call-iptables=1
net.bridge.bridge-nf-call-ip6tables=1
net.ipv4.ip_forward=1
net.ipv4.tcp_tw_recycle=0
vm.swappiness=0 # 禁止使用 swap 空间,只有当系统 OOM 时才允许使用它
vm.overcommit_memory=1 # 不检查物理内存是否够用
vm.panic_on_oom=0 # 开启 OOM
fs.inotify.max_user_instances=8192
fs.inotify.max_user_watches=1048576
fs.file-max=52706963
fs.nr_open=52706963
net.ipv6.conf.all.disable_ipv6=1
net.netfilter.nf_conntrack_max=2310720
EOF
刷新一下
sysctl -p /etc/sysctl.d/kubernetes.conf
- 关闭系统不需要服务
邮件服务在这里是不需要的,可以关闭
systemctl stop postfix && systemctl disable postfix
- 设置rsyslogd和systemd journald
mkdir /var/log/journal # 持久化保存日志的目录
mkdir /etc/systemd/journald.conf.d
cat > /etc/systemd/journald.conf.d/99-prophet.conf <<EOF
[Journal]
# 持久化保存到磁盘
Storage=persistent# 压缩历史日志Compress=yes
SyncIntervalSec=5m
RateLimitInterval=30s
RateLimitBurst=1000# 最大占用空间 10G
SystemMaxUse=10G# 单日志文件最大 200M
SystemMaxFileSize=200M# 日志保存时间 2 周
MaxRetentionSec=2week# 不将日志转发到 syslog
ForwardToSyslog=no
EOF
systemctl restart systemd-journald
- 升级内核
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
# 安装完成后检查 /boot/grub2/grub.cfg 中对应内核 menuentry 中是否包含 initrd16 配置,如果没有,再安装一次!yum --enablerepo=elrepo-kernel install -y kernel-lt
# 设置开机内核启动
grub2-set-default 'CentOS Linux (4.4.189-1.el7.elrepo.x86_64) 7 (Core)'
关闭克隆2台,注意是完整克隆
完成克隆后应该有三台机器
单独启动修改node的ip和主机名
kube相关配置
下面的需要在每台机器上都执行
- kube-proxy开启ipvs的前置条件
modprobe br_netfiltercat > /etc/sysconfig/modules/ipvs.modules <<EOF
#!/bin/bash
modprobe -- ip_vs
modprobe -- ip_vs_rr
modprobe -- ip_vs_wrr
modprobe -- ip_vs_sh
modprobe -- nf_conntrack_ipv4
EOFchmod 755 /etc/sysconfig/modules/ipvs.modules && bash /etc/sysconfig/modules/ipvs.modules && lsmod | grep -e ip_vs -e nf_conntrack_ipv4
- 安装并启动docker
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
yum update -y && yum install -y docker-ce
重启,记得选4.4的内核
设置开机自启,并启动docker
systemctl enable docker && systemctl start docker
配置 /etc/docker/daemon.json
cat > /etc/docker/daemon.json << EOF
{"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {"max-size": "100m" }
}
EOFmkdir -p /etc/systemd/system/docker.service.dsystemctl daemon-reload && systemctl restart docker && systemctl enable docker
做完要重启Linux服务器以启用4.4内核
3. 配置kubernetes yum源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
安装kubeadm、kubectl、kubelet
yum -y install kubeadm-1.15.1 kubectl-1.15.1 kubelet-1.15.1systemctl enable kubelet.service
- 初始化主节点
将kubeadm-basic.images放入解压到家目录下,编写一个脚本来导入镜像
cat > load_images.sh << EOF
#!/bin/bash
ls ~/kubeadm-basic.images > /tmp/image-list.txt
cd ~/kubeadm-basic.images
for item in $( cat /tmp/image-list.txt)
dodocker load -i $item
done
rm -rf /tmp/image-list.txt
EOF
觉得脚本导入麻烦也可以docker load *.jar
执行这个脚本
bash ~/load_images.sh
导出初始配置文件:
kubeadm config print init-defaults > kubeadm-config.yaml
修改如下几处
添加的这一段如下
---
apiVersion: kubeproxy.config.k8s.io/v1alpha1
kind: KubeProxyConfiguration
featureGates:SupportIPVSProxyMode: true
mode: ipvs
执行kubeadm初始化集群命令:
kubeadm init --config=kubeadm-config.yaml \
--experimental-upload-certs | tee kubeadm-init.log
- 加入主节点及其余工作节点
这里复制日志中的就行 - 部署网络
mkdir -p install-k8s/core
mv ~/kubeadm-config.yaml kubeadm-init.log ~/install-k8s/coremkdir -p install-k8s/plugin/flannel
cd install-k8s/plugin/flannel
wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
其中的yml文件需要科学上网才能下载,我这里给个百度网盘,最后
链接:https://pan.baidu.com/s/1_7qEpgSwM7JaNovs4E_SEA
提取码:rros
复制这段内容后打开百度网盘手机App,操作更方便哦
kubectl create -f kube-flannel.yml
vmvare搭建k8s集群相关推荐
- 搭建K8s集群(二进制方式)-搭建步骤介绍
使用二进制方式搭建K8S集群 注意 [暂时没有使用二进制方式搭建K8S集群,因此本章节内容不完整... 欢迎小伙伴能补充~] 准备工作 在开始之前,部署Kubernetes集群机器需要满足以下几个条件 ...
- 搭建K8s集群(kubeadm方式)-操作系统初始化
使用kubeadm方式搭建K8S集群 kubeadm是官方社区推出的一个用于快速部署kubernetes集群的工具. 这个工具能通过两条指令完成一个kubernetes集群的部署: # 创建一个 Ma ...
- kubernetes(一)kubeadm搭建k8s集群
使用kubeadm搭建一个k8s集群 1个MasterNode,2个WorkNode 步骤 1.准备3台centos机器 可以使用阿里云,也可以使用virtualbox或者vm MasterNode: ...
- centos8搭建k8s集群
1. 系统初始化 关闭防火墙 systemctl disable firewalld 关闭swap sed -ri 's/.*swap.*/#&/' /etc/fstab 关闭selinux ...
- 纯手工搭建k8s集群-(二)核心模块部署
1. 部署ETCD(主节点) 1.1 简介 kubernetes需要存储很多东西,像它本身的节点信息,组件信息,还有通过kubernetes运行的pod,deployment,service等等.都需 ...
- 【运维开发】Mac OS(10.13.6)使用 vagrant+VirtualBox +centos7搭建k8s集群
Mac OS(10.13.6)使用 vagrant+VirtualBox +centos7搭建k8s集群步骤 环境准备工作 下载VirtualBox 地址:https://www.virtualbox ...
- 从零开始搭建K8S集群(二)-- 搭建K8S集群
一.下面我们开始搭建K8S集群 配置K8S的yum源(自v1.6.0起,Kubernetes默认启用了CRI,Container Runtime Interface,详情请查看官网:https://k ...
- 搭建k8s集群完整流程,云服务器、虚拟机均可参考
一.机器准备 本次搭建k8s集群采用三台云服务器,master节点最好采用2核2G以上的机器,node节点不作要求 二.开始搭建 1.机器 | 角色 | IP | | -- ...
- 【云原生之k8s】kubeadm搭建k8s集群
[云原生之k8s]kubeadm搭建k8s集群 前言 一.集群介绍 (1)集群搭建方法 (2)集群架构 二.集群部署 (1)环境部署 ①所有节点,关闭防火墙规则,关闭selinux,关闭swap交换 ...
最新文章
- png库结合zlib库使用出现的一个链接问题的解决
- HashMap的容量(桶的数量)为什么要是2的n次方
- jmeter强大的扩展插件!!
- 嵌入式C语言自我修养 08:变参函数的格式检查
- 接受你无法改变的事情 改变你可以改变的事情
- 微软社区大课堂 - Transform the Datacenter (数据迁移与Windows Server )社区巡讲- 北京站...
- Kafka设计解析(三):Kafka High Availability (下)
- c语言线性规划建模及求解,C语言大作报告线性规划求解基科3字班.doc
- jmeter-模拟弱网测试
- 软件项目文档及其必要性
- 音创ktv点歌系统服务器,音创ktv点歌系统家庭版
- input 框隐藏光标问题
- 淘宝 阿里 数据库 内核月报—目录索引
- 蓝桥杯java历年真题及答案整理21~40
- pandas parquet文件读取pyarrow、feather文件保存与读取;requests 或wget下载图片文件
- 河南大学计算机学院魏倩,何欣-计算机与信息工程学院官网
- Linux/Centos7搭建饥荒服务器教程
- linux中shell的循环
- 1-Adversarial Learning for Semi-Supervised Semantic Segmentation
- 2020年阴历三月初三 投资理财~为什么永远抄底不到最低点?