Gunicorn + Nginx+systemd 配置flask

启动gunicorn

复制代码
仅仅内部访问
gunicorn -w 4 -b 127.0.0.1:8002 app:app
或 外部也可访问
gunicorn -w 4 -b 0.0.0.0:8002 app:app

配置nginx服务

复制代码
ubuntu@VM-4-3-ubuntu:/etc/nginx/sites-available$ cat zhiliao_oa
server {
    listen 80;
    server_name flask.larance.xyz; # 替换为你的域名或IP
    client_max_body_size 10M;    # 限制上传文件大小(可选)

    # 静态文件服务 - 让Nginx直接处理,效率最高
    location /static/ {
        alias /home/ubuntu/zhiliao_oa/static/; # 替换为你的静态文件绝对路径
        expires 30d;                           # 客户端缓存30天
        access_log off;                        # 可选:关闭静态文件访问日志减少IO
        add_header Cache-Control "public, immutable"; # 缓存控制头
    }

    # 动态请求 - 代理到Gunicorn
    location / {
        proxy_pass http://127.0.0.1:8002;

        # 传递必要的HTTP头
        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;
        proxy_set_header X-Forwarded-Host $server_name;

        # 超时设置(根据应用调整)
        proxy_connect_timeout 75s;
        proxy_send_timeout 300s;
        proxy_read_timeout 300s;


        # 上传大文件可能需要
        # proxy_request_buffering off;
    }

}

配置环境中遇到的一个小问题 访问 访问静态文件403

此前已经修改了静态目录权限

复制代码
sudo chown -R www-data:www-data /home/ubuntu/zhiliao_oa/static/
sudo chmod -R 755 /home/ubuntu/zhiliao_oa/static/

当时访问静态文件依然403,后来发现上级目录的权限不对

使用 systemd 服务

创建 systemd 服务文件:

复制代码
sudo vi /etc/systemd/system/flask.service

内容:

复制代码
ubuntu@VM-4-3-ubuntu:~/zhiliao_oa$ cat /etc/systemd/system/flask.service
[Unit]
Description=Gunicorn instance to serve flask
After=network.target

[Service]
User=ubuntu
Group=www-data
WorkingDirectory=/home/ubuntu/zhiliao_oa
ExecStart=/usr/bin/gunicorn --workers 4 --bind 0.0.0.0:8002 app:app
ExecStop=/bin/kill -s TERM $MAINPID
Restart=always

[Install]
WantedBy=multi-user.target
ubuntu@VM-4-3-ubuntu:~/zhiliao_oa$
复制代码

然后:

复制代码
# 启动服务
sudo systemctl start flask

# 停止服务
sudo systemctl stop flask

# 重启服务
sudo systemctl restart flask

# 查看状态
sudo systemctl status flask

验证是否已杀死

复制代码
# 检查是否还有 gunicorn 进程
ps aux | grep gunicorn | grep -v grep

# 检查端口是否还在监听
netstat -tlnp | grep :8002
lsof -i :8002
# 如果没有输出,说明进程已停止

注意事项

复制代码
优雅停止 vs 强制停止:

kill -TERM 或 kill -15:优雅停止,让进程完成当前请求

kill -KILL 或 kill -9:强制停止,立即终止

多个实例:
如果运行了多个 Gunicorn 实例,需要指定正确的进程ID或端口

权限问题:
如果使用 sudo 启动,可能需要 sudo 来停止

推荐使用 pkill gunicorn 或 kill $(lsof -t -i:8002),这两种方法最简单直接。
相关推荐
cvcode_study39 分钟前
Nginx 基础
运维·nginx
福大大架构师每日一题1 小时前
nginx 1.31.1 发布:一次安全修复驱动的主线升级,涉及 Rewrite、HTTP/2、Mail、MP4 与工作流修正
nginx·安全·http
Shawn Dev1 小时前
使用 Certbot 为 Nginx 自动申请 HTTPS 证书并配置自动续签
运维·nginx·https
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ2 小时前
docker重新加载docer-compose.yml文件(nginx配置)
nginx·docker·eureka
Yana.nice2 小时前
nginx+tomcat环境下,nginx对后端Tomcat实例的健康检查机制
运维·nginx·tomcat
難釋懷2 小时前
Nginx动静分离
运维·nginx·firefox
Yana.nice2 小时前
Nginx 实现会话保持(Session Persistence)
运维·nginx
Yana.nice2 小时前
nginx的四种代理模式
运维·nginx·代理模式
難釋懷4 小时前
Nginx负载均衡策略
运维·nginx·负载均衡
liux35284 小时前
Nginx 安全升级方案:1.22.0 → 1.30.1
网络·nginx·安全