【实战】在 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。

相关推荐
YYRAN_ZZU2 分钟前
Petalinux新建自动脚本启动
linux
charlie11451419118 分钟前
嵌入式Linux驱动开发pinctrl篇(1)——从寄存器到子系统:驱动演进之路
linux·运维·驱动开发
于小猿Sup36 分钟前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
cen__y1 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
不仙5202 小时前
VMware Workstation 26.0.0 在 Ubuntu 24.04 (内核 6.17.0) 上的安装与内核模块编译问题
linux·ubuntu·elasticsearch
彦为君3 小时前
Agent 安全:从权限提示到沙箱隔离
python·ai·ai编程
AI视觉网奇3 小时前
linux 检索库 判断库是否支持
java·linux·服务器
dapeng-大鹏3 小时前
KVM+LVM 零停机在线扩容 Ubuntu 根分区:从磁盘添加到逻辑卷扩展完整
linux·运维·ubuntu·磁盘空间扩展
PILIPALAPENG3 小时前
Python 语法速成指南:前端开发者视角(JS 类比版)
前端·人工智能·python