K8s Docker实践三

单主机创建多个node

在Mac桌面上部署多个Kubernetes节点可以使用Minikube工具。Minikube是一个轻量级的Kubernetes工具,它可以在单个主机上创建一个虚拟集群。以下是在Mac桌面上使用Minikube部署多个Kubernetes节点的步骤:

安装Minikube,运行以下命令:

java 复制代码
# brew install minikube
或
# curl -LO https://github.com/kubernetes/minikube/releases/download/v1.21.0/minikube-darwin-amd64
# sudo install minikube-darwin-amd64 /usr/local/bin/minikube

启动docker desktop后, 启动Minikube集群,运行以下命令:

java 复制代码
# minikube start --node 3

此命令将在你的Mac上创建一个具有3个节点的Kubernetes集群。

如果因为gcr.io/k8s-minikube/kicbase:v0.0.10下载失败导致启动失败,可以

查找替代的镜像,比如anjone/kicbase,指定镜像启动:

java 复制代码
# docker pull anjone/kicbase
# minikube start --base-image="anjone/kicbase" -n 3

验证集群是否正常运行,运行以下命令:

java 复制代码
kubectl get nodes

现在已经在Mac桌面上成功部署了一个具有两个节点的Kubernetes集群,可以使用kubectl命令来管理和操作集群。

指定pod在哪个node上运行

k8s集群的yaml文件,需要指定pod在哪个node上面运行:

通过label-selector机制选择节点

java 复制代码

查询node的label情况命令:

java 复制代码
 kubectl get node --show-labels

为node添加label:

java 复制代码
kubectl label node k8s-node1 type=node1

修改一个Label的值,如果key值相同,需要加上--overwrite参数;key值不同,同上直接添加label即可:

java 复制代码
 kubectl label node nodename type=node2 --overwrite

删除一个Label,只需在命令行最后指定Label的key名并与一个减号相连即可:

java 复制代码
 kubectl label node nodename role- 

参考:https://blog.csdn.net/u010420283/article/details/103928862

相关推荐
J2虾虾7 小时前
Docker启动超时,吓得我一身汗
运维·docker·容器
码农小卡拉7 小时前
Ubuntu22.04 安装 Docker 及 Docker Compose v2 详细教程
ubuntu·docker·容器
EasyNVR9 小时前
docker版EasyNVR如何使用同步插件教程(包含网盘挂载,路径映射等)
docker·容器·音视频
岁岁种桃花儿10 小时前
详解kubectl get replicaset命令及与kubectl get pods的核心区别
运维·nginx·容器·kubernetes·k8s
thulium_10 小时前
Redis Cluster + Docker + --net=host在 WSL2 下是一个“看起来能跑,实际上必失败”的组合
redis·docker
疯子的梦想@13 小时前
记录一次docker+k3s+防火墙规则冲突,导致服务无法正常启动的现象。
docker·容器·eureka
小雨青年15 小时前
环境准备 Windows Mac 下 Docker Desktop 的安装与镜像源加速
windows·macos·docker
倒流时光三十年16 小时前
阿里云 CentOS 7 使用 docker 安装 Nginx
nginx·阿里云·docker·centos
德育处主任Pro16 小时前
『NAS』在绿联部署一个像素风宝可梦同人游戏-pokerogue
游戏·docker·群晖·nas·绿联
skywalk816318 小时前
MiniMax说的FreeBSD系统使用Kubernetes完整指南
云原生·容器·kubernetes·freebsd