一、Deployment

1、Deployment概念

用于部署无状态的服务,这个最常用的控制器。一般用于管理维护企业内部无状态的微服务,比如configserver、zuul、springboot。他可以管理多个副本的Pod实现无缝迁移、自动扩容缩容、自动灾难恢复、一键回滚等功能。

2、Deployment创建方式

(1)手动创建

kubectl create deployment nginx --image=nginx:1.15.2

导出yaml文件

kubectl get deployment nginx -o yaml > nginx-deploy.yaml
kubectl run nginx-dp --image=nginx --port=80 --replicas=3 --dry-run -o yaml
无控制器yaml文件导出

(2)基于文件创建

vim nginx-deploy.yaml
apiVersion: apps/v1   #指定api版本标签
kind: Deployment       #定义资源的类型/角色,deployment 为副本控制器,此处资源类型可以是Deployment、Job、 Ingress、 Service等
metadata:               #定义资源的元数据信息,比如资源的名称、namespace、标签等信息annotations:deployment.kubernetes.io/revision: "1"creationTimestamp: "2022-07-31T11:36:37Z"generation: 1          #相同的pod有几个labels:app: nginx
manager: kubectl-createoperation: Updatetime: "2022-07-31T11:36:37Z"- apiVersion: apps/v1fieldsType: FieldsV1manager: kube-controller-manageroperation: Updatetime: "2022-07-31T11:36:49Z"name: nginxnamespace: defaultresourceVersion: "84720"selfLink: /apis/apps/v1/namespaces/default/deployments/nginxuid: ee57150d-2912-411f-92f2-39538174d921
spec:progressDeadlineSeconds: 600     #判断线程是否存活的时间replicas: 2       #定义副本数量revisionHistoryLimit: 10       #历史记录保留次数selector:matchLabels:app: nginxstrategy:                   rollingUpdate:maxSurge: 25%             #临时有不可用的pod最大为25%maxUnavailable: 25%       #临时有不可用的pod最大为25%type: RollingUpdatetemplate:metadata:                   #定义资源的元数据信息creationTimestamp: nulllabels:                   #定义资源标签(Pod的标签)app: nginx              #匹配上面的标签,需与上面的标签定义的app保持一致spec:containers:       #定义容器属性- image: nginx:1.15.2      #定义容器使用的镜像以及版本imagePullPolicy: IfNotPresentname: nginxresources: {}terminationMessagePath: /dev/termination-logterminationMessagePolicy: FilednsPolicy: ClusterFirstrestartPolicy: AlwaysschedulerName: default-schedulersecurityContext: {}terminationGracePeriodSeconds: 30
status:availableReplicas: 1conditions:- lastTransitionTime: "2022-07-31T11:36:49Z"lastUpdateTime: "2022-07-31T11:36:49Z"message: Deployment has minimum availability.reason: MinimumReplicasAvailablestatus: "True"type: Available- lastTransitionTime: "2022-07-31T11:36:37Z"lastUpdateTime: "2022-07-31T11:36:49Z"message: ReplicaSet "nginx-66bbc9fdc5" has successfully progressed.reason: NewReplicaSetAvailablestatus: "True"type: ProgressingobservedGeneration: 1readyReplicas: 1replicas: 1      #定义副本数量updatedReplicas: 1

3、deployment状态解析

kubectl get deploy -owide

参数详情

NAME:deployment名称

READY:Pod的状态,已经Ready的个数

UP-TO-DATE:已经达到期望状态的被更新的副本数

AVALABLE:已经可以用的副本数

AGE:显示应用程序运行的时间

CONTAINERS:容器名称

IMAGES:容器的镜像

SELECTOR:管理的Pod的标签

