当前位置: 首页 > news >正文

如何在本地使用Docker搭建和运行Kubernetes集群

Alt

文章目录

  • 1. 准备环境
  • 2. 安装Minikube
  • 3. 启动Minikube集群
  • 4. 验证集群
  • 5. 部署一个示例应用
    • 创建一个Deployment
    • 部署应用
    • 检查部署
  • 6. 访问应用
    • 创建一个Service
    • 部署Service
    • 获取Service的访问地址
  • 7. 清理资源
  • 结论

🎈个人主页:程序员 小侯
🎐CSDN新晋作者
🎉欢迎 👍点赞✍评论⭐收藏
✨收录专栏:云计算
✨文章内容:
🤝希望作者的文章能对你有所帮助,有不足的地方请在评论区留言指正,大家一起学习交流!🤗

在本文中,我们将探讨如何在本地环境中使用Docker运行Kubernetes(通常称为K8s)集群。本地运行Kubernetes可以为开发、测试和学习提供便利,同时避免了与云提供商的互动。我们将分步骤介绍如何设置和运行本地Kubernetes集群,并穿插一些关键代码示例。

1. 准备环境

首先,确保您的系统上已经安装了Docker。如果您尚未安装Docker,可以根据您的操作系统下载并安装Docker Desktop(对于Windows和macOS用户)或Docker CE(对于Linux用户)。
在这里插入图片描述

2. 安装Minikube

Minikube是一个用于在本地运行Kubernetes集群的工具。它是一个轻量级的Kubernetes发行版,适用于本地开发和测试。

使用以下命令安装Minikube:

curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
chmod +x minikube
sudo mv minikube /usr/local/bin/

3. 启动Minikube集群

一旦安装了Minikube,您可以使用以下命令启动本地Kubernetes集群:

minikube start

Minikube将在Docker中创建一个虚拟机,然后在该虚拟机中启动Kubernetes集群。

4. 验证集群

您可以运行以下命令来验证Minikube集群的状态:

kubectl cluster-info

您应该看到类似以下内容的输出:

Kubernetes control plane is running at https://192.168.49.2:8443
KubeDNS is running at https://192.168.49.2:8443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy

这表明您的本地Kubernetes集群已成功启动。

5. 部署一个示例应用

让我们通过部署一个简单的示例应用程序来进一步了解如何在Minikube上运行Kubernetes。

创建一个Deployment

创建一个名为nginx-deployment.yaml的文件,并将以下内容添加到文件中:

apiVersion: apps/v1
kind: Deployment
metadata:name: nginx-deployment
spec:replicas: 2selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:latestports:- containerPort: 80

此配置定义了一个名为nginx-deployment的Deployment,将运行两个Nginx容器。

部署应用

运行以下命令来部署Nginx应用程序:

kubectl apply -f nginx-deployment.yaml

检查部署

运行以下命令来检查Deployment的状态:

kubectl get deployments

您应该看到nginx-deployment的副本数为2。

6. 访问应用

要访问部署的Nginx应用程序,您需要创建一个Service以公开应用程序。

创建一个Service

创建一个名为nginx-service.yaml的文件,并将以下内容添加到文件中:

apiVersion: v1
kind: Service
metadata:name: nginx-service
spec:selector:app: nginxports:- protocol: TCPport: 80targetPort: 80type: NodePort

部署Service

运行以下命令来部署Service:

kubectl apply -f nginx-service.yaml

获取Service的访问地址

运行以下命令来获取Service的访问地址:

minikube service nginx-service --url

您将获得一个URL,可在浏览器中访问Nginx应用程序。

7. 清理资源

当您完成测试后,可以使用以下命令来清理Minikube集群和相关资源:

minikube delete

这将删除Minikube虚拟机以及关联的Kubernetes集群。

结论

通过这个示例,您学会了如何在本地环境中使用Docker和Minikube运行Kubernetes集群,并部署了一个简单的Nginx应用程序。本地运行Kubernetes对于开发、测试和学习Kubernetes非常有用,可以帮助您更好地理解和熟悉Kubernetes的功能和操作。希望这篇文章能帮助您入门本地Kubernetes的使用。

后记 👉👉💕💕美好的一天,到此结束,下次继续努力!欲知后续,请看下回分解,写作不易,感谢大家的支持!! 🌹🌹🌹

http://www.lryc.cn/news/164641.html

相关文章:

  • 每天几道Java面试题(第二天)
  • Java | 线程的生命周期和安全
  • Bootstrap的一些主要作用
  • 网络编程套接字 | UDP套接字
  • 网络层IP协议
  • C++ Day4
  • 2024字节跳动校招面试真题汇总及其解答(二)
  • SpringBoot集成websocket(4)|(使用okhttp3实现websocket)
  • 【MySQL】JDBC编程
  • 数据结构——二叉树线索化遍历(前中后序遍历)
  • GO语言网络编程(并发编程)Channel
  • c++day3
  • 算法通过村第六关-树青铜笔记|中序后序
  • C++动态内存管理+模板
  • SQL 注入漏洞攻击
  • 一篇五分生信临床模型预测文章代码复现——Figure 10.机制及肿瘤免疫浸润(四)
  • Transformer 模型中常见的特殊符号
  • C# halcon SubImage的使用
  • 每天几道Java面试题:异常机制(第三天)
  • Linux 中的 chattr 命令及示例
  • LeetCode 2605. Form Smallest Number From Two Digit Arrays【数组,哈希表,枚举;位运算】1241
  • VoxWeekly|The Sandbox 生态周报|20230904
  • antd setFieldsValue 设置初始值无效AutoComplete 设置默认值失败
  • 01-Redis核心数据结构与高性能原理
  • 预防Dos攻击
  • ant design的文档真的是一坨屎
  • 关于迁移学习的一点理解
  • 【力扣周赛】第 361 场周赛(⭐前缀和+哈希表 树上倍增、LCA⭐)
  • 解决 Android 依赖冲突
  • 前端设计模式基础笔记