K8s 是啥?

啥是K8s?

Kubernetes是一个开源的容器 orchestration系统,它可以帮助你自动化部署、扩展和管理容器化应用。

以下是一些入门和日常使用K8S的关键步骤和概念:

  1. 理解基础概念

    • Pods: Kubernetes中最基础的调度单元,一个Pod可以包含一个或多个紧密相关的容器。
    • Deployments: 用于管理Pods的完整生命周期,包括滚动更新、回滚和复制等。
    • Services: 提供了一种稳定的网络标识符和通信端点,用于访问一组Pods。
    • Volumes: 为Pods提供持久化存储。
  2. 安装和配置Kubernetes

    • 根据你的操作系统和需求选择合适的安装方法,如通过kubeadm、Minikube或者云服务商提供的托管K8S服务。
  3. 创建和管理资源

    • 使用kubectl命令行工具来创建、查看、修改和删除各种K8S资源对象,如Pods、Deployments和Services。
  4. 部署应用

    • 编写YAML或JSON格式的配置文件,定义你的应用程序所需的Pods、Deployments和服务。
    • 使用kubectl apply -f <your-config-file>命令将配置应用到Kubernetes集群中。
  5. 扩展和更新应用

    • 使用Deployments可以方便地进行水平扩展和回滚操作,只需修改Deployment的副本数量或更新其镜像版本即可。
  6. 监控和调试

    • 使用kubectl get, describe, 和 logs 命令来监控和调试你的应用程序和Kubernetes资源。
  7. 高级主题

    • 学习如何使用StatefulSets管理有状态应用。
    • 探索Ingress资源和Controller如何处理外部流量进入集群。
    • 理解Helm charts如何简化应用程序的打包和部署过程。

在日常使用中,你需要熟悉并掌握Kubernetes的核心概念和技术,并根据你的应用程序需求灵活调整和优化你的Kubernetes配置。同时,保持对Kubernetes社区和新特性的关注也是非常重要的,这可以帮助你不断提升和优化你的K8S使用经验。

如何部署

部署应用程序到Kubernetes主要包括以下步骤:

  1. 编写YAML配置文件

    • 创建一个或多个YAML文件来描述你的应用程序所需的Kubernetes资源,如Pods、Deployments、Services等。
      以下是一个简单的Deployment配置文件示例:
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-app-deployment
    spec:
      replicas: 3
      selector:
        matchLabels:
          app: my-app
      template:
        metadata:
          labels:
            app: my-app
        spec:
          containers:
          - name: my-app-container
            image: your-docker-repo/your-image-name:latest
            ports:
            - containerPort: 8080
    
  2. (可选)创建Service

    • 如果你需要从集群外部或者集群内部的其他服务访问你的应用程序,可以创建一个Service。以下是一个简单的ClusterIP类型Service配置文件示例:
    apiVersion: v1
    kind: Service
    metadata:
      name: my-app-service
    spec:
      selector:
        app: my-app
      ports:
      - name: http
        port: 80
        targetPort: 8080
      type: ClusterIP
    
  3. 使用kubectl应用配置

    • 确保你的kubectl已经配置为指向正确的Kubernetes集群。
    • 使用kubectl apply命令将你的配置应用到集群中:
    kubectl apply -f deployment.yaml
    kubectl apply -f service.yaml
    
  4. 验证部署

    • 使用以下命令检查Deployment和Pod的状态:
    kubectl get deployments
    kubectl get pods
    
  5. (可选)如果创建了Service,获取Service的URL

    • 如果你创建了一个对外提供服务的Service,并且它是一个NodePort或LoadBalancer类型,你可以获取其访问URL:
    kubectl get services my-app-service
    

    输出中会显示Service的外部IP和端口,你可以通过http://<external-ip>:<port>访问你的应用程序。

以上就是部署应用程序到Kubernetes的基本步骤。请注意,这只是一个基础示例,实际部署过程中可能需要根据你的应用程序特性和需求进行更多配置和优化。



欢迎关注公-众-号【TaonyDaily】、留言、评论,一起学习。

公众号

Don’t reinvent the wheel, library code is there to help.

文章来源:刘俊涛的博客


若有帮助到您,欢迎点赞、转发、支持,您的支持是对我坚持最好的肯定(_)

posted @ 2023-12-25 13:36  刘俊涛的博客  阅读(17)  评论(0编辑  收藏  举报