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

k8s入门:从安装到实际应用

Kubernetes (K8s) 入门指南:从安装到实际应用

Kubernetes 是一个开源的容器编排平台,用于自动化容器化应用程序的部署、扩展和管理。它能帮助你管理多个容器化应用程序,并确保它们在不同环境下的一致性和可用性。本文将介绍如何在本地环境安装 Kubernetes 并进行简单的应用部署。

一、安装 Kubernetes

Kubernetes 的安装可以通过多种方式完成,以下是几种常见的安装方法:

1. 使用 Minikube 安装 Kubernetes

Minikube 是一个工具,可以在本地运行单节点 Kubernetes 集群,适合开发和测试使用。

步骤:

  1. 安装 Minikube:

    • 在 Linux 上:

      curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
      sudo install minikube /usr/local/bin/
      
    • 在 macOS 上:

      brew install minikube
      
    • 在 Windows 上:

      下载 Minikube 并将其添加到系统路径。

  2. 安装 kubectl:

    kubectl 是 Kubernetes 的命令行工具,用于管理 Kubernetes 集群。

    • 在 Linux 上:

      curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl"
      chmod +x ./kubectl
      sudo mv ./kubectl /usr/local/bin/kubectl
      
    • 在 macOS 上:

      brew install kubectl
      
    • 在 Windows 上:

      下载 kubectl 并将其添加到系统路径。

  3. 启动 Minikube:

 #安装相关依赖yum install -y conntrack git wget golangVERSION="v1.30.0"wget https://github.com/kubernetes-sigs/cri-tools/releases/download/$VERSION/crictl-$VERSION-linux-amd64.tar.gztar zxvf crictl-$VERSION-linux-amd64.tar.gz -C /usr/local/bingit clone https://github.com/Mirantis/cri-dockerd.gitcd cri-dockerdmkdir bingo get && go build -o bin/cri-dockerdmv bin/cri-dockerd /usr/local/bin/wget https://raw.githubusercontent.com/Mirantis/cri-dockerd/master/packaging/systemd/cri-docker.service -O /etc/systemd/system/cri-docker.servicewget https://raw.githubusercontent.com/Mirantis/cri-dockerd/master/packaging/systemd/cri-docker.socket -O /etc/systemd/system/cri-docker.socketsudo systemctl daemon-reloadsudo systemctl enable cri-docker.servicesudo systemctl enable cri-docker.socketsudo systemctl start cri-docker.servicesudo systemctl start cri-docker.socket
#启动minikube
minikube start
  1. 验证安装:

    kubectl get nodes
    

    如果安装成功,你应该会看到一个名为 minikube 的节点。

2. 使用 Kind 安装 Kubernetes

Kind (Kubernetes IN Docker) 是另一个适合本地开发的 Kubernetes 集群工具,通过 Docker 容器运行 Kubernetes 集群。

步骤:

  1. 安装 Kind:

    • 在 Linux 和 macOS 上:

      curl -Lo ./kind https://kind.sigs.k8s.io/dl/latest/kind-linux-amd64
      chmod +x ./kind
      sudo mv ./kind /usr/local/bin/kind
      
    • 在 Windows 上:

      下载 Kind 并将其添加到系统路径。

  2. 创建 Kubernetes 集群:

    kind create cluster
    
  3. 验证安装:

    kubectl cluster-info --context kind-kind
    
二、部署应用到 Kubernetes

一旦 Kubernetes 集群启动并运行,你可以开始部署应用程序。以下是一个简单的 Nginx 应用部署示例:

  1. 创建 Nginx Deployment:

    Deployment 用于声明应用的期望状态,Kubernetes 将确保实际状态匹配声明的期望状态。

    kubectl create deployment nginx --image=nginx
    
  2. 暴露 Nginx 服务:

    Service 用于将 Deployment 暴露为一个网络服务。

    kubectl expose deployment nginx --port=80 --type=NodePort
    
  3. 查看服务信息:

    kubectl get services
    

    你将看到类似以下的输出,其中 PORT(S) 显示了服务暴露的端口:

    NAME         TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)        AGE
    nginx        NodePort    10.96.0.1      <none>        80:PORT/TCP    1m
    
  4. 访问 Nginx 应用:

    在浏览器中访问 http://<Node_IP>:<PORT>,其中 <Node_IP> 是集群节点的 IP 地址,<PORT> 是上一步中显示的端口。

三、管理 Kubernetes 应用

