我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在virtualBox搭建一个本地kubernets集群

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在virtualBox搭建一个本地kubernets集群

这篇文章给大家分享的是有关如何在virtualBox搭建一个本地kubernets集群的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

1. 虚拟机准备工作

1.1 下载centos7的镜像

注意centos8不支持kubeadm,血泪教训。也不要下mini会无法使用界面。http://mirrors.aliyun.com/centos/7/isos/x86_64/
安装不要使用最小化安装,不然接下来安装增强功能不方便。

systemctl stop firewalld && systemctl disable firewalld

1.2 关闭sawp内存空间

在安装K8S集群时,Linux的Swap内存交换机制是一定要关闭的,否则会因为内存交换而影响性能以及稳定性。这里,我们可以提前进行设置:

  • 执行swapoff -a可以临时关闭,但系统重启后会恢复

  • 编辑/etc/fstab,注释掉包含swap那一行就可以永久关闭了,可以执行如下命令注释掉该行:

sed -i '/ swap / s/^/#/' /etc/fstab

1.3 关闭 SeLinux

  • 执行setenforce 0可以临时关闭

  • 永久关闭需要修改/etc/sysconfig/selinux的文件设置

sed -i '/SELINUX=e\|SELINUX=p\|SELINUX=d/c\SELINUX=disabled' /etc/sysconfig/selinux

1.4 配置桥接模式

桥接模式相当于假设了一个虚拟网卡,把虚拟机加入宿主机所在的网卡区域,所以界面名称是宿主机的网卡名字。

如何在virtualBox搭建一个本地kubernets集群

可以在网络和internet设置

如何在virtualBox搭建一个本地kubernets集群

然后查看现在正在使用的网卡

如何在virtualBox搭建一个本地kubernets集群

通过关闭网卡发现,实际上是ens8在做网桥,和外界通讯。

其中centos的网卡配置文件目录:cd /etc/sysconfig/network-scripts/,我们需要改的是vi /etc/sysconfig/network-scripts/ifcfg-enp0s8,把下面的内容输入。(经测试无关)

BOOTPROTO="static" IPADDR=192.168.0.50GATEWAY=192.168.0.1DNS1=192.168.0.1DNS2=8.8.8.8NETMASK=255.255.255.0

宿主机可以ping虚拟机,但是虚拟机无法ping宿主机。

如何在virtualBox搭建一个本地kubernets集群

1.5 安装增强功能

参考我上一篇博客: https://www.yisu.com/article/234291.htm

1.6 XSHELL连接SSH

为了防止需要x11,所以需要去vi /etc/sudoers增加一个修改Defaults env_keep="DISPLAY XAUTHORITY"

如何在virtualBox搭建一个本地kubernets集群

如何在virtualBox搭建一个本地kubernets集群

如何在virtualBox搭建一个本地kubernets集群

如何在virtualBox搭建一个本地kubernets集群

2. 安装docker

2.1 卸载旧的docker版本

首先是参考官网的步骤https://docs.docker.com/engine/install/centos/#prerequisites
先卸载旧版本:

sudo yum remove docker \                  docker-client \                  docker-client-latest \                  docker-common \                  docker-latest \                  docker-latest-logrotate \                  docker-logrotate \                  docker-engine

2.2 配置阿里的镜像仓库

sudo yum install -y yum-utilsyum-config-manager \    --add-repo \    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

2.3 安装最新版本的 Docker Engine 和 containerd

这一步可能会遇到问题和podman冲突,podman是redhat用来取代docker的打包工具,因此直接移除就好:

如何在virtualBox搭建一个本地kubernets集群

yum erase podman buildahsudo yum install docker-ce docker-ce-cli containerd.io

4 启动docker并且用helloWord测试,如果成功可以在结果看到提示你正确安装:

sudo systemctl start dockersudo docker run hello-world

设计开启启动,并且测试完移除容器

如何在virtualBox搭建一个本地kubernets集群

systemctl enable docker

2.5 避免和kubelet的冲突

docker info|grep cgroup检视,如果docker使用的Cgroup Driver为cgroupfs。则有可能跟kubelet冲突,需要改为一致的systemd
,先vi /etc/docker/daemon.json,在档案中新增如下程式码,重启docker即可systemctl restart docker

