CentOS7上搭建Kubernetes(K8S)集群并部署nginx(kubeadm方式)

简介: CentOS7上搭建Kubernetes(K8S)集群并部署nginx(kubeadm方式)

前提条件

服务器配置

可以具体查看拓扑图

三台服务器搭建完成:

同时需要保证三台虚拟机网络能够互通

其他要求

需要三台服务器能连接外网!!!因为要下载依赖

准备工作

开始前你得完成以下准备工作

关闭各个机器的防火墙

systemctl stop firewalld
systemctl disable firewalld

关闭SELinux

# 永久关闭
sed -i 's/enforcing/disabled/' /etc/selinux/config
# 临时关闭
setenforce 0

关闭Swap

# 永久关闭
vim /etc/fstab
# 临时关闭
swapoff -a

永久关闭的时候需要注释这一行:

设置主机名

分别在几台服务器上执行以下命令,需要注意的是每台主机上不一样!

  • 192.168.10.112:hostnamectl set-hostname k8s-master
  • 192.168.10.114:hostnamectl set-hostname k8s-node1
  • 192.168.10.116:hostnamectl set-hostname k8s-node2
    设置完成后:

修改hosts文件

cat >> /etc/hosts << EOF
192.168.10.112 k8s-master
192.168.10.114 k8s-node1
192.168.10.116 k8s-node2
EOF

将桥接的 IPv4 流量传递到 iptables

cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1

使其生效

sysctl --system

同步时间

yum install ntpdate -y
ntpdate time.windows.com

开始安装Kubernetes

安装docker

每台电脑都需要安装docker,可执行一下脚本:

#!/bin/bash
sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine
sudo yum install -y yum-utils
sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install -y docker-ce docker-ce-cli containerd.io
sudo systemctl start docker
sudo systemctl enable docker

以上脚本执行完之后docker就安装好了

docker的阿里云加速配置

来到地址:https://cr.console.aliyun.com/cn-shenzhen/instances/mirrors,复制以下代码:

然后在中括号下面加上一行代码:

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

添加完成后:

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://xxxxx.mirror.aliyuncs.com"],
  "exec-opts": ["native.cgroupdriver=systemd"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

添加K8S的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

安装 kubelet、kubeadm 和 kubectl

使用以下命令通过yum安装

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

启动master

查看版本如图:

然后执行命令启动:

kubeadm init \
--apiserver-advertise-address=192.168.10.112 \
--image-repository registry.aliyuncs.com/google_containers \
--kubernetes-version v1.23.4 \
--service-cidr=10.96.0.0/12 \
--pod-network-cidr=10.244.0.0/16

注意 --apiserver-advertise-address=192.168.10.114 后面的IP地址需要改成自己mater的IP,然后 --kubernetes-version v1.23.4 的版本注意改成自己K8S的版本

获取启动信息

查看启动成功的信息

本机执行这些命令(以上面截图的为准):

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

启动两个Slave

还记得上面需要记录下来的命令吗,就是这行:

kubeadm join 192.168.10.112:6443 --token ib1gcv.ggho8b3nz3i60usm \
        --discovery-token-ca-cert-hash sha256:beb328d9fbadfe79e7599d8be74527f4dbde7c4278cc0a791e0bcc641bfca30d

执行它,查看结果

然后我们在master中执行这一行命令

kubectl get nodes

查看结果:

可以看到两个node成功注册,但是没能达到准备状态,因为 STATUS 任然是 NotReady 状态,我们需要为 master 安装网络插件:

kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

看到这个代表安装成功(如果没有安装成功,那么需要将问价下载下来,然后将url替换成下载下来的文件):

但是还需要等一下,因为他正在联网下载依赖呢,然后再次查看,就变为 Ready 状态了:

运行nginx容器

拉去一个镜像:

kubectl create deployment nginx --image=nginx

运行它:

kubectl expose deployment nginx --port=80 --type=NodePort

查看运行状态:

kubectl get pod,svc

在这个端口,任何一个node节点的IP都可以访问(192.168.10.114或192.168.10.116):

访问查看是否成功:

好了,安装完成!

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2月前
|
存储 Kubernetes Docker
Kubernetes(k8s)和Docker Compose本质区别
理解它们的区别和各自的优势,有助于选择合适的工具来满足特定的项目需求。
232 19
|
2月前
|
Kubernetes 应用服务中间件 nginx
二进制安装Kubernetes(k8s)v1.32.0
本指南提供了一个详细的步骤,用于在Linux系统上通过二进制文件安装Kubernetes(k8s)v1.32.0,支持IPv4+IPv6双栈。具体步骤包括环境准备、系统配置、组件安装和配置等。
686 10
|
2月前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
4月前
|
监控 应用服务中间件 网络安全
部署Django应用:使用Gunicorn和Nginx构建高效的生产环境
部署Django应用:使用Gunicorn和Nginx构建高效的生产环境
277 0
|
4月前
|
Kubernetes Ubuntu Linux
Centos7 搭建 kubernetes集群
本文介绍了如何搭建一个三节点的Kubernetes集群,包括一个主节点和两个工作节点。各节点运行CentOS 7系统,最低配置为2核CPU、2GB内存和15GB硬盘。详细步骤包括环境配置、安装Docker、关闭防火墙和SELinux、禁用交换分区、安装kubeadm、kubelet、kubectl,以及初始化Kubernetes集群和安装网络插件Calico或Flannel。
309 4
|
4月前
|
Kubernetes API 调度
中间层 k8s(Kubernetes) 到底是什么,架构是怎么样的?
中间层 k8s(Kubernetes) 到底是什么,架构是怎么样的?
83 3
|
4月前
|
Kubernetes Linux 开发工具
centos7通过kubeadm安装k8s 1.27.1版本
centos7通过kubeadm安装k8s 1.27.1版本
|
Kubernetes 容器
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(五)
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(五)
172 0
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(五)
|
Kubernetes 容器
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(四)
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(四)
145 0
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(四)
|
Kubernetes 应用服务中间件 API
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(二)
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(二)
165 0
KUBERNETES03_k8s对象是什么、如何管理、命名空间、代码自动补全提示(二)