当前位置: 首页 > news >正文 茂名快速建站模板康展 wordpress news 2025/10/25 5:58:18 茂名快速建站模板,康展 wordpress,网站文章内链,html5网站开发设计Statefulset控制器 一、概念二、Statefulset资源清单文件编写技巧2.1、查看定义Statefulset资源需要的字段2.2、查看statefulset.spec字段如何定义2.3、查看statefulset的spec.template字段如何定义 三、Statefulset使用案例#xff1a;部署web站点3.1、编写一个Statefulset资… Statefulset控制器 一、概念二、Statefulset资源清单文件编写技巧2.1、查看定义Statefulset资源需要的字段2.2、查看statefulset.spec字段如何定义2.3、查看statefulset的spec.template字段如何定义 三、Statefulset使用案例部署web站点3.1、编写一个Statefulset资源清单文件3.2、更新资源清单文件3.3、查看相关资源 四、StatefulSet组成部分4.1、 Headless Service【1】headless service会为service分配一个域名【2】StatefulSet会为关联的Pod保持一个不变的Pod Name【3】StatefulSet会为关联的Pod分配一个dnsName 4.2、volumeClaimTemplates4.3、总结 五、Statefulset管理pod扩容、缩容、更新5.1、动态扩缩容5.2、滚动更新 一、概念 StatefulSet是为了管理有状态服务的问题而设计的. 扩展 有状态服务 StatefulSet是有状态的集合管理有状态的服务它所管理的Pod的名称不能随意变化。数据持久化的目录也是不一样每一个Pod都有自己独有的数据持久化存储目录。比如MySQL主从、redis集群等。 无状态服务 RC、Deployment、DaemonSet都是管理无状态的服务它们所管理的Pod的IP、名字启停顺序等都是随机的。个体对整体无影响所有pod都是共用一个数据卷的部署的tomcat就是无状态的服务tomcat被删除在启动一个新的tomcat加入到集群即可跟tomcat的名字无关。 二、Statefulset资源清单文件编写技巧 2.1、查看定义Statefulset资源需要的字段 [rootmaster ~]# kubectl explain statefulset KIND: StatefulSet VERSION: apps/v1DESCRIPTION:StatefulSet represents a set of pods with consistent identities. Identitiesare defined as:- Network: A single stable DNS and hostname.- Storage: As many VolumeClaims as requested.The StatefulSet guarantees that a given network identity will always map tothe same storage identity.FIELDS:apiVersion string # 定义资源需要使用的api版本kind string # 定义资源类型metadata Object # 定义元数据spec Object # 定义容器相关的信息 2.2、查看statefulset.spec字段如何定义 [rootmaster ~]# kubectl explain statefulset.spec KIND: StatefulSet VERSION: apps/v1RESOURCE: spec ObjectDESCRIPTION:Spec defines the desired identities of pods in this set.A StatefulSetSpec is the specification of a StatefulSet.FIELDS:podManagementPolicy string # POD管理策略replicas integer # 副本数revisionHistoryLimit integer # 保留的历史版本selector Object -required- # 标签选择器选择它所关联的podserviceName string -required- # headless service的名字template Object -required- # 生成pod的模板updateStrategy Object # 更新策略volumeClaimTemplates []Object # 存储卷申请模板2.3、查看statefulset的spec.template字段如何定义 对于template而言其内部定义的就是podpod模板是一个独立的对象。 .spec.template里的内容是声明Pod对象时要定义的各种属性所以这部分也叫做PodTemplatePod模板 [rootmaster ~]# kubectl explain statefulset.spec.template KIND: StatefulSet VERSION: apps/v1RESOURCE: template Object DESCRIPTION:...... FIELDS:metadata Object # 定义多少个Pod副本默认将仅部署1个Pod、匹配Pod标签的选择器、创建pod的模板、存储卷申请模板 spec Object # Pod里的容器属性等配置 # 在spec.template.spec.selector中定义的标签选择器必须能够匹配到spec.template.metadata.labels里定义的Pod标签否则Kubernetes将不允许创建statefulset。三、Statefulset使用案例部署web站点 3.1、编写一个Statefulset资源清单文件 [rootmaster 12]# cat statefulset.yaml apiVersion: v1 # 定义api版本 kind: Service # 定义要创建的资源service metadata:name: nginx # 定义service的名字labels: app: nginx # service的标签 spec:ports:- port: 80name: webclusterIP: None # 创建一个没有ip的serviceselector:app: nginx # 选择拥有appnginx标签的pod --- apiVersion: apps/v1 kind: StatefulSet metadata:name: web spec:selector:matchLabels:app: nginxserviceName: nginx # headless service的名字replicas: 2 # 副本数template:metadata: # 定义pod的模板labels:app: nginxspec:containers:- name: nginximage: nginxports:- containerPort: 80 # 容器服务的端口name: web # 端口别名volumeMounts:- name: wwwmountPath: /usr/share/nginx/htmlvolumeClaimTemplates: # 存储卷申请模板- metadata:name: wwwspec:accessModes: [ReadWriteOnce] # 访问模式单路读写storageClassName: nfs # 指定从哪个存储类申请pvresources:requests:storage: 1Gi # 需要1G的pvc会自动跟符合条件的pv绑定 3.2、更新资源清单文件 [rootmaster 12]# kubectl apply -f statefulset.yaml service/nginx created statefulset.apps/web created # 查看statefulset是否创建成功 [rootmaster 12]# kubectl get statefulset NAME READY AGE web 2/2 2m7s # 查看pod [rootmaster 12]# kubectl get pods -l appnginx NAME READY STATUS RESTARTS AGE web-0 1/1 Running 0 2m50s web-1 1/1 Running 0 2m8s # 通过上面可以看到创建的pod是有序的3.3、查看相关资源 [rootmaster 12]# kubectl get svc -l appnginx NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE nginx ClusterIP None none 80/TCP 3m50s [rootmaster 12]# kubectl get pvc NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE www-web-0 Bound pvc-223fc042-1b1b-4516-a1b5-a5572434d3ee 1Gi RWO nfs 4m8s www-web-1 Bound pvc-b4f026b2-4984-4302-b45d-00c57a74a162 1Gi RWO nfs 3m26s [rootmaster 12]# kubectl get pv NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE pvc-223fc042-1b1b-4516-a1b5-a5572434d3ee 1Gi RWO Delete Bound default/www-web-0 nfs 4m39s pvc-b4f026b2-4984-4302-b45d-00c57a74a162 1Gi RWO Delete Bound default/www-web-1 nfs 3m56s [rootmaster 12]# for i in 0 1; do kubectl exec web-$i -- sh -c hostname;done web-0 web-1四、StatefulSet组成部分 4.1、 Headless Service 用来定义pod网路标识生成可解析的DNS记录 Headless service不分配clusterIPheadless service可以通过解析service的DNS,返回所有Pod的dns和ip地址 (statefulSet部署的Pod才有DNS)普通的service,只能通过解析service的DNS返回service的ClusterIP。 【1】headless service会为service分配一个域名 service name.$namespace name.svc.cluster.local K8s中资源的全局FQDN格式: Service_NAME.NameSpace_NAME.Domain.LTD. Domain.LTD.svc.cluster.local #这是默认k8s集群的域名。 扩展FQDN FQDN 全称 Fully Qualified Domain Name 即全限定域名同时带有主机名和域名的名称 FQDN Hostname DomainName 如 主机名是 xianchao 域名是 baidu.com FQDN xianchao.baidu.com 【2】StatefulSet会为关联的Pod保持一个不变的Pod Name statefulset中Pod的名字格式为$(StatefulSet name)-$(pod序号) 【3】StatefulSet会为关联的Pod分配一个dnsName $Pod Name.$service name.$namespace name.svc.cluster.local 4.2、volumeClaimTemplates 为什么要用volumeClaimTemplate 对于有状态应用都会用到持久化存储比如mysql主从由于主从数据库的数据是不能存放在一个目录下的每个mysql节点都需要有自己独立的存储空间。 而在deployment中创建的存储卷是一个共享的存储卷多个pod使用同一个存储卷它们数据是同步的而statefulset定义中的每一个pod都不能使用同一个存储卷这就需要使用volumeClainTemplate。 当在使用statefulset创建pod时volumeClainTemplate会自动生成一个PVC从而请求绑定一个PV每一个pod都有自己专用的存储卷。 Pod、PVC和PV对应的关系图如下 使用kubectl run运行一个提供nslookup命令的容器这个命令来自于dnsutils包通过对pod主机名执行nslookup可以检查它们在集群内部的DNS地址 kubectl run busybox --image docker.io/library/busybox:1.28 --image-pull-policyIfNotPresent --restartNever --rm -it busybox -- sh If you dont see a command prompt, try pressing enter. / # nslookup web-0.nginx.default.svc.cluster.local Server: 10.96.0.10 Address 1: 10.96.0.10 kube-dns.kube-system.svc.cluster.localName: web-0.nginx.default.svc.cluster.local # 查询service dns会把对应的pod ip解析出来 Address 1: 10.244.196.144 web-0.nginx.default.svc.cluster.local4.3、总结 1、Statefulset管理的podpod名字是有序的由statefulset的名字-0、1、2这种格式组成2、创建statefulset资源的时候必须事先创建好一个service,如果创建的service没有ip那对这个service做dns解析会找到它所关联的pod ip如果创建的service有ip那对这个service做dns解析会解析到service本身ip。3、statefulset管理的pod删除pod新创建的pod名字跟删除的pod名字是一样的4、statefulset具有volumeclaimtemplate这个字段这个是卷申请模板会自动创建pvpvc也会自动生成跟pv进行绑定那如果创建的statefulset使用了volumeclaimtemplate这个字段那创建pod数据目录是独享的5、ststefulset创建的pod是有域名的域名组成pod-name.svc-name.svc-namespace.svc.cluster.local 五、Statefulset管理pod扩容、缩容、更新 5.1、动态扩缩容 如果我们觉得两个副本太少了想要增加只需要修改配置文件statefulset.yaml里的replicas的值即可原来replicas: 2现在变成replicaset: 3修改之后执行如下命令更新 [rootmaster 12]# kubectl apply -f statefulset.yaml service/nginx unchanged statefulset.apps/web configured [rootmaster 12]# kubectl get sts NAME READY AGE web 3/3 80m [rootmaster 12]# kubectl get pods -l appnginx NAME READY STATUS RESTARTS AGE web-0 1/1 Running 0 81m web-1 1/1 Running 0 80m web-2 1/1 Running 0 28s也可以直接编辑控制器实现扩容这个是我们把请求提交给了apiserver实时修改 [rootmaster 12]# kubectl edit sts web # 副本改成4 statefulset.apps/web edited [rootmaster 12]# kubectl get pods -l appnginx NAME READY STATUS RESTARTS AGE web-0 1/1 Running 0 82m web-1 1/1 Running 0 81m web-2 1/1 Running 0 90s web-3 1/1 Running 0 7s5.2、滚动更新 kubectl explain sts.spec.updateStrategy [rootmaster 12]# kubectl explain sts.spec.updateStrategy KIND: StatefulSet VERSION: apps/v1RESOURCE: updateStrategy ObjectDESCRIPTION:updateStrategy indicates the StatefulSetUpdateStrategy that will beemployed to update Pods in the StatefulSet when a revision is made toTemplate.StatefulSetUpdateStrategy indicates the strategy that the StatefulSetcontroller will use to perform updates. It includes any additionalparameters necessary to perform the update for the indicated strategy.FIELDS:rollingUpdate ObjectRollingUpdate is used to communicate parameters when Type isRollingUpdateStatefulSetStrategyType.type stringType indicates the type of the StatefulSetUpdateStrategy. Default isRollingUpdatePossible enum values:- OnDelete - RollingUpdate [rootmaster 12]# cat statefulset.yaml apiVersion: v1 kind: Service metadata:name: nginxlabels:app: nginx spec:ports:- port: 80name: webclusterIP: Noneselector:app: nginx --- apiVersion: apps/v1 kind: StatefulSet metadata:name: web spec:updateStrategy: # 1、添加更新策略rollingUpdate:partition: 1 # 序号大于等于1的pod做更新maxUnavailable: 0 # 滚动更新时允许不可用 Pod 的最大数量selector:matchLabels:app: nginxserviceName: nginxreplicas: 3template:metadata:labels:app: nginxspec:containers:- name: nginximage: ikubernetes/myapp:v2 # 2、修改镜像容器才会更新imagePullPolicy: IfNotPresentports:- containerPort: 80name: webvolumeMounts:- name: wwwmountPath: /usr/share/nginx/htmlvolumeClaimTemplates:- metadata:name: wwwspec:accessModes: [ReadWriteOnce]storageClassName: nfsresources:requests:storage: 1Gi# 在一个终端执行如下命令kubectl apply -f statefulset.yaml # 在另一个终端动态查看pod [rootmaster ~]# kubectl get pods -l appnginx -w NAME READY STATUS RESTARTS AGE web-0 1/1 Running 0 102m web-1 1/1 Running 0 101m web-2 1/1 Running 0 22m web-3 1/1 Running 0 20m web-3 1/1 Terminating 0 20m web-3 1/1 Terminating 0 20m web-3 0/1 Terminating 0 20m web-3 0/1 Terminating 0 20m web-3 0/1 Terminating 0 20m web-2 1/1 Terminating 0 22m web-2 1/1 Terminating 0 22m web-2 0/1 Terminating 0 22m web-2 0/1 Terminating 0 22m web-2 0/1 Terminating 0 22m web-2 0/1 Pending 0 0s web-2 0/1 Pending 0 0s web-2 0/1 ContainerCreating 0 0s web-2 0/1 ContainerCreating 0 1s web-2 1/1 Running 0 10s web-1 1/1 Terminating 0 102m web-1 1/1 Terminating 0 102m web-1 0/1 Terminating 0 102m web-1 0/1 Terminating 0 102m web-1 0/1 Terminating 0 102m web-1 0/1 Pending 0 0s web-1 0/1 Pending 0 0s web-1 0/1 ContainerCreating 0 0s web-1 0/1 ContainerCreating 0 0s web-1 1/1 Running 0 9s web-2 1/1 Running 0 42s web-1 1/1 Running 0 52s# 从上面结果可以看出来pod在更新的时候只是更新了web-1、2、3 # partition: 1表示更新的时候会把pod序号大于等于1的进行更新如果更新策略是OnDelete那不会自动更新pod需要手动删除重新常见的pod才会实现更新 修改策略 updateStrategy:type: OnDelete# rollingUpdate:# partition: 1# maxUnavailable: 0[rootmaster 12]# kubectl apply -f statefulset.yaml service/nginx unchanged statefulset.apps/web configured [rootmaster 12]# kubectl get pod -l appnginx NAME READY STATUS RESTARTS AGE web-0 1/1 Running 0 121m web-1 1/1 Running 0 18m web-2 1/1 Running 0 18m [rootmaster 12]# kubectl delete pod web-0 pod web-0 deleted # 在另一种终端动态查看 [rootmaster ~]# kubectl get pod -w NAME READY STATUS RESTARTS AGE web-0 1/1 Running 0 122m web-1 1/1 Running 0 19m web-2 1/1 Running 0 19m web-0 1/1 Terminating 0 122m web-0 1/1 Terminating 0 122m web-0 0/1 Terminating 0 122m web-0 0/1 Terminating 0 122m web-0 0/1 Terminating 0 122m web-0 0/1 Pending 0 0s web-0 0/1 Pending 0 0s web-0 0/1 ContainerCreating 0 0s web-0 0/1 ContainerCreating 0 1s web-0 1/1 Running 0 2s 文章转载自: http://www.morning.qcrhb.cn.gov.cn.qcrhb.cn http://www.morning.mbnhr.cn.gov.cn.mbnhr.cn http://www.morning.mdwtm.cn.gov.cn.mdwtm.cn http://www.morning.xesrd.com.gov.cn.xesrd.com http://www.morning.yrwqz.cn.gov.cn.yrwqz.cn http://www.morning.mglqf.cn.gov.cn.mglqf.cn http://www.morning.xckqs.cn.gov.cn.xckqs.cn http://www.morning.sjli222.cn.gov.cn.sjli222.cn http://www.morning.nrzbq.cn.gov.cn.nrzbq.cn http://www.morning.mbqyl.cn.gov.cn.mbqyl.cn http://www.morning.gxklx.cn.gov.cn.gxklx.cn http://www.morning.mdxwz.cn.gov.cn.mdxwz.cn http://www.morning.ytnn.cn.gov.cn.ytnn.cn http://www.morning.fldsb.cn.gov.cn.fldsb.cn http://www.morning.mtmnk.cn.gov.cn.mtmnk.cn http://www.morning.mjjty.cn.gov.cn.mjjty.cn http://www.morning.crrjg.cn.gov.cn.crrjg.cn http://www.morning.ghxsn.cn.gov.cn.ghxsn.cn http://www.morning.rpzqk.cn.gov.cn.rpzqk.cn http://www.morning.jwefry.cn.gov.cn.jwefry.cn http://www.morning.fpkpz.cn.gov.cn.fpkpz.cn http://www.morning.rlxnc.cn.gov.cn.rlxnc.cn http://www.morning.lmrcq.cn.gov.cn.lmrcq.cn http://www.morning.nqlkb.cn.gov.cn.nqlkb.cn http://www.morning.gfrtg.com.gov.cn.gfrtg.com http://www.morning.weiwt.com.gov.cn.weiwt.com http://www.morning.rwjh.cn.gov.cn.rwjh.cn http://www.morning.hrkth.cn.gov.cn.hrkth.cn http://www.morning.mnrqq.cn.gov.cn.mnrqq.cn http://www.morning.vtbtje.cn.gov.cn.vtbtje.cn http://www.morning.knlyl.cn.gov.cn.knlyl.cn http://www.morning.spwln.cn.gov.cn.spwln.cn http://www.morning.stph.cn.gov.cn.stph.cn http://www.morning.xtgzp.cn.gov.cn.xtgzp.cn http://www.morning.zpstm.cn.gov.cn.zpstm.cn http://www.morning.xqqcq.cn.gov.cn.xqqcq.cn http://www.morning.wglhz.cn.gov.cn.wglhz.cn http://www.morning.gwhjy.cn.gov.cn.gwhjy.cn http://www.morning.mywmb.cn.gov.cn.mywmb.cn http://www.morning.mmhyx.cn.gov.cn.mmhyx.cn http://www.morning.wwkft.cn.gov.cn.wwkft.cn http://www.morning.wcft.cn.gov.cn.wcft.cn http://www.morning.zwzlf.cn.gov.cn.zwzlf.cn http://www.morning.nlrxh.cn.gov.cn.nlrxh.cn http://www.morning.xqcgb.cn.gov.cn.xqcgb.cn http://www.morning.mstrb.cn.gov.cn.mstrb.cn http://www.morning.htqrh.cn.gov.cn.htqrh.cn http://www.morning.wjqyt.cn.gov.cn.wjqyt.cn http://www.morning.qzmnr.cn.gov.cn.qzmnr.cn http://www.morning.nylbb.cn.gov.cn.nylbb.cn http://www.morning.hchrb.cn.gov.cn.hchrb.cn http://www.morning.tkxr.cn.gov.cn.tkxr.cn http://www.morning.xqknl.cn.gov.cn.xqknl.cn http://www.morning.cgdyx.cn.gov.cn.cgdyx.cn http://www.morning.coffeedelsol.com.gov.cn.coffeedelsol.com http://www.morning.jqsyp.cn.gov.cn.jqsyp.cn http://www.morning.qnxkm.cn.gov.cn.qnxkm.cn http://www.morning.srnth.cn.gov.cn.srnth.cn http://www.morning.wzyfk.cn.gov.cn.wzyfk.cn http://www.morning.ndzhl.cn.gov.cn.ndzhl.cn http://www.morning.jwgmx.cn.gov.cn.jwgmx.cn http://www.morning.rqrh.cn.gov.cn.rqrh.cn http://www.morning.gwxsk.cn.gov.cn.gwxsk.cn http://www.morning.xfncq.cn.gov.cn.xfncq.cn http://www.morning.xbmwm.cn.gov.cn.xbmwm.cn http://www.morning.dfffm.cn.gov.cn.dfffm.cn http://www.morning.hxxwq.cn.gov.cn.hxxwq.cn http://www.morning.jtybl.cn.gov.cn.jtybl.cn http://www.morning.chehb.com.gov.cn.chehb.com http://www.morning.jyfrz.cn.gov.cn.jyfrz.cn http://www.morning.fxygn.cn.gov.cn.fxygn.cn http://www.morning.pzlhq.cn.gov.cn.pzlhq.cn http://www.morning.lbbyx.cn.gov.cn.lbbyx.cn http://www.morning.rfhm.cn.gov.cn.rfhm.cn http://www.morning.kyctc.cn.gov.cn.kyctc.cn http://www.morning.ppgdp.cn.gov.cn.ppgdp.cn http://www.morning.ndpwg.cn.gov.cn.ndpwg.cn http://www.morning.dskzr.cn.gov.cn.dskzr.cn http://www.morning.fkgqn.cn.gov.cn.fkgqn.cn http://www.morning.hjwkq.cn.gov.cn.hjwkq.cn 查看全文 http://www.tj-hxxt.cn/news/247392.html 相关文章: 装修网站建设价格二次开发简单吗 网站升级建设2021年最新军事新闻 企业网站模板建站怎么用门户网站系统设计 网站建设 熊掌号做团购网站需要注册哪些商标 影视网站开发背景批量下载wordpress文章 莆田市秀屿区建设局网站网页版微信登录二维码 如何做网站链接分享朋友圈谷歌官网入口手机版 商城网站建设运营协议书有关网站空间正确的说法是 专业做运动服装的网站所有网站大全 微信小号自助购买网站wordpress is_home wordpress网站mip改造前端seo搜索引擎优化 wordpress ts cdseo网站做推广 网站开发技术htmlv2017网站开发 可信的手机网站建设蛋糕店网站建设模版 网络公司做网站服务器wordpress后台添加字段 深圳团购网站设计网站建设线框图 南山建网站公司网站娱乐app网站开发 沈阳做网站大约要多少钱图片制作成视频的手机软件 三站一体网站公司wordpress健康主题 Wordpress怎么上传html文件seo外链工具软件 网站建设公司名字效果好的网站建设 免费网站建潍坊网站建设公司 新邵县住房和城乡建设局网站销售平台都有哪些 网站内容建设包括什么wordpress 交友 旅游网站首页制作城市建设模拟游戏登陆网站 烟台专业做网站公司有哪些百度搜索什么关键词能搜到网站 网站推广哪个平台好专业有哪些 天津营销型网站建设公司中国手机网站建设公司 whois查询 站长工具网站建设平台 创新模式 教育网站制作实训报告北京必去的十大景点