kubernetes deployment维护常用命令

deployment样本文件

$ cat hello-world.yaml

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: hello-world
  namespace: dev
  labels:
    app: hello-world
spec:
  replicas: 3
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 1
  template:
    metadata:
      labels:
        app: hello-world
    spec:
      containers:
      - name: hello-world
        image: hello-world:v1
        imagePullPolicy: IfNotPresent

说明:
maxSurge: 1 表示滚动升级前先启动1个pod
maxUnavailable: 1 表示滚动升级时允许的最大Unavailable的pod个数,一次升级数量

maxSurge >= maxUnavailable


创建deployment

$ kubectl create -f hello-world.yaml

查看deployment

$ kubectl describe deployment hello-world -n dev

Name:                   hello-world
Namespace:              dev
CreationTimestamp:      Fri, 09 Mar 2018 10:09:15 +0800
Labels:                 app=hello-world
Annotations:            deployment.kubernetes.io/revision=1
Selector:               app=hello-world
Replicas:               3 desired | 3 updated | 3 total | 3 available | 0 unavailable
StrategyType:           RollingUpdate
MinReadySeconds:        0
RollingUpdateStrategy:  1 max unavailable, 1 max surge
Pod Template:
  Labels:  app=hello-world
  Containers:
   hello-world:
    Image:        hello-world:v1
    Port:         <none>
    Environment:  <none>
    Mounts:       <none>
  Volumes:        <none>
Conditions:
  Type           Status  Reason
  ----           ------  ------
  Available      True    MinimumReplicasAvailable
OldReplicaSets:  <none>
NewReplicaSet:   hello-world-5cc47c955f (3/3 replicas created)
Events:
  Type    Reason             Age   From                   Message
  ----    ------             ----  ----                   -------
  Normal  ScalingReplicaSet  4s    deployment-controller  Scaled up replica set hello-world-5cc47c955f to 3

升级deployment

$ kubectl set image deployment hello-world hello-world=hello-world:v2 -n dev

或者

$ kubectl edit deployment hello-world -n dev

终止升级

$ kubectl rollout pause deployment hello-world -n dev

继续升级

$ kubectl rollout resume deployment hello-world -n dev

回滚上一个版本

$ kubectl rollout unto deployment hello-world -n dev

查看deployment版本

$ kubectl rollout history deployment hello-world -n dev
deployments "hello-world"
REVISION  CHANGE-CAUSE
1         <none>
2         <none>

回滚指定版本

kubectl rollout undo deployment hello-world --to-revision=1 -n dev

查看升级部署状态

$ kubectl rollout status deployment hello-world -n dev

原文地址:http://blog.51cto.com/2759492/2084484

时间: 2024-11-08 17:42:32

kubernetes deployment维护常用命令的相关文章

Linux系统管理和维护常用命令

Linux系统管理和维护常用命令 Linux系统管理和维护常用命令 ls 命令 功能说明ls 命令显示指定工作目录下的内容,列出工作目录所包含的文件及子目录.语法结构: ls [选项] [路径或文件] ls 选项及说明 -a  显示指定目录下的所有文件以及子目录,包含隐藏文件-d  只显示目录列表,不显示文件-l  除文件名称外,同时将文件或者子目录的权限,使用者和文件大小等详细信息列出-s  在每个文件名后输出该文件的大小-k  以k字节的形式表示文件的大小-u  以文件上次被访问的时间排序-

Kubernetes之kubectl常用命令使用指南:2:故障排查

kubectl是一个用于操作kubernetes集群的命令行接口,通过利用kubectl的各种命令可以实现各种功能,是在使用kubernetes中非常常用的工具.这里我们会通过一些简单的实例来展现其中一些高频命令的使用方法. 更为重要的是这些命令使用的场景以及能够解决什么样的问题.上篇文章我们介绍了创建和删除相关的几条命令,这篇文章我们来看一下出现问题时最常用的另外九条命令. 常用命令 kubectl故障排查相关,本文将会简单介绍一下如下命令 项番 命令 说明 No.1 version 显示客户

Oracle以及SDE维护常用命令-查看表空间等

之前现场反馈一个数据更新的问题,查看感觉是因为表空间满了导致的(错误在之前的博客随笔中写过),因此远程对服务器进行查看.个人平常都是通过Oracle客户端的Entreprise Manager Console进行查看的,但是发现服务器上只安装了Oracle服务端并且不能正常进行网页登录查看. 因此到网上查了一下查看Oracle表空间使用情况的查询语句,通过PLSQL进行查询查看,在这里记录一下,另外附几个常用的Oracle以及SDE命令. 查看表空间的使用情况(解决此次问题使用) select

nginx日常维护常用命令

一.简明nginx常用命令 1. 启动 Nginx 代码如下: [email protected]:sudo ./sbin/nginx 2. 停止 Nginx 代码如下: [email protected]:sudo ./sbin/nginx -s stop [email protected]:sudo ./sbin/nginx -s quit -s都是采用向 Nginx 发送信号的方式. 3. Nginx 重载配置 代码如下: [email protected]:sudo ./sbin/ngi

Kubernetes之kubectl常用命令

本文转自:http://blog.csdn.net/xingwangc2014/article/details/51204224 kubernetes通过kube-apiserver作为整个集群管理的入口.Apiserver是整个集群的主管理节点,用户通过Apiserver配置和组织集群,同时集群中各个节点同etcd存储的交互也是通过Apiserver进行交互.Apiserver实现了一套RESTfull的接口,用户可以直接使用API同Apiserver交互.另外官方还提供了一个客户端kubec

mongodb维护常用命令

一,用户操作:1. #进入数据库adminuse admin2. #增加或修改用户密码db.addUser('name','pwd')3. #查看用户列表db.system.users.find()4. #用户认证db.auth('name','pwd')5. #删除用户db.removeUser('name')6. #查看所有用户show users7. #查看所有数据库show dbs8. #查看所有的collectionshow collections9. #查看各collection的状

aix 维护常用命令

errpt   - dH  :如果有记录表示硬故障件出现.#向ibm报修 mail:关键错误信息会以mail方式发给root用户.#根据报错程序联系相应厂家. df  -g: 文件系统不可以,当/var./temp./占满时系统会挂.#找出哪些文件占用空间大du -sm* bootinfo-K : 64bit/32bit,64bit内核能给系统带来更优的性能. uptime:系统运行系统如果超过一年,系统中的碎片可能会增加,建议维护日重启

Linux服务器维护常用命令

1 # uname -a # 查看内核/操作系统/CPU信息 2 # head -n 1 /etc/issue # 查看操作系统版本 3 # cat /proc/cpuinfo # 查看CPU信息 4 # hostname # 查看计算机名 5 # lspci -tv # 列出所有PCI设备 6 # lsusb -tv # 列出所有USB设备 7 # lsmod # 列出加载的内核模块 8 # env # 查看环境变量 9 # free -m # 查看内存使用量和交换区使用量 10 # df -

oracle表空间维护常用命令

---查看表空间的名字及文件所在位置: select tablespace_name, file_id, file_name,round(bytes/(1024*1024),0) total_space from dba_data_files order by tablespace_name ---如何查看oracle表空间是否自动扩展 (increment_by是块数[8192byte/块]) select file_name,tablespace_name,bytes/1024/1024 "