k8s中Service暴露的种类以及用法

一、说明

在 Kubernetes 中,有几种不同的方式可以将服务(Service)暴露给外部流量。这些方式通过定义服务的 spec.type 字段来确定。
二、详解
1. ClusterIP

定义:默认类型,服务只能在集群内部访问。

作用:通过集群内部 IP 地址暴露服务。

示例:

yaml 复制代码
spec:
  type: ClusterIP
  ports:
    - port: 80
      targetPort: 8080

2.NodePort

定义:在每个节点上开放一个高端口(通常是 30000-32767),允许外部流量访问服务。

作用:通过任意节点的 IP 地址和 nodePort 访问服务。

示例:

yaml 复制代码
spec:
  type: NodePort
  ports:
    - port: 80
      targetPort: 8080
      nodePort: 30007

3. LoadBalancer

定义:云平台提供的负载均衡器会为服务分配一个外部 IP 地址。

作用:通过该 IP 地址访问服务,适合需要外部流量负载均衡的情况。

示例:

yaml 复制代码
spec:
  type: LoadBalancer
  ports:
    - port: 80
      targetPort: 8080
  selector:
    app: my-app

4. ExternalName

定义:将服务映射到一个外部域名(例如数据库服务)。

作用:通过指定的外部域名访问服务,而不是通过集群内部 IP 或节点 IP。

示例:

yaml 复制代码
spec:
  type: ExternalName
  externalName: example.com

二、总结

ClusterIP:默认的服务类型,仅在集群内部可访问。

NodePort:在每个节点上开放一个端口,允许外部流量访问服务。

LoadBalancer:云平台提供的负载均衡器分配一个外部 IP 地址,适合需要负载均衡的情况。

ExternalName:将服务映射到一个外部域名,适用于需要访问外部服务的场景。

相关推荐
眠りたいです31 分钟前
基于脚手架微服务的视频点播系统-播放控制部分
c++·qt·ui·微服务·云原生·架构·播放器
Ribou37 分钟前
Ubuntu 24.04.2安装k8s 1.33.4 配置cilium
linux·ubuntu·kubernetes
Mr. Cao code2 小时前
Docker:颠覆传统虚拟化的轻量级革命
linux·运维·ubuntu·docker·容器
Dontla2 小时前
Docker多共享网络配置策略(Docker多网络、Docker networks、Docker Compose网络、Docker网络、Docker共享网络)
网络·docker·容器
Jayin_chan3 小时前
paddlex3.0.1-ocr服务化安装部署(docker)
docker·容器·ocr
ifanatic3 小时前
[每周一更]-(第159期):Go 工程师视角:容器化技术(Docker/Kubernetes)与CI/CD流程的应用场景
docker·golang·kubernetes
程序猿阿伟5 小时前
《云原生微服务治理进阶:隐性风险根除与全链路能力构建》
微服务·云原生·架构
LuiChun7 小时前
docker desktop更新到【4.45.0 】后,旧容器镜像都丢失了
docker·容器·dubbo
Sweety丶╮7948 小时前
【Ansible】实施 Ansible Playbook知识点
服务器·云原生·ansible
ZLRRLZ8 小时前
【Docker】Docker安装
运维·docker·容器