Kubernetes 提供了丰富的功能来管理和扩展你的应用程序:

  1. 扩展 Deployment:

    可以使用以下命令扩展 Nginx 部署的副本数:

    kubectl scale deployment nginx --replicas=3
    
  2. 更新 Deployment:

    可以使用以下命令滚动更新 Nginx 部署:

    kubectl set image deployment/nginx nginx=nginx:latest
    
  3. 查看 Deployment 状态:

    使用以下命令查看 Deployment 的状态:

    kubectl get deployments
    
  4. 查看 Pod 日志:

    使用以下命令查看 Pod 的日志:

    kubectl logs <pod_name>
    
四、常见的 Kubernetes 资源类型
  • Pod:Kubernetes 中最小的部署单元,包含一个或多个容器。
  • Service:用于定义 Pod 的网络访问策略。
  • Deployment:用于声明应用的期望状态,支持滚动更新和回滚。
  • ConfigMap 和 Secret:用于管理应用配置和敏感信息。
  • PersistentVolume (PV) 和 PersistentVolumeClaim (PVC):用于管理持久存储。

总结

本文介绍了如何在本地安装 Kubernetes 并部署一个简单的 Nginx 应用。Kubernetes 是一个功能强大的平台,提供了丰富的功能来管理和扩展容器化应用程序。通过掌握本文介绍的基本概念和操作,你可以开始探索 Kubernetes 的更多高级功能,以满足实际应用的需求。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【Linux杂货铺】期末总结篇3:用户账户管理命令 | 组账户管理命令
  • redis-缓存三剑客
  • FreeRTOS的中断管理、临界资源保护、任务调度
  • 2024CAIP省赛
  • 【吊打面试官系列-ZooKeeper面试题】简述 Zookeeper 文件系统?
  • 安全运营概述
  • 【学习】美国虚拟信用卡申请流程
  • 【解决】多个网卡导致nacos注册的服务ip有误问题
  • Java-排序~查找算法
  • Qt会议室项目
  • 景区导航导览系统:基于AR技术+VR技术的功能效益全面解析
  • RocketMQ实现分布式事务
  • vst 算法R语言手工实现 | Seurat 筛选高变基因的算法
  • 优化Python爬虫:多线程助力数据采集高速通道
  • vue仿甘特图开发工程施工进度表
  • 《网管员必读——网络组建》(第2版)电子课件下载
  • 【编码】-360实习笔试编程题(二)-2016.03.29
  • angular2开源库收集
  • eclipse(luna)创建web工程
  • eclipse的离线汉化
  • HTML5新特性总结
  • JavaScript中的对象个人分享
  • java第三方包学习之lombok
  • java取消线程实例
  • jdbc就是这么简单
  • Linux Process Manage
  • MySQL QA
  • Spring Cloud Feign的两种使用姿势
  • SQLServer之创建显式事务
  • 对JS继承的一点思考
  • 将 Measurements 和 Units 应用到物理学
  • 前端之React实战:创建跨平台的项目架构
  • 数据仓库的几种建模方法
  • 深度学习之轻量级神经网络在TWS蓝牙音频处理器上的部署
  • ​VRRP 虚拟路由冗余协议(华为)
  • # 达梦数据库知识点
  • # 利刃出鞘_Tomcat 核心原理解析(七)
  • #C++ 智能指针 std::unique_ptr 、std::shared_ptr 和 std::weak_ptr
  • #QT项目实战(天气预报)
  • (1)常见O(n^2)排序算法解析
  • (html5)在移动端input输入搜索项后 输入法下面为什么不想百度那样出现前往? 而我的出现的是换行...
  • (大众金融)SQL server面试题(1)-总销售量最少的3个型号的车及其总销售量
  • (三)Hyperledger Fabric 1.1安装部署-chaincode测试
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • **PHP二维数组遍历时同时赋值
  • *算法训练(leetcode)第四十五天 | 101. 孤岛的总面积、102. 沉没孤岛、103. 水流问题、104. 建造最大岛屿
  • .bashrc在哪里,alias妙用
  • .NET 4.0网络开发入门之旅-- 我在“网” 中央(下)
  • .NET CF命令行调试器MDbg入门(四) Attaching to Processes
  • .NET精简框架的“无法找到资源程序集”异常释疑
  • .NET与 java通用的3DES加密解密方法
  • @Bean注解详解
  • @TableId注解详细介绍 mybaits 实体类主键注解
  • @Transient注解
  • @WebService和@WebMethod注解的用法