Flask服务器部署的踩坑记录

今天在腾讯云进行flask后台进行配置的时候,按照官方的方法无论如何都无法访问到服务器

官方关于外部可访问的服务器配置

快速入门 — Flask 0.10.1 文档

如果你运行了这个服务器,你会发现它只能从你自己的计算机上访问,网络中其它任何的地方都不能访问。在调试模式下,用户可以在你的计算机上执行任意 Python 代码。因此,这个行为是默认的。

如果你禁用了 debug 或信任你所在网络的用户,你可以简单修改调用 run() 的方法使你的服务器公开可用,如下:

app.run(host='0.0.0.0')

这会让操作系统监听所有公网 IP。

然而并不行,接着看了网上各种相关问题,主要有几种方面的问题

  • 防火墙是否开放

    这个是与自己的云服务配置相关,需要配置相应的安全组,或者内部直接开启相应的防火墙端口

    1
    2
    3
    4
    # 添加 --permanent永久生效,没有此参数重启后失效
    firewall-cmd --zone=public --add-port=80/tcp --permanent
    # 重新载入
    firewall-cmd --reload

    当然也可以暴力点把防火墙直接关掉

    1
    2
    3
    4
    # 启动
    systemctl start firewalld
    # 关闭
    systemctl stop firewalld
  • 是否修改了默认的IP为0.0.0.0

然而尽管这些都弄好了,问题还是没有解决。接下来将介绍Window 10以及Centos 7下我的解决方法

Window 10

Pycharm

需要修改项目的一些配置,流程如下图

1

2

3

最后发现运行的命令变成了python.exe -m flask run --host=0.0.0.0,并且相应的IP地址也变成了0.0.0.0,此时测试发现服务器能够被外部正常访问了。发现Flask的服务修改默认的IP和端口需要显示指定

1
python.exe -m flask run --host=0.0.0.0 -- port=8080

Centos 7

其原理其实和Window 10环境一样,不过不需要重新配置项目,只需要直接修改运行命令即可。

1
flask run -h 0.0.0.0 -p 5000