【实战】在 Linux 上使用 Nginx 部署 Python Flask 应用

在 Linux 上使用 Nginx 部署 Python Flask 应用

步骤一:准备 Flask 应用

  1. 创建 Flask 应用 确保你有一个可以运行的 Flask 应用。例如,创建一个简单的 app.py 文件:

    复制代码
    from flask import Flask
    app = Flask(__name__)
    
    @app.route('/')
    def hello_world():
        return 'Hello, World!'
    
    if __name__ == '__main__':
        app.run(host='0.0.0.0', port=5000)
  2. 安装依赖 在你的 Flask 应用目录中创建一个 requirements.txt 文件,并添加 Flask

    复制代码
    Flask==2.0.1

    然后安装依赖:

    复制代码
    pip3 install -r requirements.txt

步骤二:使用 systemd 管理 Flask 应用

  1. 创建一个 systemd 服务文件 创建一个新的 systemd 服务文件,例如 /etc/systemd/system/flaskapp.service,内容如下:

    复制代码
    [Unit]
    Description=Flask Application
    After=network.target
    
    [Service]
    User=your_username
    WorkingDirectory=/path/to/your/flaskapp
    ExecStart=/usr/bin/python3 /path/to/your/flaskapp/app.py
    Restart=always
    
    [Install]
    WantedBy=multi-user.target
  2. 重新加载 systemd 配置

    复制代码
    sudo systemctl daemon-reload
  3. 启动并启用服务

    复制代码
    sudo systemctl start flaskapp
    sudo systemctl enable flaskapp
  4. 检查服务状态

    复制代码
    sudo systemctl status flaskapp

步骤三:配置 Nginx

  1. 安装 Nginx 如果你还没有安装 Nginx,可以使用以下命令进行安装:

    SHELL

    复制代码
    sudo yum install nginx
  2. 配置 Nginx 反向代理 创建一个新的 Nginx 配置文件,例如 /etc/nginx/conf.d/flaskapp.conf,内容如下:

    SHELL

    复制代码
    server {
        listen 80;
        server_name your_domain_or_ip;
    
        location / {
            proxy_pass http://127.0.0.1:5000;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
        }
    }
  3. 测试 Nginx 配置

    复制代码
    sudo nginx -t
  4. 重启 Nginx

    复制代码
    sudo systemctl restart nginx

步骤四:访问你的 Flask 应用

现在,你可以通过浏览器访问你的服务器 IP 或域名,应该能够看到 "Hello, World!" 的输出。

额外提示

  • 确保防火墙允许 HTTP 流量(端口 80)。你可以使用以下命令打开端口:

    复制代码
    sudo firewall-cmd --permanent --add-service=http
    sudo firewall-cmd --reload
  • 如果你使用的是 HTTPS,可以考虑配置 SSL 证书,例如使用 Let's Encrypt。

相关推荐
2401_858936887 分钟前
【Linux C 编程】标准 IO 详解与实战:从基础接口到文件操作实战
linux·c语言
Yorlen_Zhang9 分钟前
Python Tkinter Text 控件完全指南:从基础编辑器到富文本应用
开发语言·python·c#
Roc.Chang19 分钟前
Ubuntu 下 VLC 无法启动(Segmentation fault)终极解决方案
linux·ubuntu·vlc·媒体播放
HAPPY酷37 分钟前
C++ 和 Python 的“容器”对决:从万金油到核武器
开发语言·c++·python
松涛和鸣1 小时前
72、IMX6ULL驱动实战:设备树(DTS/DTB)+ GPIO子系统+Platform总线
linux·服务器·arm开发·数据库·单片机
简单中的复杂1 小时前
【避坑指南】RK3576 Linux SDK 编译:解决 Buildroot 卡死在 host-gcc-final 的终极方案
linux·嵌入式硬件
gpfyyds6661 小时前
Python代码练习
开发语言·python
wVelpro2 小时前
如何在Pycharm 2025.3 版本实现虚拟环境“Make available to all projects”
linux·ide·pycharm
larance2 小时前
Gunicorn + Nginx+systemd 配置flask
nginx·flask·gunicorn
程序员老舅2 小时前
C++高并发精髓:无锁队列深度解析
linux·c++·内存管理·c/c++·原子操作·无锁队列