k8s通过域名访问 StatefulSet的pod

以下是实现通过域名访问 Kubernetes StatefulSet Pod 的完整配置:

bash 复制代码
apiVersion: v1
kind: Service
metadata:
  name: nginx
  namespace: default
spec:
  clusterIP: None
  selector:
    app: nginx
  ports:
    - port: 80
      name: web
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: web
  namespace: default
spec:
  serviceName: "nginx"
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
        - name: nginx
          image: nginx
          ports:
            - containerPort: 80
          volumeMounts:
            - name: www
              mountPath: /usr/share/nginx/html
  volumeClaimTemplates:
    - metadata:
        name: www
      spec:
        accessModes: [ "ReadWriteOnce" ]
        storageClassName: "standard"
        resources:
          requests:
            storage: 1Gi
  1. 创建无头服务(Headless Service):通过设置 clusterIP: None 实现 DNS 解析,不使用负载均衡。
  2. 定义 StatefulSet:关联无头服务 serviceName: "nginx",自动为每个 Pod 生成唯一 DNS 名称。
  3. 生成 DNS 域名:Pod 名称格式为 web-0.nginx.default.svc.cluster.local,支持直接通过域名访问。
  4. 持久化存储:通过 volumeClaimTemplates 自动为每个 Pod 绑定独立 PV,确保数据持久化。
  5. 有序部署:StatefulSet 按序号创建 Pod,确保依赖关系正确处理。

使用说明:

  1. 部署后,可通过 web-0.nginx.default.svc.cluster.local 访问第一个 Pod。
  2. 支持 DNS 解析,无需手动配置 IP 地址。
  3. 适用于需要稳定网络标识的有状态应用(如数据库集群)。
相关推荐
米高梅狮子16 分钟前
Redis
数据库·redis·mysql·缓存·docker·容器·github
汪汪大队u38 分钟前
基于 K8s 的物联网平台运维体系:Ansible+Zabbix 自动化监控与故障自愈(三)—— Zabbix Server 启动排错记
运维·kubernetes·ansible
代码熬夜敲Q1 小时前
Docker基础
运维·docker·容器
亚空间仓鼠1 小时前
Docker容器化高可用架构部署方案(十四)
docker·容器·架构
平行云2 小时前
实时云渲染平台数据通道,支持3D应用文件上传下载分享无缝交互
linux·unity·云原生·ue5·gpu算力·实时云渲染·像素流送
日取其半万世不竭2 小时前
OpenCost:Kubernetes 成本监控,开源的云资源费用分析
容器·kubernetes·开源
姚不倒2 小时前
Go 进阶实战:实现泛型数据验证器
云原生·golang
万里侯2 小时前
Ansible自动化运维实战:从入门到生产级应用
微服务·容器·k8s
Cat_Rocky2 小时前
k8s zabbix7学习-设置告警
学习·容器·kubernetes
容器魔方4 小时前
华为云云容器引擎CCE 2026-Q1优化升级,全面进化您的云原生体验!
大数据·分布式·云原生·容器·云计算