k8s-yaml部署第一个nginx

kubectl是直接操作APTServer的,所以就相当于我们的清单提交给APIServer,然后集群获取到清单描述的应用信息后存入etcd数据库中,然后kube-scheduler组件发现一有一个pod还没绑定到节点上,就会对这个pod进行一系列的调度,把他调度到一个合适的节点上,这个合适可以是pod上约束也可以是node约束,后面讲。

调度好后,把这个节点和pod绑定到一起,回写etcd,然后节点上的kubelet组件这个时候watch到一个pod被分配过来了,就去吧这个pod的信息拉取下来,然后根据描述通过容器运行时,可以使docker也可以是其他的,把容器创建起来,最后当然同样吧pod状态写回etcd,完成创建流程。

apiVersion: apps/v1   //头部信息
kind: Deployment
metadata:
  name: nginx-deploy  
  labels:
    chapter: first-app  //标签
spec:
  selector:  //选择器
     matchLabels:  
       app: nginx   //此处需要跟pod模板相同
  replicas: 2  //副本数量
  template: //pod模板
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name : nginx
        image: nginx:latest  //指定容器镜像名
        ports:
        - containerPort: 80 //容器内部端口

kubectl  get  pods 查看pod

 

 此时修改replicas就会想象pod的副本数量,yaml第一次生成显示create,提交变更configured

看到集群上按照replicas:value的数量,生产pod,而整个资源清单文件对应到kubernetes中就是一个API Object API对象,我们按照这些对象的要求填充上对应的属性后,提交给kubernetes集群,就可以为我们创建出对应的资源对象,比如我们这里定义的是一个deployment类型的API对象。

kubectl  get deploy

deployment这个资源对象就是用于定义多个副本应用的对象,而且还支持对每个副本进行滚动更新,另外就是我们刚才提到的replicas:4

而这个deployment定义的副本pod具体是什么样的,是通过下面的pod模板来定义的,就是template下面定义的,这个template定义pod中只有一个名nginx的容器,容器使用的镜像是nginx:1.7.9,容器监听的端口是80,另外我们还为pod添加了一个app:nginx这样的label标签。

selector:
  matchLables:
   app: nginx

 deployment来管理那些pod,所以这个地方需要和pod模板中的label标签保持一致,这个label标签保持一致,这个label标签之前我们也可提到是

 

 到这里我们就完成了我们的第一个应用的容器化部署,但是往往我们在部署应用的过程中会遇到问题

修改了镜像的版本

kubectl  describe  pod   #podname

 我们可以看到很多这个pod的详细信息,比如调度的节点,状态,ip等。kubernetes创建资源对象的过程中,对该对象的一些重要操作,都会被记录在这个对象的enents里面,可以通过kubectl describe指令查看对应的结果。nginx:latest后,重新 kubectl apply -f 

 

 左侧

kubectl  get  pod  -l  app=nginx --watch  //夯住

右侧更新yaml文件,就可以看见pod的更新过程,可以看到更新过程是先terminating-pending-containercreating,这就是我们所说的滚动更新,滚动更新对于我们的应用持续提供服务是非常重要的手段。

kubelet  delete -f  yaml可以将应用从集群中删除掉

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要通过YAML文件部署Kubernetes Dashboard,可以按照以下步骤进行操作: 1. 首先,创建一个名为`dashboard.yaml`的YAML文件,并使用文本编辑器打开它。 2. 在`dashboard.yaml`文件中,添加以下内容: ```yaml apiVersion: v1 kind: Namespace metadata: name: kubernetes-dashboard --- apiVersion: v1 kind: ServiceAccount metadata: name: admin-user namespace: kubernetes-dashboard ``` 这将创建一个名为`kubernetes-dashboard`的命名空间以及一个名为`admin-user`的ServiceAccount。 3. 接下来,添加以下内容来授予ServiceAccount相关权限: ```yaml apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: admin-user roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: cluster-admin subjects: - kind: ServiceAccount name: admin-user namespace: kubernetes-dashboard ``` 这将创建一个名为`admin-user`的ClusterRoleBinding,并将其绑定到`cluster-admin`角色。 4. 最后,在`dashboard.yaml`文件中添加以下内容来部署Dashboard: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: kubernetes-dashboard namespace: kubernetes-dashboard labels: k8s-app: kubernetes-dashboard spec: replicas: 1 selector: matchLabels: k8s-app: kubernetes-dashboard template: metadata: labels: k8s-app: kubernetes-dashboard spec: serviceAccountName: admin-user containers: - name: kubernetes-dashboard image: kubernetesui/dashboard:v2.4.0 ports: - containerPort: 8443 protocol: TCP args: - --enable-skip-login ``` 这将创建一个名为`kubernetes-dashboard`的Deployment,并使用`admin-user` ServiceAccount进行验证。Dashboard的镜像版本为v2.4.0,并且启用了跳过登录的功能。 5. 保存并关闭`dashboard.yaml`文件。 6. 运行以下命令来部署Dashboard: ``` kubectl apply -f dashboard.yaml ``` 这将使用`dashboard.yaml`文件中定义的配置部署Kubernetes Dashboard。 部署完成后,可以使用以下命令检查Dashboard的状态: ``` kubectl get all -n kubernetes-dashboard ``` 确保所有相关的Pod和服务都处于运行状态。然后,可以通过访问Dashboard的URL(通常是https://<cluster-ip>:8443)来访问Kubernetes Dashboard。请注意,具体的URL和访问方式可能因集群配置而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值