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. 适用于需要稳定网络标识的有状态应用(如数据库集群)。
相关推荐
小猿姐4 小时前
唯品会大规模数据库云原生实践:基于 KubeBlocks 管理数千实例的统一运维之路
运维·elasticsearch·云原生
阿里云云原生14 小时前
AgentTeams 和 Claude Tag 都进入群聊模式,是新范式还是新叙事?
云原生·agent
阿里云云原生2 天前
Higress v2.2.3 发布:正式入驻 CNCF Sandbox,AI Gateway 与 Ingress 迁移能力双向加固
云原生
lichenyang4532 天前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4532 天前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4532 天前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
阿里云云原生3 天前
香港站【企业 AI Agent 工程化实战专场】来啦,邀您7月9日见!
云原生·agent
阿里云云原生3 天前
研发域与运维域的“数字握手”:通过 Agentic Skills 实现 DevOps 全链路自动化
云原生
运维开发故事5 天前
基于 Arthas 的多集群在线诊断系统设计与实现
kubernetes
Patrick_Wilson6 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js