{"exec-opts": ["native.cgroupdriver=systemd"]}

3. 安装kubernetes

我们利用kubernetes官方提供的kubeadm工具来安装kubernetes集群,官方文档可以参考:https://kubernetes.io/docs/setup/production-environment/tools/kubeadm/create-cluster-kubeadm/

3.2 配置kubernetes的yum源

这里使用阿里云的镜像仓库,之前使用过腾讯的镜像仓库,报过404的错误,其实应该是镜像仓库源错误。

Errors during downloading metadata for repository 'kubernetes':
  - Status code: 404 for https://mirrors.cloud.tencent.com/kubernetes/yum/repos/kubernetes-el7-x86_64/repodata/repomd.xml.asc (IP: 120.196.204.237)
  - Status code: 404 for https://mirrors.cloud.tencent.com/kubernetes/yum/doc/yum-key.gpg (IP: 120.196.204.75)
错误:为仓库 'kubernetes' 获取 GPG 密钥失败 : Status code: 404 for https://mirrors.cloud.tencent.com/kubernetes/yum/doc/yum-key.gpg (IP: 120.196.204.75)

还有就是阿里云的仓库参考的博主的也是失败的,最新的找到了这个:

# 配置k8s阿里云源cat <<EOF > /etc/yum.repos.d/kubernetes.repo[kubernetes]name=Kubernetesbaseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/enabled=1gpgcheck=1repo_gpgcheck=1gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpgEOF

安装组件(需要指定版本,我试过最新的版本或者1.18.4镜像仓库都下载失败):

yum install kubectl-1.20.0 kubeadm-1.20.0 kubelet-1.20.0 -y

3.3 启动 kubelet

systemctl enable kubelet && systemctl start kubelet

3.4 设置主机名

然后复制若干份,给每个主机设置名字:

hostnamectl set-hostname k8s-master2

3.5 规划集群网络

注意这里hosts的名字要和上面的主机名一致,不然待会儿建设集群会报错Could not resolve host: mirrors.aliyun.com; 未知的错误

vi /etc/hosts192.168.0.104 k8s-master1192.168.0.105 k8s-master2192.168.0.106 k8s-node1192.168.0.107 k8s-node2

然后给每个节点设置静态IP,不然每次重启都不一样,再重启网络组件,注意我这里的内核版本是centos8.0,所以网络组件不是network,改动的加进去的静态IP部分都是根据我本机电脑的IP得来的。DNS要设置,不然可能会出现之后使用镜像下载失败的问题

vi /etc/sysconfig/network-scripts/ifcfg-enp0s3DNS1=8.8.8.8DNS2=8.8.4.4IPV6_PRIVACY=noOXY_METHOD="none"BROWSER_ONLY="no"############改动部分开始#############动态IP#BOOTPROTO="dhcp"#静态IPBOOTPROTO="static"IPADDR=192.168.0.104NETMASK=255.255.255.0GATEWAY=192.168.0.1DNS1=192.168.0.1############改动部分结束############DEFROUTE="yes"IPV4_FAILURE_FATAL="no"IPV6INIT="yes"IPV6_AUTOCONF="yes"IPV6_DEFROUTE="yes"IPV6_FAILURE_FATAL="no"IPV6_ADDR_GEN_MODE="stable-privacy"NAME="enp0s3"UUID="73ab5a69-9070-4c5a-a0b9-c5a6250af943"DEVICE="enp0s3"ONBOOT="yes"nmcli c reloadnmcli c up enp0s3

此时集群的主机可以互相ping通,但是虚拟机ping主机无法ping通。

依次打开【控制面板】-【Windows Definder防火墙】-【高级设置】-【入站规则】-【按配置文件筛选】-【按公有配置文件筛选】

拉到最下面,找到并启用文件类型为“公用”的“文件和打印共享(回显请求 &ndash; ICMPv4-In)”规则,此时就可以ping通了。

如何在virtualBox搭建一个本地kubernets集群

3.6 初始化一台机器的master节点

验收标准: kubectl get node -n kube-system可以看到输出的结果
安装方式: kubeadm init \ --apiserver-advertise-address=192.168.0.104\ --image-repository registry.aliyuncs.com/google_containers \ --kubernetes-version v1.20.0 \ --service-cidr=10.1.0.0/16 \ --pod-network-cidr=10.244.0.0/16
可以在后面跟上:--ignoer-preflight-errors=all

