关于服务器只能访问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

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

相关推荐
FreeBuf_17 分钟前
新型恶意软件采用独特混淆技术劫持Docker镜像
运维·docker·容器
xxy!40 分钟前
OSI七层模型和TCP/IP四层模型
网络·网络协议·tcp/ip
unique_pursuit1 小时前
CS144 Lab 6 实战记录:构建 IP 路由器
网络·tcp/ip·智能路由器
哈哈幸运1 小时前
Linux Sed 深度解析:从日志清洗到 K8s 等12个高频场景
linux·运维·编辑器·sed
lllsure2 小时前
SpringCloud——负载均衡
服务器·网络·spring cloud
用户867132495742 小时前
5 个开源 MCP 服务器,让您的 AI 代理势不可挡
服务器
masx2003 小时前
升级uptime-kuma版本2.0.0-beta.2的cloudflared版本到2025.4.0
运维·后端
杨凯凡3 小时前
Linux安全防护:全方位服务安全配置指南
linux·运维·服务器·安全
李菠菜3 小时前
CentOS系统中重置Root用户密码的完整步骤详解
linux·运维
Nightwish53 小时前
Linux随记(十七)
linux·运维·服务器