k8s单master部署

一、部署

1、初始化

1.1、主机准备

1.2、防火墙与上下文

复制代码
iptables -t nat -F
iptables -t filter -F
systemctl disable --now firewalld

setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config 

1.3、免密登录

复制代码
ssh-keygen

ssh-copy-id 192.168.11.11
ssh-copy-id 192.168.11.12

1.4、hosts文件

复制代码
vim /etc/hosts

192.168.11.10    k8s-master
192.168.11.11    k8s-node1
192.168.11.12    k8s-node2

scp /etc/hosts 192.168.11.11:/etc/
scp /etc/hosts 192.168.11.12:/etc/

1.5、关闭交换空间

复制代码
swapoff -a
sed -i 's/.*swap.*/#&/' /etc/fstab 

2、安装Docker环境

2.1、配置阿里源

复制代码
vim /etc/yum.repos.d/docker-ce.repo

/etc/yum.repos.d/docker-ce.repo
[docker-ce-stable]
name=Docker CE Stable - $basearch
baseurl=https://mirrors.aliyun.com//docker-ce/linux/centos/9/x86_64/stable/
enabled=1
gpgcheck=1
gpgkey=https://mirrors.aliyun.com/docker-ce/linux/centos/gpg

scp /etc/yum.repos.d/docker-ce.repo 192.168.11.11:/etc/yum.repos.d/docker-ce.repo

scp /etc/yum.repos.d/docker-ce.repo 192.168.11.12:/etc/yum.repos.d/docker-ce.repo

2.2、安装并启动

复制代码
yum install -y docker-ce

systemctl enable --now docker

2.3、安装cri-docker

下载地址:https://github.com/Mirantis/cri-dockerd/releases

复制代码
yum localinstall -y cri-dockerd-0.3.8-3.el8.x86_64.rpm

2.4、修改CRI启动脚本

复制代码
vim /usr/lib/systemd/system/cri-docker.service 

ExecStart=/usr/bin/cri-dockerd --container-runtime-endpoint fd:// --pod-infra-container-image=registry.aliyuncs.com/google_containers/pause:3.9


scp /usr/lib/systemd/system/cri-docker.service 192.168.11.11:/usr/lib/systemd/system/cri-docker.service

scp /usr/lib/systemd/system/cri-docker.service 192.168.11.12:/usr/lib/systemd/system/cri-docker.service

2.5、启动cri

复制代码
systemctl daemon-reload
systemctl enable --now cri-docker

3、安装kubeadm和kubectl

3.1、配置yum源

复制代码
cat <<EOF | tee /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes-new/core/stable/v1.28/rpm/
enabled=1
gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes-new/core/stable/v1.28/rpm/repodata/repomd.xml.key
EOF

scp /etc/yum.repos.d/kubernetes.repo 192.168.11.11:/etc/yum.repos.d/kubernetes.repo
scp /etc/yum.repos.d/kubernetes.repo 192.168.11.12:/etc/yum.repos.d/kubernetes.repo

3.2、安装并启动

复制代码
yum install -y kubelet kubeadm kubectl
systemctl enable kubelet && systemctl start kubelet

3.3、内核加载

复制代码
vim /etc/sysctl.conf
net.ipv4.ip_forward = 1
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1

modprobe br_netfilter
sysctl net.bridge.bridge-nf-call-ip6tables=1
sysctl net.bridge.bridge-nf-call-iptables=1

sysctl -p

scp /etc/sysctl.conf 192.168.11.11:/etc/sysctl.conf
scp /etc/sysctl.conf 192.168.11.12:/etc/sysctl.conf      

4、部署各节点

4.1、master节点

复制代码
kubeadm init --apiserver-advertise-address=192.168.11.10 --image-repository=registry.aliyuncs.com/google_containers --kubernetes-version=v1.28.15 --pod-network-cidr=10.244.0.0/16 --service-cidr=10.96.0.0/12 --cri-socket=unix:///var/run/cri-dockerd.sock

4.2、创建集群文件

Go 复制代码
mkdir -p $HOME/.kube
cd /root/.kube
cp /etc/kubernetes/admin.conf ./config

4.3、node节点

复制代码
master证书   --cri-socket=unix:///var/run/cri-dockerd.sock

5、部署网络插件

5.1、导入镜像

将 calico-3.29 tar包导入各节点

复制代码
docker load -i calico.tar

5.2、在master上编辑网络信息

5.3、提交资源清单(master)

Go 复制代码
kubectl create -f tigera-operator.yaml

kubectl create -f custom-resources.yaml

5.4、结果

6、命名

Go 复制代码
kubectl label node k8s-master node-role.kubernetes.io/master=master
kubectl label node k8s-node1 node-role.kubernetes.io/worker=worker
kubectl label node k8s-node2 node-role.kubernetes.io/worker=worker

二、单容器部署lnmp

1、创建镜像文件

1.1 、Dockerfile

1.2、nginx

1.3、php

1.4、mysql

1.5、mysql初始化

1.6、启动脚本

2、生成容器并导为镜像

2.1、生成镜像

2.2、运行容器

复制代码
docker run -itd  -p 80:80  lnmp:v1

2.3、拷贝discuz论坛

复制代码
docker cp /root/lnmp/discuz/ 8b2e:/var/www/html/

2.4、进入容器

复制代码
docker exec -it 8b2e sh

2.5、写测试文件

2.6、更改属性

2.7、测试文件

2.8、导出镜像

2.9、节点导入镜像

3、yaml文件

3.1、编写yaml文件

3.2、命名空间

3.2.1、创建
复制代码
kubectl create namespace lnmp
3.2.2、更改默认
复制代码
kubectl config set-context --current --namespace=lnmp 

3.3、创建pod

复制代码
kubectl create -f lnmp.yaml 

3.4、网络访问

3.5、论坛部署

/discuz/upload/

3.6、查看探针

复制代码
kubectl exec -it dep-lnmp-5c885975b9-6mk55 -- cat /var/log/nginx/discuz_access.log


存活探针一直在检测 info.php文件

相关推荐
码路工人1 分钟前
第10章:K8s 数据持久化
docker·云原生·容器
小闫BI设源码1 小时前
istio集群服务治理
云原生·负载均衡·istio·service服务·ingress路由·网络插件·端口暴露
Achou.Wang1 小时前
Kubernetes 的本质:一个以 API 为中心的“元操作系统”
java·容器·kubernetes
小闫BI设源码1 小时前
istio 部署
云原生·istio·集群架构·api server·kubelet组件·控制器管理器·etcd存储
2501_920047032 小时前
k8s-Service服务
云原生·容器·kubernetes
rggrgerj2 小时前
前后端部署实战:Vue3+Vite+PNPM + NestJS + Docker + Nginx + 云效
nginx·docker·容器
Vahala0623-孔勇3 小时前
服务发现与注册中心设计:从Eureka到Nacos的CAP权衡——AP与CP的边界,藏在服务列表的一致性里
云原生·eureka·服务发现
ayaya_mana3 小时前
Docker常见问题与解决
运维·docker·容器
江湖有缘4 小时前
【Docker项目实战】使用Docker部署Hasty Paste粘贴应用程序
docker·容器·eureka
王家视频教程图书馆4 小时前
关于docker pull不了相关资源
运维·docker·容器