栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

k8s-Controller概念和应用场景

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

k8s-Controller概念和应用场景

目录
  • 一、什么是Controller
  • 二、Pod和Controller关系
  • 三、Deployment控制器应用场景
  • 四、yaml文件字段说明
  • 五、Deployment控制器部署应用
    • 1.导出yaml文件
    • 2.使用yaml文件部署
    • 3.对外发布(暴露对外端口)
    • 4.通过分配的ip访问
  • 六、升级回滚
  • 七、弹性伸缩

一、什么是Controller
  • 在集群上管理和运行容器的对象

二、Pod和Controller关系
  • Pod通过Controller实现应用的运维,比如伸缩,滚动升级等等
  • pod和Controller的关系建立是通过label标签和selector选择器

三、Deployment控制器应用场景
  • 部署无状态应用

  • 管理Pod和ReplicaSet

  • 部署,滚动升级等服务

应用场景:
	1、web服务
	2、微服务

四、yaml文件字段说明
apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: web
  name: web
spec:
  replicas: 1
  selector:
    matchLabels:
      app: web
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: web
    spec:
      containers:
      - image: nginx
        name: nginx
        resources: {}
status: {}

五、Deployment控制器部署应用

1.导出yaml文件
kubectl create deployment web --image=nginx --dry-run -o yaml > web.yaml

2.使用yaml文件部署
kubectl apply -f web.yaml

3.对外发布(暴露对外端口)
kubectl expose deployment web --port=80 --type=NodePort --target-port=80 --name=web1 -o yaml ->web1.yaml

kubectl apply -f web1.yaml

4.通过分配的ip访问

六、升级回滚
// 镜像版本升级
kubectl set image deployment web nginx=nginx:1.15

// 检查版本升级状态
kubectl rollout status deployment web

// 查看升级历史版本
kubectl rollout history deployment web

//还原成上一个版本
kubectl rollout undo deployment web

// 回滚到指定的版本
kubectl rollout undo deployment web --to-revision=3

七、弹性伸缩
kubectl scale deployment web --replicas=1

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/673283.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号