k8s中的service组件

背景

service组件是k8s中类似于nginx网关的入口,通过它可以访问到背后的pod提供的服务,并且自带负载均衡的功能,本文就简单看下service组件

k8s中的service组件

假设我们要配置一个tomcat的service集群,配置步骤如下

1.首先我们要创建tomcat的pod,内部打开了端口8080,映射到宿主机8090端口中,配置文件如下

xml 复制代码
kind: pod  --pod类型
metadata:
	labels:
		name: tomcat-pod --pod的label名称
spec:
	containers:
		name: tomcat --pod中docker容器名称
		image: tomcat --tomcat docker容器的镜像
		ports:
			containerport:8080 --pod中tomcat容器内部端口
			hostport:8090      --pod中tomcat容器端口对应的宿主机的端口

2.创建service组件,打开端口80,通过serviceIp:80可以访问到后端的pod服务,配置文件如下:

xml 复制代码
kind: service   --service组件类型
spec:
	selector:
		name:tomcat-pod  --选择的pod的label标识
		ports:
			port:80	--service的访问端口

当完成以上步骤后,k8s会给service组件分配一个独一无二的ip,而且是长期有效的,通过这个serviceIp和service对外的80端口,使用方就可以访问到后端的pod服务了。

k8s实现service组件的方式是在集群的每个节点上都安装了一个kube-proxy代理,它会负责设置iptables路由规则,保证访问service的流量可以正确的代理到对应的pod上面。

使用方pod中如何使用service服务?

当使用方pod使用到对应的service时,会把service的ip和端口通过环境变量的方式设置到使用方pod的环境变量中,如此使用方pod就可以把对service的访问变成访问serviceIp:port的形式

相关推荐
赵鑫亿2 小时前
ClawPanel — 开源 OpenClaw 智能管理面板,20+ 通道接入 / 多模型配置 / Docker 一键部署
docker·容器·开源
杨云龙UP2 小时前
Windows Server 2012 环境下 Oracle 11.2 使用 expdp 实现自动备份、异地复制与定期清理_20260504
服务器·数据库·windows·mysql·docker·oracle·容器
切糕师学AI3 小时前
Docker CE 与 Docker Compose 详解:容器化引擎与多容器编排
docker·容器
红球yyds3 小时前
Kubernetes 简介及部署方法
云原生·容器·kubernetes
ezreal_pan3 小时前
Docker部署Kafka持久化遇到的各种问题及解决方案
docker·容器·kafka
IT邦德3 小时前
26ai OGG 微服务高可用部署及切换
微服务·云原生·架构
AI攻城狮3 小时前
上下文窗口不是你的问题,你塞进去的东西才是——RAG 精排技术深度解析
云原生
.柒宇.14 小时前
AI掘金头条项目-K8s部署实战教程
python·云原生·容器·kubernetes·fastapi
AI攻城狮14 小时前
DeepSeek V4:LLM 世界的"好又多"超市
云原生
AI精钢15 小时前
AI Agent 从上线到删库跑路始末
网络·人工智能·云原生·aigc