当前位置: 首页> 文旅> 旅游 > 关于k8s nginx外网访问负载均衡的yaml配置文件,使用nodePort

关于k8s nginx外网访问负载均衡的yaml配置文件,使用nodePort

时间:2025/7/12 19:35:28来源:https://blog.csdn.net/ljj19910401/article/details/141398360 浏览次数:1次

在Kubernetes (k8s) 中,使用Nginx作为反向代理并通过NodePort方式暴露服务到外网是一种常见的做法。NodePort 允许你将服务暴露在每个节点的特定端口上,这样外部流量就可以通过任何节点的IP地址加上这个端口来访问服务。

以下是一个示例的YAML配置文件,它定义了一个Nginx Deployment和一个Service,该Service使用NodePort来暴露Nginx服务。

  1. Nginx Deployment YAML

首先,我们定义一个Nginx Deployment,它负责运行Nginx容器。

vim nginx-deployment.yaml apiVersion: apps/v1  
kind: Deployment  
metadata:  name: nginx-deployment  labels:  app: nginx  
spec:  replicas: 3  selector:  matchLabels:  app: nginx  template:  metadata:  labels:  app: nginx  spec:  containers:  - name: nginx  image: nginx:latest  ports:  - containerPort: 80

这个Deployment会创建3个Nginx容器的副本,每个容器都监听80端口。
2. Nginx Service YAML

接下来,我们定义一个Service,它将Nginx Deployment暴露给外部网络。

vim nginx-service.yamlapiVersion: v1  
kind: Service  
metadata:  name: nginx-service  labels:  app: nginx  
spec:  type: NodePort  ports:  - port: 80  targetPort: 80  nodePort: 30007  protocol: TCP  selector:  app: nginx

在这个Service配置中:

type: NodePort 指定了Service的类型为NodePort,这意呀着服务将被暴露在每个节点的指定端口上。
port: 80 是Service的端口,即集群内部访问这个Service时使用的端口。
targetPort: 80 指定了流量应该被转发到的容器端口。
nodePort: 30007 是NodePort的端口,即外部访问这个Service时使用的端口。这个端口号需要在Kubernetes集群的节点上可用,并且范围通常是30000-32767。
protocol: TCP 指定了协议类型。
selector 定义了Service如何选择Pods,这里它选择了所有带有app: nginx标签的Pods。

部署

你可以使用kubectl命令行工具来部署这些YAML文件:

kubectl apply -f nginx-deployment.yaml  
kubectl apply -f nginx-service.yaml

访问

部署完成后,你可以通过任何Kubernetes节点的IP地址加上nodePort端口(在这个例子中是30007)来访问Nginx服务。例如,如果你的一个节点IP是192.168.1.100,那么你可以通过http://192.168.1.100:30007来访问Nginx服务。

请注意,由于Kubernetes的负载均衡和路由机制,即使你通过某个特定节点的IP和端口访问服务,流量也可能被转发到集群中的其他节点上的Pod上。

关键字:关于k8s nginx外网访问负载均衡的yaml配置文件,使用nodePort

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: