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. 适用于需要稳定网络标识的有状态应用(如数据库集群)。
相关推荐
问简2 小时前
docker 镜像相关
运维·docker·容器
Benszen3 小时前
Docker容器化技术实战指南
运维·docker·容器
lin_dec+4 小时前
Serverless:零成本按需计算的未来
云原生·serverless
Hommy884 小时前
【开源剪映小助手】Docker 部署
docker·容器·开源·github·aigc
斯普信云原生组6 小时前
Prometheus 环境监控虚机 Redis 方案(生产实操版)
运维·docker·容器
喵了几个咪6 小时前
如何在 Superset Docker 容器中安装 MySQL 驱动
mysql·docker·容器·superset
工具罗某人6 小时前
docker compose部署kafka集群搭建
docker·容器·kafka
迷藏4946 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
刘~浪地球6 小时前
架构设计--事件驱动架构设计与实现(05)
云原生·系统架构·云计算
鬼先生_sir6 小时前
Zookeeper:从入门到精通
分布式·zookeeper·云原生