如何使用minikube搭建k8s集群

简介: 如何使用minikube搭建k8s集群

使用minikube搭建K8s(Kubernetes)集群是一个在本地快速设置Kubernetes环境的方法,特别适合用于学习和开发。以下是详细步骤:

一、环境准备
操作系统:如Linux CentOS 7.9 64位。
CPU和内存:至少2核CPU和4GiB内存,建议2核CPU和更多内存以获得更好的性能。
硬盘:至少需要20GB的硬盘空间。
网络:需要网络连接以下载和访问必要的资源。
容器:需要先安装Docker,建议使用较新的稳定版本,如Docker 24.0.4或Docker 20.10.x。
二、安装Docker
移除旧版本的Docker(如果已安装):
bash
sudo yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-engine
配置yum源:
bash
sudo yum install -y yum-utils
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装Docker:
bash
sudo yum install -y docker-ce docker-ce-cli containerd.io
启动Docker:
bash
systemctl enable docker --now
配置Docker加速(可选):
编辑/etc/docker/daemon.json文件,添加以下内容:

json
{
"registry-mirrors": ["https://lkb2w75n.mirror.aliyuncs.com"],
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
},
"storage-driver": "overlay2"
}
然后重新加载Docker配置并重启Docker服务:

bash
sudo systemctl daemon-reload
sudo systemctl restart docker
三、安装Minikube
下载并安装Minikube:
bash
sudo curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64 && sudo install minikube-linux-amd64 /usr/local/bin/minikube
或者下载指定版本的Minikube:

bash
sudo curl -LO https://storage.googleapis.com/minikube/releases/v1.XX.X/minikube-linux-amd64 && sudo install minikube-linux-amd64 /usr/local/bin/minikube
请将v1.XX.X替换为所需的版本号。

验证Minikube安装:
bash
minikube version
四、启动Minikube集群
启动Minikube集群:
bash
minikube start --image-mirror-country='cn' --kubernetes-version=v1.XX.X
请将v1.XX.X替换为所需的Kubernetes版本号。如果需要使用root用户启动,可以添加--force参数:

bash
minikube start --force --image-mirror-country='cn' --kubernetes-version=v1.XX.X
验证集群状态:
bash
minikube status
验证kubectl版本:
由于Minikube内置的kubectl命令功能不全,建议独立安装一个kubectl。可以使用以下命令下载并安装最新版本的kubectl:

bash
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
sudo install -o root -g root -m0755 kubectl /usr/local/bin/kubectl
kubectl version --client --output=yaml
然后验证kubectl是否可以正确连接到Minikube集群:

bash
minikube kubectl version
五、启动Kubernetes Dashboard
启动Dashboard并显示代理地址:
bash
minikube dashboard --url
该URL只能在宿主机内部访问。如果需要在宿主机之外访问,需要设置kubectl proxy代理或其他方式。

设置kubectl proxy代理:
bash
minikube kubectl -- proxy --address='0.0.0.0' --accept-hosts='^*$'&
然后修改ECS防火墙规则,允许入方向的8001端口通行。在宿主机之外的浏览器中访问:http://ECS公网IP:8001/api/v1/namespaces/kubernetes-dashboard/services/http:kubernetes-dashboard:/proxy/。

六、部署应用
创建一个Deployment(例如nginx):
bash
kubectl create deployment test-nginx --image=nginx:1.7.9
查看Deployment和Pod状态:
bash
kubectl get pod,deploy
暴露Service端口:
bash
kubectl expose deploy test-nginx --port=80 --type=NodePort
查看Service状态:
bash
kubectl get svc
在Minikube环境中,可以通过minikube service命令来访问暴露的服务:

[kod.fxs360.com)
[kod.wed921.com)
[kod.zhidianjiaoyu.com)
[kod.zgbzcq.com)
[kod.myhallo.com)
[kod.wuyouliangpin.com)
[kod.tupiangc.com)
bash
minikube service test-nginx
这将会打开一个浏览器窗口并显示服务的地址和端口。

注意事项
在使用Minikube时,如果遇到任何问题,可以参考官方文档或社区提供的解决方案。
Minikube主要用于学习和开发环境,不建议在生产环境中使用。
根据需要调整Minikube的启动参数,如CPU、内存和Kubernetes版本等。
通过以上步骤,您应该能够成功使用Minikube搭建一个本地的Kubernetes集群,并部署和运行容器化的应用程序。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
13天前
|
Kubernetes 监控 Cloud Native
Kubernetes集群的高可用性与伸缩性实践
Kubernetes集群的高可用性与伸缩性实践
46 1
|
2月前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
2月前
|
Kubernetes 持续交付 开发工具
ACK One GitOps:ApplicationSet UI简化多集群GitOps应用管理
ACK One GitOps新发布了多集群应用控制台,支持管理Argo CD ApplicationSet,提升大规模应用和集群的多集群GitOps应用分发管理体验。
|
2月前
|
Kubernetes Ubuntu Linux
Centos7 搭建 kubernetes集群
本文介绍了如何搭建一个三节点的Kubernetes集群,包括一个主节点和两个工作节点。各节点运行CentOS 7系统,最低配置为2核CPU、2GB内存和15GB硬盘。详细步骤包括环境配置、安装Docker、关闭防火墙和SELinux、禁用交换分区、安装kubeadm、kubelet、kubectl,以及初始化Kubernetes集群和安装网络插件Calico或Flannel。
166 4
|
2月前
|
Kubernetes 应用服务中间件 nginx
搭建Kubernetes v1.31.1服务器集群,采用Calico网络技术
在阿里云服务器上部署k8s集群,一、3台k8s服务器,1个Master节点,2个工作节点,采用Calico网络技术。二、部署nginx服务到k8s集群,并验证nginx服务运行状态。
646 1
|
2月前
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
77 3
|
2月前
|
Kubernetes Cloud Native 微服务
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
116 1
|
2月前
|
负载均衡 应用服务中间件 nginx
基于Ubuntu-22.04安装K8s-v1.28.2实验(二)使用kube-vip实现集群VIP访问
基于Ubuntu-22.04安装K8s-v1.28.2实验(二)使用kube-vip实现集群VIP访问
59 1
|
2月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--k8s集群使用容器镜像仓库Harbor
本文介绍了在CentOS 7.9环境下部署Harbor容器镜像仓库,并将其集成到Kubernetes集群的过程。环境中包含一台Master节点和两台Node节点,均已部署好K8s集群。首先详细讲述了在Harbor节点上安装Docker和docker-compose,接着通过下载Harbor离线安装包并配置相关参数完成Harbor的部署。随后介绍了如何通过secret和serviceaccount两种方式让Kubernetes集群使用Harbor作为镜像仓库,包括创建secret、配置节点、上传镜像以及创建Pod等步骤。最后验证了Pod能否成功从Harbor拉取镜像运行。
125 0
|
2月前
|
Kubernetes Cloud Native 云计算
云原生之旅:Kubernetes 集群的搭建与实践
【8月更文挑战第67天】在云原生技术日益成为IT行业焦点的今天,掌握Kubernetes已成为每个软件工程师必备的技能。本文将通过浅显易懂的语言和实际代码示例,引导你从零开始搭建一个Kubernetes集群,并探索其核心概念。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你打开一扇通往云原生世界的大门。
128 17