关于服务器只能访问localhost:8111地址,局域网不能访问的问题

一、问题来源

服务器是使用的阿里云的服务器,服务器端的8111端口没有设置任何别的限制,但是在阿里云服务器端并没有设置相应的tcp连接8111端口。

二、解决办法:

1、使用阿里云初始化好的端口;2、配置新的阿里云端口。

三、具体排错方案:

1、确保 uvicorn 运行时绑定了 0.0.0.0,外部才可以访问(如果是轮询地址127.0.0.1只能在服务器端访问)

bash 复制代码
uvicorn main:app --host 0.0.0.0 --port 8111

2、在服务器上用 curl 试试:

bash 复制代码
curl http://127.0.0.1:8111

如果本地访问正常,再试试公网 IP:

bash 复制代码
curl http://公网ip:8111

3、运行以下命令,查看 8111 端口的监听状态:

bash 复制代码
sudo netstat -tulnp | grep 8111

或者:

bash 复制代码
sudo lsof -i :8111

正常情况:

tcp 0 0 0.0.0.0:8111 0.0.0.0:* LISTEN 12345/python

错误情况(只监听 127.0.0.1):

tcp 0 0 127.0.0.1:8111 0.0.0.0:* LISTEN 12345/python

如果监听的是 127.0.0.1:8111,局域网当然访问不到,你需要重新启动程序:

bash 复制代码
uvicorn predicttemp:app --host 0.0.0.0 --port 8111 --reload

4、检查 ufw(防火墙)是否拦截了 8011 端口

bash 复制代码
sudo ufw status

未启用为inactive

ufw 启用了(状态是 active),手动放行 8011 端口:

bash 复制代码
sudo ufw allow 8011/tcp

sudo ufw reload

服务器防火墙(iptables)是否允许 8011 端口

bash 复制代码
iptables -L -n

正常输出:

ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:8111

可以再手动添加一次

bash 复制代码
sudo iptables -A INPUT -p tcp --dport 8111 -j ACCEPT
sudo iptables -A OUTPUT -p tcp --sport 8111 -j ACCEPT
bash 复制代码
sudo iptables-save

5、云服务器的安全组是否允许 8111

如果你的服务器是 阿里云、腾讯云、AWS、华为云,你需要:(上述步骤一、二)

  • 阿里云 :进入 ECS控制台安全组添加入站规则 ,放行 TCP 8111 端口。

  • 腾讯云 :进入 云服务器防火墙放行 8111 端口

  • AWS (EC2):进入 Security GroupsInbound Rules允许 8111

6、服务器端验证

bash 复制代码
curl http://服务器端ip:8111

会成功连接你的服务器端口!

相关推荐
飛_1 小时前
解决VSCode无法加载Json架构问题
java·服务器·前端
java叶新东老师3 小时前
git stash 命令详解
linux·运维·flink
写bug的羊羊4 小时前
CentOS 9 配置国内 YUM 源
linux·运维·centos
清 晨5 小时前
剖析 Web3 与传统网络模型的安全框架
网络·安全·web3·facebook·tiktok·instagram·clonbrowser
国科安芯5 小时前
抗辐照芯片在低轨卫星星座CAN总线通讯及供电系统的应用探讨
运维·网络·人工智能·单片机·自动化
gx23486 小时前
HCLP--MGER综合实验
运维·服务器·网络
VB5946 小时前
[N1盒子] 斐讯盒子N1 T1通用刷机包(可救砖)
网络
angushine6 小时前
鲲鹏服务器部署Kafka2.8.1
运维·服务器
-XWB-6 小时前
【安全漏洞】防范未然:如何有效关闭不必要的HTTP请求方法,保护你的Web应用
服务器·网络·http
画中鸦7 小时前
VRRP的概念及应用场景
网络