当前位置: 首页 > news >正文

k8s-第五节-StatefulSet

StatefulSet

StatefulSet 是用来管理有状态的应用,例如数据库。

前面我们部署的应用,都是不需要存储数据,不需要记住状态的,可以随意扩充副本,每个副本都是一样的,可替代的。
而像**数据库、Redis **这类有状态的,则不能随意扩充副本。

StatefulSet 会固定每个 Pod 的名字

apiVersion: apps/v1
kind: StatefulSet
metadata:name: mongodb
spec:serviceName: mongodbreplicas: 3selector:matchLabels:app: mongodbtemplate:metadata:labels:app: mongodbspec:containers:- name: mongoimage: mongo:4.4# IfNotPresent 仅本地没有镜像时才远程拉,Always 永远都是从远程拉,Never 永远只用本地镜像,本地没有则报错imagePullPolicy: IfNotPresent
---
# 定义 HeadLess service
apiVersion: v1
kind: Service
metadata:name: mongodb
spec:selector:app: mongodbtype: ClusterIP# HeadLess 就不再给Service分配IP了,通过pod名字访问clusterIP: Noneports:- port: 27017targetPort: 27017

StatefulSet 特性

  • Service 的 CLUSTER-IP 是空的,Pod 名字也是固定的。
  • Pod 创建和销毁是有序的,创建是顺序的,销毁是逆序的,可以从创建的序号看出来0,1,2,3…。
  • Pod 重建不会改变名字,除了IP,所以不要用IP直连.

创建 statefulset 会在endpoints 多一个 hostname,用于service和pod之间做dns指向

  • 访问时,如果直接使用 Service 名字连接,会随机转发请求连接指定 Pod,可以这样pod-name.service-name

测试连接

运行一个临时 Pod 连接数据测试下
kubectl run mongodb-client --rm --tty -i --restart='Never' --image docker.io/bitnami/mongodb:4.4.10-debian-10-r20 --command -- bash

进去bash 后 使用

mongo --host mongodb 为随机转发连接mongodb service下的pod
mongo --host mongodb-0.mongodb 为直接连接mongodb-0 pod

http://www.lryc.cn/news/392720.html

相关文章:

  • ai机器狗
  • 数据库关键字执行顺序
  • Linux 永久挂载磁盘
  • windows启动Docker闪退Docker desktop stopped
  • 探索Redis GEOMETRY数据结构:地理空间索引与查询(基于Redis GEO和Java实现附近商户查找功能)
  • DP学习——策略模式
  • 0701_ARM5
  • Python用户宝典:了解并实现遗传算法
  • 如何使用深度学习进行实时目标检测:速度与精度的双重挑战
  • 创新引领,构筑产业新高地
  • npm,yarn清楚缓存
  • httpclient访问https请求报错处理
  • ffmpeg + opencv 把摄像头画面保存为mp4文件(Ubuntu24.04)
  • Fastapi 项目第二天首次访问时数据库连接报错问题Can‘t connect to MySQL server
  • 尚硅谷k8s 2
  • 机器学习---线性回归
  • 字符串去重、集合遍历 题目
  • SQL窗口函数详解
  • 如何用Java写一个整理Java方法调用关系网络的程序
  • 基于STM32设计的管道有害气体检测装置(ESP8266局域网)176
  • iCloud照片库全指南:云端存储与智能管理
  • IDEA中使用Maven打包及碰到的问题
  • TreeMap、HashMap 和 LinkedHashMap 的区别
  • 【跟我学K8S】45天入门到熟练详细学习计划
  • ubuntu下载Nginx
  • 【区分vue2和vue3下的element UI Dialog 对话框组件,分别详细介绍属性,事件,方法如何使用,并举例】
  • docker push 推送镜像到阿里云仓库
  • 伯克利、斯坦福和CMU面向具身智能端到端操作联合发布开源通用机器人Policy,可支持多种机器人执行多种任务
  • 昇思25天学习打卡营第17天(+1)|Diffusion扩散模型
  • 【Leetcode笔记】406.根据身高重建队列