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

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 获取Service的访问地址运行以下命令来获取Service的访问地址:

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


1. 准备环境

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

af58e87e7bff3155d2fd13d977f8e953_0127e7662d404f38a92c3b9b4e146a5f.png


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: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80


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


部署应用

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


apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80


检查部署

运行以下命令来检查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: nginx
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
  type: 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的使用。


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

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2天前
|
Kubernetes 应用服务中间件 调度
如何在Kubernetes集群中配置跨可用区的Pod调度
如何在Kubernetes集群中配置跨可用区的Pod调度
|
10天前
|
弹性计算 运维 应用服务中间件
容器的优势,在Docker中运行Tomcat
摘要:了解Docker与虚拟机的区别:虚拟机使用Hypervisor创建完整操作系统,而容器通过namespace和cgroup实现轻量级隔离,共享主机内核。Docker启动快、资源利用率高,适合快速部署和跨平台移植。但安全性相对较低。示例介绍了如何通过Docker搜索、拉取官方Tomcat镜像并运行容器,最后验证Tomcat服务的正常运行。
|
10天前
|
Kubernetes API 索引
|
12天前
|
Kubernetes Cloud Native 持续交付
云原生架构的核心组成部分通常包括容器化(如Docker)、容器编排(如Kubernetes)、微服务架构、服务网格、持续集成/持续部署(CI/CD)、自动化运维(如Prometheus监控和Grafana可视化)等。
云原生架构的核心组成部分通常包括容器化(如Docker)、容器编排(如Kubernetes)、微服务架构、服务网格、持续集成/持续部署(CI/CD)、自动化运维(如Prometheus监控和Grafana可视化)等。
|
5天前
|
运维 Kubernetes Docker
|
7天前
|
Kubernetes 调度 Docker
|
8天前
|
缓存 Kubernetes Serverless
阿里云云效操作报错合集之AppStack资源池添加外部k8s集群时报错,该如何解决
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
8天前
|
弹性计算 Kubernetes Java
阿里云云效操作报错合集之在绑定其他主体下的k8s集群时,通过kubeconfig导入集群时,出现报错,该如何解决
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
8天前
|
敏捷开发 网络安全 持续交付
阿里云云效产品使用合集之ACK集群中的Pod需要访问公网,该如何实现
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
12天前
|
关系型数据库 应用服务中间件 nginx
容器引擎Docker
带你简单了解docker,开发必备!!!
38 0