南强小屋 Design By 杰米

问题描述

一个Spring + Angular前后端分离的项目,使用Nginx进行数据转发。

Nginx监听端口8100,前台端口4200,后台端口8080。

解决Nginx端口冲突的排查方法示例

像往常一样,提前配置好MySQL、配置好Redis,引入项目的Nginx配置文件,然后启动前台、后台,成功。

接下来出现了问题:前台发起的请求,只有极少数能被后台接收到,大部分都是404,随着在浏览器中的点击,控制台不断的出现404。

解决Nginx端口冲突的排查方法示例

解决Nginx端口冲突的排查方法示例

如果只是404,那问题就很简单,很大可能是Nginx端口转发设置错了。但它的神奇之处就在于,还有那么几次请求,是能到达后台的。

解决Nginx端口冲突的排查方法示例

(上图中,显示保存成功的时候,后台确实输出了相关的控制台信息)

其他的小伙伴都没有出现这个问题,于是开始排查。

排查过程

为了搞清楚是 后端 的问题还是 Nginx 转发的问题,需要先从浏览器的NetWork中看一下这个404是后台返回的还是Nginx返回的。

解决Nginx端口冲突的排查方法示例

经过查看,发现是Nginx返回的。如果是后台返回的404,会把错误信息写在HTTP请求头中。

先查看监听端口是否有冲突,使用nginx -T可以查看完整的Nginx配置文件,包括引入的外部文件。

// 测试配置文件是否正确,并输出完整的配置文件
nginx -T

解决Nginx端口冲突的排查方法示例

在输出的结果中,只看到一个8100,说明虽然引入了多个项目,但并没有出现监听端口冲突。

然后笔者打算从Nginx日志中寻找一些蛛丝马迹。

开启Nginx的日志模式之后,查看日志文件,发现了上千条访问记录

解决Nginx端口冲突的排查方法示例

大多数都是404,少数是200,但日志并没有提供什么有用的信息。

最终,还是在配置文件中发现了问题:

使用HomeBrew安装的Nginx,它的全局配置文件中,默认的监听端口就是8080,而项目后端占用的端口也是8080。

解决Nginx端口冲突的排查方法示例

虽然对于端口监听和端口占用的原理不是很了解,至少可以知道,由于Nginx监听了8080端口,有一部分请求被发到了Nginx自己那里,另一部分才是发送到后台。

所以,修改全局配置文件,改掉默认端口,问题解决。

解决Nginx端口冲突的排查方法示例

// 修改配置文件
sudo vim /usr/local/etc/nginx/nginx.conf
// 测试配置文件
nginx -t
// 重启Nginx
nginx -s reload

终于,所有的请求都能达到后台了。

解决Nginx端口冲突的排查方法示例

总结

在一开始学习XAMPP的时候,就经常听到:“如果80端口冲突,就把端口改掉,比如改成8080”。

可是当8080成为了我们的习惯之后,有些项目也会使用这个端口...因此就要解决冲突问题了。

以后更改默认端口的时候,建议改成一个不可能用到的端口,比如10000以上的端口号,避免和项目的端口产生冲突。

标签:
Nginx端口冲突排查,Nginx端口冲突

南强小屋 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
南强小屋 Design By 杰米

评论“解决Nginx端口冲突的排查方法示例”

暂无解决Nginx端口冲突的排查方法示例的评论...

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?