k8s之无状态服务Deployment1相关推荐

  1. 高可用架构设计之无状态服务

    高可用架构设计之无状态服务 笑谈架构设计 事故的发生是量的积累的结果,任何事情都没有表面看起来那么简单,在软件运行的过程中,随着用户量的增加,不考虑高可用,迟早有一天会发生故障,不得事先考虑高可用设计 ...

  2. 干货!一文搞懂无状态服务

    来源 | 机智的程序员小熊 责编 | 寇雪芹 头图 | 下载于视觉中国 事故的发生是量的积累的结果,任何事情都没有表面看起来那么简单,在软件运行的过程中,随着用户量的增加,不考虑高可用,迟早有一天会发 ...

  3. kubernetes-Deployment部署无状态服务的原理详解(七)

    引言   k8s部署无状态应用后,若需要更新应用时,可以通过使用ReplicationController或ReplicaSet实现升级,主要有两种方式: 直接删除所有现有的pod,然后创建新的pod ...

  4. Kubernetes 无状态服务和有状态服务

    无状态服务 是指该服务运行的实例不会在本地存储需要持久化的数据,并且多个实例对于同一个请求响应的结果是完全一致的. 多个实例可以共享相同的持久化数据.例如:nginx实例,tomcat实例等 相关的k ...

  5. openshift_Openshift源中的高可用性Drools无状态服务

    openshift 嗨,大家好! 在这篇博客文章中,我想举一个简单的示例,展示使用Openshift 3(Docker和Kubernetes)扩展我们的Drools Stateless服务有多么容易. ...

  6. Openshift源中的高可用性Drools无状态服务

    嗨,大家好! 在这篇博客文章中,我想举一个简单的例子,展示使用Openshift 3(Docker和Kubernetes)扩展Drools Stateless服务有多么容易. 我将展示如何通过按需提供 ...

  7. 无状态服务和有状态服务

    对服务器程序来说,究竟是有状态服务,还是无状态服务,其判断依旧是指两个来自相同发起者的请求在服务器端是否具备上下文关系.如果是状态化请求,那么服务器端一般都要保存请求的相关信息,每个请求可以默认地使用 ...

  8. 无状态服务(stateless service)

    转载:http://kyfxbl.iteye.com/blog/1831869 一.定义 无状态服务(stateless service)对单次请求的处理,不依赖其他请求,也就是说,处理一次请求所需的 ...

  9. 关于无状态服务(stateless service) 有状态服务(stateful service),指一篇文章就搞明白

    无状态服务(stateless service) 一.定义 无状态服务(stateless service)对单次请求的处理,不依赖其他请求,也就是说,处理一次请求所需的全部信息,要么都包含在这个请求 ...

  10. 有状态服务和无状态服务

    概念 服务一般分为有状态服务(Stateful Service)和无状态服务(Stateless Service).它们的区别是,当请求发起后,服务在服务端运行时是否需要关联上下文. 有状态服务,服务 ...

最新文章

  1. TensorFlow中Session.run和Tensor.eval的区别
  2. 《计算机组成与设计(ARM版)》读书笔记-第二章指令2
  3. java -cp 引用多个包_javac编译单文件、多文件引入jar包、-cp解决无法加载主类问题...
  4. kerberos体系下的应用(yarn,spark on yarn)
  5. Java常用接口与类——Date、Calendar、DateFormat、TimeZone(日期相关)
  6. 全国计算机考试可以异地考吗,公务员省考可以异地考吗
  7. 语音识别概念午后大跌 语音识别概念股一览表
  8. linux扩大lvm_Linux下lvm在线扩容步骤
  9. 客户机容易随机出现自动重启、游戏卡问题?不妨优化下BIOS中节能技术!
  10. [转]Mysql FROM_UNIXTIME as UTC
  11. Google Earth Engine ——消除影像色差直方图匹配算法(CDF累计分布函数)!
  12. finereport与finebi差别_FineBI与FineReport对比
  13. c语言程序设计题目湖南大学,湖南大学C语言期末考试样卷
  14. 机翻福音-多种语言平行语料库资源
  15. 马力测试 软件,【图】【分享百公里加速测试软件DYNOLICIOUS】内附楼主的测试结果!...
  16. JavaScript实现手机震动效果
  17. mac下charles抓android7.0的包
  18. 如果在做项目时,发现自己在规定的时间内肯定完成不了时,你会怎么办
  19. 区块链各种共识机制对比与分析
  20. 如何通过“路缘精细化管理” 缓解城市停车难题

热门文章

  1. pytorch历史版本下载_Pytorch、Anaconda安装、Navidia版本更新
  2. tenacity 报错_Python tenacity源码分析(一个专门用来做重试的库)v1.0
  3. Data Management Platform 数据管理平台全接触
  4. Spring漫画学习笔记(二) 什么是BeanFactory
  5. 挑选电脑免费加密软件特别注意哪些?
  6. 新版升级 DAEMON Tools v4.10 X86 32 Bits (with SPTD 1.50)
  7. 浏览器页面前端自适应方案
  8. Python+OpenCV 轻松实现人脸识别签到考勤系统
  9. Python——自动签到脚本
  10. duet太香啦啦啦啦啦啦啦啦啦啦