如何在virtualBox搭建一个本地kubernets集群

安装之前的验证:

  • kubeadm init --dry-run,可以不需要实际部署但是走一遍init的流程,可以看看有没有错误并且看到官方推荐的版本,也可以看到安装之后下一步要做什么,看到会给我们创建CA证书和通过yaml创建etcd等资源,/etc/kubernetes下面可以看到正常的资源。

  • 通过kubeadm config images list --kubernetes-version 1.18.4 --image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers验证资源能不能正常拉下来,注意备注kubernets版本是为了避免从墙外拉。国内镜像地址参考

  1. 选项&ndash;pod-network-cidr=10.244.0.0/16,指定了pod的子网划分地址。因为后面要使用flannel网络插件,所以这里要指定flannel规定的cidr地址。

  2. 选项&ndash;image-repository=“registry.cn-hangzhou.aliyuncs.com/google_containers”,指定了容器镜像的仓库地址。

  3. 选项&ndash;apiserver-advertise-address=192.168.0.12,表示api-server绑定的网卡地址,这里就是当前k8s-master这个节点的IP地址.

或者将配置文件保存下来kubeadm config print init-defaults > kubeadm.conf,方便修改和查看。然后主要也是改images-repository,验证的话kubeadm config images pull --config kubeadm.conf

安装错版本了需要撤销init才能重新部署,此时通过kubeadm reset完成,重置过程不会重置或清除 iptables 规则或 IPVS 表,可以看重置后的提示,不过我们刚刚初始化直接reset就行。

如何在virtualBox搭建一个本地kubernets集群

配置kubeconfig:

To start using your cluster, you need to run the following as a regular user:  mkdir -p $HOME/.kube  sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config  sudo chown $(id -u):$(id -g) $HOME/.kube/configAlternatively, if you are the root user, you can run:  export KUBECONFIG=/etc/kubernetes/admin.conf

3.7 让子节点加入

3.71 加入子节点

只需要在子节点跑下面的命令就行啦,这个是上面init提示的:

kubeadm join k8smaster.com:6443 --token pdas2m.fkgn8q7mz5u96jm6 --discovery-token-ca-cert-hash sha256:6fd9b1bf2d593d2d4f550cd9f1f596865f117fef462db42860228311c2712b8b

如果没有记录可以通过kubeadm token list查看,如果没有输出说明上个token已经过期了,直接生成新的kubeadm token create --print-join-command,默认有效期24小时,若想久一些可以结合&ndash;ttl参数,设为0则用不过期

kubeadm join k8smaster.com:6443 --token pdas2m.fkgn8q7mz5u96jm6 --discovery-token-ca-cert-hash sha256:6fd9b1bf2d593d2d4f550cd9f1f596865f117fef462db42860228311c2712b8b

如果有输出,比如下面,此时发现只有token没有CA:

如何在virtualBox搭建一个本地kubernets集群

还需要解密获得证书:openssl x509 -pubkey -in /etc/kubernetes/pki/ca.crt | openssl rsa -pubin -outform der 2>/dev/null | openssl dgst -sha256 -hex | sed 's/^.* //'
那么结果是6fd9b1bf2d593d2d4f550cd9f1f596865f117fef462db42860228311c2712b8b,也就是-discovery-token-ca-cert-hash sha256:的值。

如果报错:

error execution phase preflight: couldn&rsquo;t validate the identity of the
API Server: could not find a JWS signature in the cluster-info
ConfigMap for token ID “ecqb8f”

是因为令牌过期了,重新生成一个即可

3.72 子节点正确使用kubelet

无法正常使用kubelet get nodes,报错如下:

The connection to the server localhost:8080 was refused - did you
specify the right host or port?

先使用root用户, 发现还是不行。

mkdir $HOME/.kube/cp -i /etc/kubernets/kubelet.conf $HOME/.kube/configchown 1000:1000 $HOME/.kube/config

3.8 配置flannel

# 下载flannel.yamlhttps://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.ymlkubectl apply -f kube-flannel.yml

