nginx公网IP无法访问浏览器
配置服务器时候发现的问题,真的是搜肠刮肚的找答案,找一下午,终于找到了答案。
一、开始找原因
在浏览器输入:http://ip,正常的话,会有页面,welcome to nginx
我这里是浏览器访问失败,
查找原因:
1、在服务器上访问Ip
执行:curl http://ip
结果:超时,未连接成功
查看nginxaccess.log日志,发现日志未滚动,代表本机访问不到公网ip
2、确认网络是否可达
telnet 12x.xx.x.xx 80
Trying 12x.xx.x.xx...
Connected to 12x.xx.x.xx.
Escape character is '^]'.
- 1
- 2
- 3
- 4
这样就说明网络上可达,并且TCP三次握手可以完成,因为能telnet通,排除了网络不通的情况
但是我本地的网络不通。
3、是否受防火墙安全控制等。
将iptables和selinux关闭
以下4条命令清除iptables的配置
iptables -F
iptables -F -t nat
iptables -X
iptables -X -t nat
- 1
- 2
- 3
- 4
setenforce 0 #关闭selinux
重新远程访问,还是失败。说明不是防火墙的原因。这里因为我是debian,所以默认是没有开启防火墙的,所以不是这个原因。
4、去/var/log/nginx/error.log查看错误日志
日志报错:Address already in use
这里就已经确认错误在哪了,原来是80端口被占用的问题。
5、解决方案
1)执行:lsof -i:80 查看此时哪个进程正在使用80端口
我这边发现是阿里云盾正在使用80端口
2)杀掉云盾进程,重启nginx试试
kill -s 9 pid
具体参考博客:http://blog.csdn.net/ljfphp/article/details/78666376
6、好吧,惊奇的发现,通过浏览器还是访问不了nginx,但是此刻我的80端口已经被nginx监听了。继续查看错误日志。错误日志并没刷新。
7、百度发现有人说是iptables防火墙的原因,但是debian系统的安装默认是没有iptables,所以应该不是防火墙的原因。
8、看到有人说,是没有备案域名的原因,80端口默认是关闭状态。好吧,我准备改成8080端口,看看能不能行吧。(这个没来得及试)
二、真正的凶手
终于找到问题了,眼泪差点掉下来。原来是阿里云的问题。我刚开通的服务器,没有设置安全组规则。下面给大家演示一下安全组怎么设置。
1、进入云服务控制台
2、找到安全组,点击进入
3、在默认的一个安全组上,有一个配置规则按钮。点击配置规则
4、这是我原来的安全组规则,没有http的
5、按照如图所示添加
6、浏览器访问ip成功
相关文章
- 【愚公系列】2022年12月 .NET CORE 即时通讯-使用SignalR进行井字游戏
- Winform自动更新之AutoUpdater.NET
- [MySQL] 理解InnoDB并发高的原因
- 自己动手基于 Redis 实现一个 .NET 的分布式锁类库
- [MySQL] in 子查询出现DEPENDENT SUBQUERY问题
- [MySQL] group by 聚合函数的原理和聚合限制原因SELECT list is not in GROUP BY clause and contains nonaggregated column
- [MySQL]mysql的ANY_VALUE()函数 解决 ONLY_FULL_GROUP_BY 模式
- [日常]windows下kill进程工具taskkill
- [CSS] 纯CSS的前端图标icon库并且修改大小和颜色
- [PHP] php中的索引数组和数组顺序问题
- [日常] 修改编辑word中的页眉页脚
- [nginx]配置nginx支持websocket解决返回400错误问题
- [nginx]配置nginx支持websocket解决返回400错误问题
- [PHP] php5.3之前-php5.3-php7垃圾回收机制的进化
- [PHP] include语句的注意事项
- [TCP] tcp连接SYN超时重传次数和超时时间
- [PHP]正则表达式\w和\W区别
- [HTTP]解决406 not acceptable 错误
- [Nginx] nginx配置域名反代后端端口
- [PHP] 使用适配器模式处理数据库对象