k8s环境排查nginx转发nacos请求失败问题

一、问题背景

k8s部署两个服务,一个nginx,一个nacos, 服务信息如下(nacos有两个端口):

服务 serviceName service类型 port targetPort nodePort
nginx monitor-cp-nginx NodePort 80 80 31082
nacos monitor-cp-nacos ClusterIP 8848 8848 -
nacos monitor-cp-nacos ClusterIP 9848 9848 -

ng的default.conf配置文件关于nacos部分(将请求转发到nacos):

预期效果:

当请求nginx:服务器IP:31082/nacos时候,ng将请求代理到nacos服务,此时显示nacos的登录页面。

问题出现在请求nginx:服务器IP:31082/nacos时,并没有出现nacos的页面。

二、问题排查

2.1 错误日志

进入nginx容器查看日志,日志目录:/var/log/nginx下的error.log显示内容:

日志显示连接nacos服务失败。

2.2 验证网络

进入nginx容器,验证下网络是否畅通:

确实是连接不上。

2.3 排查nacos服务

2.3.1 确保pod正常运行

执行 kubectl get pod -n oap-dev | grep nacos,可以看到pod是running状态:

2.3.2 检查service服务

执行kubectl get svc -n oap-dev | grep nacos

可以看到两个端口88489848,没有问题。

此处的端口显示的是yaml文件中port字段值。

2.3.3 检查endpoint服务

执行kubectl get ep -n oap-dev | grep nacos

查看两个端口,此处的端口值是yaml文件中的targetPort字段值。

这两个端口值与规划值不符,应该也是8848和9848。(应该是之前执行了一个错误yaml文件,所以才导致端口与规划不符)

至此发现问题所在,将nacos.yaml文件中targetPort的值修改过来,重新执行kubectl apply -f nacos.yaml

三、验证

访问:服务器IP:31082/nacos,页面正常显示:

相关推荐
为什么不问问神奇的海螺呢丶34 分钟前
n9e categraf docker 监控配置
运维·docker·容器
青树寒鸦35 分钟前
wsl的docker备份mongo和迁移
运维·mongodb·docker·容器
伟大的大威1 小时前
NVIDIA DGX Spark (ARM64/Blackwell) Kubernetes 集群 + GPU Operator 完整部署指南
大数据·spark·kubernetes
爱宇阳3 小时前
WSL2 完整开发环境配置指南
容器
qinyia3 小时前
**使用AI助手在智慧运维中快速定位并修复服务异常:以Nginx配置错误导致502错误为例**
linux·运维·服务器·数据库·mysql·nginx·自动化
hopsky3 小时前
Docker Desktop 报 500
运维·docker·容器
only_Klein3 小时前
kubernetes Pod 通信过程演示
网络·kubernetes·tcpdump
曦云沐3 小时前
一键部署ROS2开发环境!Docker run命令详解与实战
docker·容器·ros2
404Clukay3 小时前
Windows Server 配置 Let‘s Encrypt 免费 HTTPS 证书(WACS + Nginx 自动化方案)
windows·nginx·https
为什么不问问神奇的海螺呢丶3 小时前
n9e categraf k8s监控配置 -cadvisor
云原生·容器·kubernetes