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

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

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

  1. Nginx Deployment YAML

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

yaml 复制代码
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端口。

  1. Nginx Service YAML

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

yaml 复制代码
vim nginx-service.yaml

apiVersion: 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文件:

bash 复制代码
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上。

相关推荐
码点滴2 小时前
Workload 自动化进化论:从手动运维到 AI 驱动的 Kubernetes 智能管控
运维·人工智能·kubernetes·自动化·workload
魏杨杨4 小时前
被流量逼出来的架构:从一台服务器到云原生的 17 次蜕变 —— 集群、缓存、MQ、微服务、Docker、K8S 的前世今生
微服务·k8s·负载均衡·ddd·分部署
Waay5 小时前
图文详解|K8s Pod内部结构
docker·云原生·kubernetes
码点滴5 小时前
CRI-O选型与容器运行时标准
开发语言·人工智能·架构·kubernetes·cri-o
難釋懷6 小时前
Nginx虚拟主机
git·nginx·github
前端 贾公子7 小时前
基于 Nginx 实现一个灰度上线系统
运维·nginx
鱼听禅10 小时前
CentOS使用Nginx配置代理Gitea后网址设置正确,确保URL不匹配的问题记录
nginx·centos·gitea
Jinkxs11 小时前
LoadBalancer- 简单限流策略:Nginx 基于连接 / 请求的限流实现
java·运维·nginx
牛奶咖啡1311 小时前
k8s容器编排技术实践——OpenEuler安装部署k8s
kubernetes·信创·containerd配置加速器·openeuler安装k8s·k8s的常见安装方式·彻底关闭swap·工作节点使用kubectl
老码观察11 小时前
K8s 容器化部署的宿主机资源规划的踩坑实录
docker·容器·kubernetes