StatefulSet的每个Pod单独创建Service实践

 更新时间:2026年01月16日 09:02:10   作者:CN-FuWei  
本文介绍了如何为StatefulSet的每个Pod创建独立的Service,并提供了一个示例脚本,以批量生成Service定义,通过这种方式,可以实现从集群外部访问每个Pod的功能,并且可以根据需要配置不同的Service类型(如NodePort、LoadBalancer、ClusterIP+Ingress等)

一、实现目标

假设我们有一个 StatefulSet,名称为 my-db,其 Pod 名为:

my-db-0.my-db.default.svc.cluster.local
my-db-1.my-db.default.svc.cluster.local
...

我们想为每个 Pod 创建一个对应的 Service,让它们可以被集群外访问,如:

  • my-db-0 → 可通过 db0.example.com或 <NodeIP>:<port>访问
  • my-db-1 → 可通过 db1.example.com或 <NodeIP>:<port>访问

二、操作步骤

2.1 创建 StatefulSet(示例)

先假设你已经有如下 StatefulSet(这里以简单的 nginx 为例):

apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: my-db
spec:
  serviceName: "my-db"
  replicas: 3
  selector:
    matchLabels:
      app: my-db
  template:
    metadata:
      labels:
        app: my-db
    spec:
      containers:
      - name: nginx
        image: nginx
        ports:
        - containerPort: 80

配套的 Headless Service(必须):

apiVersion: v1
kind: Service
metadata:
  name: my-db
spec:
  clusterIP: None
  selector:
    app: my-db
  ports:
  - port: 80
    targetPort: 80

2.2 为每个 Pod 创建独立 Service

我们可以写一个循环或使用 Helm 模板等方式批量生成 YAML,这里我手动展示前两个 Pod 的 Service 定义(my-db-0-svc和 my-db-1-svc)。

示例:为每个 Pod 创建 NodePort 类型的 Service

# Service for my-db-0
apiVersion: v1
kind: Service
metadata:
  name: my-db-0-svc
spec:
  selector:
    statefulset.kubernetes.io/pod-name: my-db-0
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
      nodePort: 30001   # 可选指定,范围 30000–32767
  type: NodePort
---
# Service for my-db-1
apiVersion: v1
kind: Service
metadata:
  name: my-db-1-svc
spec:
  selector:
    statefulset.kubernetes.io/pod-name: my-db-1
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
      nodePort: 30002
  type: NodePort
---
# Service for my-db-2
apiVersion: v1
kind: Service
metadata:
  name: my-db-2-svc
spec:
  selector:
    statefulset.kubernetes.io/pod-name: my-db-2
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
      nodePort: 30003
  type: NodePort

说明:

  • statefulset.kubernetes.io/pod-name: 这是一个 Kubernetes 内置的标签,表示 Pod 是由哪个 StatefulSet 创建的以及它的序号。
  • 我们通过这个 label selector 精确地选中某一个 Pod。
  • 每个 Service 都通过 NodePort 暴露出去,也可以替换为 LoadBalancer 或 ClusterIP+Ingress。

2.3 从集群外部访问

例如:

  • 访问 my-db-0:http://<NodeIP>:30001
  • 访问 my-db-1:http://<NodeIP>:30002

你也可以配置域名解析,将 db0.example.com 指向 <NodeIP>:30001,依此类推。

自动生成多个 Service(Shell 脚本方式)

当 Pod 数量较多时,可以使用脚本来生成 YAML 文件。例如:

for i in 0 1 2; do
cat <<EOF | kubectl apply -f -
apiVersion: v1
kind: Service
metadata:
  name: my-db-${i}-svc
spec:
  selector:
    statefulset.kubernetes.io/pod-name: my-db-${i}
  ports:
    - protocol: TCP
      port: 80
      targetPort: 80
      nodePort: 3000$((i+1))
  type: NodePort
EOF
done

补充:使用 Headless + External DNS + Ingress 等组合

对于更复杂的场景,还可以:

  • 使用 Ingress + 自定义 Host 匹配不同后端 Service
  • 使用 external-dns 自动注册 DNS 记录
  • 使用 Istio 等服务网格进行流量管理

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于CentOS7日志文件及journalctl日志查看方法

    关于CentOS7日志文件及journalctl日志查看方法

    这篇文章主要介绍了关于CentOS7日志文件及journalctl日志查看方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • K8S 使用EFK日志的统一管理(详细步骤)

    K8S 使用EFK日志的统一管理(详细步骤)

    在Kubernetes中,EFK是一种常见的日志统一管理方案,EFK堆栈允许你收集、存储、搜素、分析和可视化容器应用程序的日志,下面是如何在Kubernetes中使用EFK实现日志统一管理的详细步骤,感兴趣的朋友一起看看吧
    2025-01-01
  • k8s之安全机制的使用及说明

    k8s之安全机制的使用及说明

    Kubernetes的安全机制主要围绕保护APIServer来设计,包括认证、鉴权和准入控制三部分,认证通过Token、Basic和HTTPS证书进行,鉴权使用AlwaysDeny、AlwaysAllow、ABAC、WebHook和RBAC,准入控制通过插件进行
    2025-11-11
  • helmfile声明式部署Helm Chart使用详解

    helmfile声明式部署Helm Chart使用详解

    这篇文章主要为大家介绍了helmfile声明式部署Helm Chart使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • Kubernetes DNS解析实战过程

    Kubernetes DNS解析实战过程

    Kubernetes中,Pod需Ready状态才会被CoreDNS解析,而Service创建时即添加记录,当服务依赖Pod解析时易引发启动死循环,通过设置Service的publishNotReadyAddresses为true,可解决此问题,允许未就绪Pod的IP立即被解析
    2025-09-09
  • 一篇文章搞懂K8S高级特性

    一篇文章搞懂K8S高级特性

    这篇文章主要给大家介绍了关于K8S高级特性的相关资料,文中通过时实例代码以及图文介绍的非常详细,对大家学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-11-11
  • K8S 中 kubectl 命令详解

    K8S 中 kubectl 命令详解

    这篇文章主要介绍了K8S 中 kubectl 命令,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • Kubernetes集群环境初始化

    Kubernetes集群环境初始化

    这篇文章介绍了Kubernetes集群环境初始化的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • K8S集群卸载清理的完整步骤流程

    K8S集群卸载清理的完整步骤流程

    在Kubernetes(简称K8S)的生命周期中,可能会遇到需要卸载和清理集群的情况,本文将详细介绍如何安全地卸载K8S集群,并清理所有相关的资源,需要的可以了解下
    2025-08-08
  • K8S 实用工具之合并多个kubeconfig实现详解

    K8S 实用工具之合并多个kubeconfig实现详解

    这篇文章主要为大家介绍了K8S 实用工具之合并多个kubeconfig实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03

最新评论