镜像:quay.io/coreos/flannel:v0.11.0-amd64可能拉取很慢,可以提前下载已导出的镜像包在节点上执行docker load完成镜像导入(.docker)或者docker import(.tar)
flannel起来后,cosedns也会起来

感谢各位的阅读!关于“如何在virtualBox搭建一个本地kubernets集群”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在virtualBox搭建一个本地kubernets集群

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在virtualBox搭建一个本地kubernets集群

这篇文章给大家分享的是有关如何在virtualBox搭建一个本地kubernets集群的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 虚拟机准备工作1.1 下载centos7的镜像注意centos8不支持ku
2023-06-26

如何使用VirtualBox+Ubuntu16搭建Kubernetes集群

小编给大家分享一下如何使用VirtualBox+Ubuntu16搭建Kubernetes集群,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Kubernetes 运
2023-06-15

怎么在docker中搭建一个Hadoop集群环境

这篇文章给大家介绍怎么在docker中搭建一个Hadoop集群环境,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。docker安装1、国际惯例更新下apt软件包的源 curl -fssl https://mirrors.
2023-06-07

怎么在vmware中搭建一个Hadoop集群环境

怎么在vmware中搭建一个Hadoop集群环境?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。先在虚拟机中关闭系统右键虚拟机,点击管理,选择克隆3.点击下一步,
2023-06-14

如何在本地搭建github

随着开源社区的不断发展,GitHub 已经成为了一个非常重要的代码托管平台,它不仅提供了代码托管的功能,还提供了很多简单易用的功能,例如 code review、issue 跟踪、Pull Request 等等。虽然广大开发者可以使用 Gi
2023-10-22

使用SpringCloud如何搭建一个netflix-eureka微服务集群

使用SpringCloud如何搭建一个netflix-eureka微服务集群?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。新建项目选择需要引入的组件,然后下载下
2023-06-14

如何在Windows上搭建一个使用GIT的本地服务器

在软件开发过程中,代码管理是必不可少的环节之一。GIT是一种分布式版本控制系统,已成为当今主流的代码管理工具之一。虽然有很多云端GIT仓库,但是本地搭建GIT服务器仍然是一个非常流行的做法。在这篇文章中,我们将讲解如何在Windows上搭建
2023-10-22

Elasticsearch分布式集群搭建与管理实践(如何构建并管理一个高效的Elasticsearch分布式集群?)

本文详细讲解了构建和管理高效Elasticsearch分布式集群的实践。涵盖了集群架构、硬件和网络、安装和配置、集群管理、性能优化以及最佳实践等方面。遵循文中指导,可以构建一个可靠且满足搜索和分析需求的Elasticsearch集群。
Elasticsearch分布式集群搭建与管理实践(如何构建并管理一个高效的Elasticsearch分布式集群?)
2024-04-02

Git中如何创建一个本地仓库

这篇文章主要介绍了Git中如何创建一个本地仓库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。创建一个新的项目目录,并生成一些简单的文件内容:$ mkdir test_proj
2023-06-16

在CentOS7上如何搭建本地GitLab服务器

本篇内容介绍了“在CentOS7上如何搭建本地GitLab服务器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、安装并配置必要的依赖关系首
2023-06-29

如何在Windows上搭建Git本地服务器

要搭建一个本地服务器以进行代码版本控制和协作开发,Git是一个好的选择。在这篇文章中,我将向你展示如何在Windows上搭建Git本地服务器。步骤一:安装Git首先,你需要下载并安装Git。可以从Git官网上下载安装程序,然后按照安装向导进
2023-10-22

Solr分布式搜索集群的搭建与配置指南(如何构建并配置一个高效的Solr分布式搜索集群?)

本指南详细介绍了如何构建和配置高效的Solr分布式搜索集群。步骤包括规划集群拓扑、安装Solr、配置ZooKeeper、配置SolrCloud、优化性能,并提供故障排除技巧和最佳实践。通过遵循这些步骤,可以创建满足应用程序需求的可靠、可扩展且响应迅速的搜索解决方案。
Solr分布式搜索集群的搭建与配置指南(如何构建并配置一个高效的Solr分布式搜索集群?)
2024-04-02

如何搭建RocketMQ在本地IDEA开发调试环境

今天小编给大家分享一下如何搭建RocketMQ在本地IDEA开发调试环境的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言发
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录