k8s-----12、controller-StatefulSet

news/2024/6/3 17:27:18 标签: kubernetes, 容器, 云原生

StatefulSet

  • 1、有状态和无状态的区别
    • 1.1 无状态
    • 1.2 有状态
  • 2、部署有状态应用
    • 2.1 部署要求
    • 2.2 实战部署

1、有状态和无状态的区别

1.1 无状态

  • 认为pod都是一样的
  • 随意进行伸缩和扩展
  • 没有顺序要求
  • 不用考虑在哪一个node运行

1.2 有状态

  • 无状态的因素都需要考虑到
  • 让每个pod独立,保持Pod启动顺序和唯一性。如唯一的网络标识符或者持久存储。有序状态,如mysql主从。

2、部署有状态应用

2.1 部署要求

  • 首先需要创建一个无头service,即clusterIP: None
  • deployment和statefulSet的区别是:有身份的(唯一标识)
  • 每一个pod有唯一的主机名。
  • 每一个pod有唯一域名。域名规则:主机名称.service名称.名称空间.svc.cluster.local

2.2 实战部署

[root@master controlleryaml]# vim sts.yaml 

apiVersion: v1
kind: Service
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  ports:
  - port: 80
    name: web
  clusterIP: None      ##首先创建的无头service
  selector:
    app: nginx

---

apiVersion: apps/v1
kind: StatefulSet    ##创建带有statefulSet的有状态控制器
metadata:
  name: nginx-statefulset
  namespace: default
spec:
  serviceName: nginx
  replicas: 3    # 3个会顺序启动
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80
[root@master controlleryaml]# kubectl apply -f sts.yaml
[root@master controlleryaml]# kubectl get pods   #查看pod 的唯一标识
NAME                  READY   STATUS    RESTARTS   AGE
nginx-statefulset-0   1/1     Running   0          70s
nginx-statefulset-1   1/1     Running   0          67s
nginx-statefulset-2   1/1     Running   0          51s

[root@master controlleryaml]# kubectl get  svc     # 查看service
NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   61d
nginx        ClusterIP   None         <none>        80/TCP    92s   # None的无头service



http://www.niftyadmin.cn/n/5114852.html

相关文章

k8s集群镜像下载加gradana监控加elk日志收集加devops加秒杀项目

展示 1.配套资料2.devops 3.elk日志收集 4.grafana监控 5.dashboard![在这里插入图片描述](https://img-blog.csdnimg.cn/bf294f9fd98e4c038858a6bf5c34dbdc.png 目的 学习k8s来来回回折腾很久了&#xff0c;光搭个环境就能折腾几天。这次工作需要终于静下心来好好学习了一…

快速解决“msvcp110.dll丢失”问题,msvcp110.dll丢失修复分享

解决"msvcp110.dll丢失"问题的方法 在计算机使用过程中&#xff0c;我们可能会遇到各种问题。其中&#xff0c;“msvcp110.dll丢失”是一个常见的错误&#xff0c;通常出现在运行某些软件或游戏时。这个错误不仅会打断我们的工作或娱乐&#xff0c;而且可能对我们的…

Python【列表的反转与排序】

目录 要求&#xff1a;列表的反转 列表的排序 列表的反转&#xff1a; 方案一&#xff1a;使用reverse()方法&#xff1a;它会直接修改原始列表&#xff0c;进行反转。 方案二&#xff1a;还是使用reversed()函数&#xff1a;该函数返回一个反转后的迭代器对象&#xff0c…

短视频矩阵系统源码/源头搭建技术交付

一、短视频矩阵系统&#xff0c;短视频矩阵源码技术 1、抖音开放平台申请账号&#xff0c;快手平台申请账号&#xff1b;阿里云混剪接口。 2、系统总台支持OEM代理&#xff0c;可以按点数管理。 3、代理功能。包括是否允许再次开二级代理、是否允许OEM等。 4、可支持一条龙…

cocos creator 小游戏允许他人访问本地项目

需求背景&#xff1a; 发版成微信小游戏前&#xff0c;需要策划介入体验。不上传微信体验版本 实现&#xff1a; 1.发布平台选择web桌面端 2.构建完成后点击运行从浏览器上获取本地的运行地址 3.winR ——》 cmd 控制台 输入 ipconfig 找到IPv4地址&#xff0c;替换本地部分 …

Qt音乐播放器

简介 使用QMediaPlayer和QMediaPlaylist制作的音乐播放器 编译环境 Qt5.6 MGW32 windows10 功能特性 GUI 功能 加载mp3文件&#xff0c;得到歌曲信息&#xff1b;打开文件夹加载或拖拽音乐文件加载滑动条关联播放进度、音量显示/隐藏歌曲列表&#xff0c;编辑歌曲列表&am…

为什么学完了 C#觉得自己什么都干不了?

为什么学完了 C#觉得自己什么都干不了&#xff1f; 俺一向的观点&#xff1a;&#xff08;1&#xff09;学跟干是两码事。学&#xff0c;你要往外掏钱或时间或两个都得掏。干&#xff0c;是你从别人兜里掏钱。&#xff08;2&#xff09;如果没有干的需求&#xff0c;那么可以啥…

跨境商城源码可以支持多种营销推广方式吗?

一、多种营销推广方式的重要性 跨境商城源码作为现代电商领域的重要工具&#xff0c;其支持多种营销推广方式对于吸引用户、增加销量以及提升品牌影响力都至关重要。通过采用多种营销推广方式&#xff0c;商家可以全方位地宣传和推广产品&#xff0c;吸引更多的潜在顾客&#x…