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】win10 wsl docker不能挂GPU
运维·docker·容器·wsl
Bonnie3732 小时前
云边端一体化解析-什么是云边端,为何能成为AI基础设施核心
人工智能·程序人生·云原生·个人开发
江畔何人初2 小时前
Docker、containerd、CRI、shim 之间的关系
运维·docker·云原生·容器·kubernetes
万象.4 小时前
docker镜像仓库
运维·docker·容器
2401_891655815 小时前
Git + 云原生:如何管理K8s配置版本?
git·云原生·kubernetes
2401_844221325 小时前
深入理解K8s中的应用服务:访问、集群与配置
容器·kubernetes·php
vpk1126 小时前
Docker 安装与常用命令
运维·docker·容器
Volunteer Technology7 小时前
zookeeper基础应用与实战二
分布式·zookeeper·云原生
vpk1127 小时前
Docker Compose 安装 MySQL 8
mysql·容器
FJW0208147 小时前
cephadm部署ceph集群以及k8s对接
ceph·容器·kubernetes