【k8s】svc-headless
环境
- kubernetes 1.20.4
- Spring Boot 2.5.0-M3
目标
在 k8s 的 Service 的使用过程中,有一种比较特殊的 Service,叫做 headless。
它与其它 Service 的最大区别就是不提供负载均衡 IP,而是直接走 DNS 记录。
并且它和 sts 结合,还可以访问到固定的某个 Pod。
示例
StatefulSet.yaml
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: spring-k8s
spec:
serviceName: spring-k8s
selector:
matchLabels:
app: spring-k8s
replicas: 2
template:
metadata:
labels:
app: spring-k8s
spec:
containers:
- name: spring-k8s
image: jiangbo920827/spring-k8s:liveness
ports:
- containerPort: 8080
Service.yaml
apiVersion: v1
kind: Service
metadata:
name: spring-k8s
spec:
clusterIP: None
selector:
app: spring-k8s
ports:
- port: 80
targetPort: 8080
查看全部地址
[root@master ~]# nslookup spring-k8s.default.svc.cluster.local 10.96.0.10
Server: 10.96.0.10
Address: 10.96.0.10#53
Name: spring-k8s.default.svc.cluster.local
Address: 10.244.2.6
Name: spring-k8s.default.svc.cluster.local
Address: 10.244.2.5
可以看到,根据服务名访问时,会得到两个 IP 地址。
指定访问 Pod
[root@master ~]# nslookup spring-k8s-0.spring-k8s.default.svc.cluster.local 10.96.0.10
Server: 10.96.0.10
Address: 10.96.0.10#53
Name: spring-k8s-0.spring-k8s.default.svc.cluster.local
Address: 10.244.2.5
[root@master ~]# nslookup spring-k8s-1.spring-k8s.default.svc.cluster.local 10.96.0.10
Server: 10.96.0.10
Address: 10.96.0.10#53
Name: spring-k8s-1.spring-k8s.default.svc.cluster.local
Address: 10.244.2.6
加上 Pod 的名称和服务名,就可以直接访问到具体的某个 Pod。
总结
headless 不提供负载均衡的 IP 地址,和 sts 结合可以访问指定的 Pod。
附录
分类:
Kubernetes
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2020-05-30 JavaWeb:Filter