zoukankan      html  css  js  c++  java
  • 入门-k8s部署应用 (三)

    Kubernetes 部署应用

    在 k8s 上进行部署前,首先需要了解一个基本概念 Deployment

    Deployment 译名为 部署。在k8s中,通过发布 Deployment,可以创建应用程序 (docker image) 的实例 (docker container),这个实例会被包含在称为 Pod 的概念中,Pod 是 k8s 中最小可管理单元。

    在 k8s 集群中发布 Deployment 后,Deployment 将指示 k8s 如何创建和更新应用程序的实例,master 节点将应用程序实例调度到集群中的具体的节点上。

    创建应用程序实例后,Kubernetes Deployment Controller 会持续监控这些实例。如果运行实例的 worker 节点关机或被删除,则 Kubernetes Deployment Controller 将在群集中资源最优的另一个 worker 节点上重新创建一个新的实例。这提供了一种自我修复机制来解决机器故障或维护问题。

    在容器编排之前的时代,各种安装脚本通常用于启动应用程序,但是不能够使应用程序从机器故障中恢复。通过创建应用程序实例并确保它们在集群节点中的运行实例个数,Kubernetes Deployment 提供了一种完全不同的方式来管理应用程序。

    Kubernetes教程:部署第一个应用程序

    Deployment 处于 master 节点上,通过发布 Deployment,master 节点会选择合适的 worker 节点创建 Container(即图中的正方体),Container 会被包含在 Pod (即蓝色圆圈)里。

    部署 nginx Deployment

    本套教程提供了两种实战方式:

    • 使用 kubectl
    • 使用 Kuboard

    1.创建 YAML 文件

    apiVersion: apps/v1    #与k8s集群版本有关,使用 kubectl api-versions 即可查看当前集群支持的版本
    kind: Deployment    #该配置的类型,我们使用的是 Deployment
    metadata:            #译名为元数据,即 Deployment 的一些基本属性和信息
      name: nginx-deployment    #Deployment 的名称
      labels:        #标签,可以灵活定位一个或多个资源,其中key和value均可自定义,可以定义多组,目前不需要理解
        app: nginx    #为该Deployment设置key为app,value为nginx的标签
    spec:            #这是关于该Deployment的描述,可以理解为你期待该Deployment在k8s中如何使用
      replicas: 1    #使用该Deployment创建一个应用程序实例
      selector:        #标签选择器,与上面的标签共同作用,目前不需要理解
        matchLabels: #选择包含标签app:nginx的资源
          app: nginx
      template:        #这是选择或创建的Pod的模板
        metadata:    #Pod的元数据
          labels:    #Pod的标签,上面的selector即选择包含标签app:nginx的Pod
            app: nginx
        spec:        #期望Pod实现的功能(即在pod中部署)
          containers:    #生成container,与docker中的container是同一种
          - name: nginx    #container的名称
            image: nginx:1.7.9    #使用镜像nginx:1.7.9创建container,该container默认80端口可访问
     

    2.应用YAML文件

    kubectl apply -f nginx-deployment.yaml

    3.查看Deployment

    [root@guanbin-k8s-master k8s]# kubectl get deployments
    NAME               READY   UP-TO-DATE   AVAILABLE   AGE
    nginx-deployment   1/1     1            1           2m27s

    4.查看Pod

    [root@guanbin-k8s-master k8s]# kubectl get pods
    NAME                                READY   STATUS    RESTARTS   AGE
    kubernetes-bootcamp                 1/1     Running   0          57m
    nginx                               1/1     Running   0          19m
    nginx-deployment-6dd8bc586b-kgn85   1/1     Running   0          2m32s
  • 相关阅读:
    设计模式之建造者模式(简单)
    设计模式之简单工厂模式,工厂模式,抽象工厂模式
    设计模式之观察者模式
    Redis java操作客服端——jedis
    Redis基础
    java环境变量配置加maven配置
    设计模式之JDK动态代理
    springboot+mybatis+Thymeleaf
    OS问题管理系统开发
    复制CentOS虚拟机网络配置
  • 原文地址:https://www.cnblogs.com/guanbin-529/p/12735142.html
Copyright © 2011-2022 走看看