如何轻松配置应用?

uWSGI 是一个高性能的 Web 服务器网关接口(WSGI),用于部署 Python Web 应用(如 Django、Flask),以下是详细的配置步骤和命令指南,遵循最佳实践并兼顾安全性与性能:


基础安装与环境准备

  1. 安装 uWSGI

    pip install uwsgi  # 推荐使用虚拟环境
    • 验证安装:uwsgi --version
  2. 准备示例应用
    创建一个测试文件 myapp.py

    def application(env, start_response):
        start_response('200 OK', [('Content-Type','text/html')])
        return [b"Hello World from uWSGI"]

uWSGI 命令的 4 种配置方式

方式 1:命令行直接运行(测试用)

uwsgi --http :8000 --wsgi-file myapp.py
  • --http:监听 HTTP 端口(生产环境建议用 Nginx 反向代理)
  • --wsgi-file:指定 WSGI 应用入口文件

方式 2:配置文件(推荐生产环境)

创建 myapp.ini 配置文件:

[uwsgi]module = myapp:application  # 应用入口(文件名:应用对象)
master = true               # 启用主进程
processes = 4               # 工作进程数
threads = 2                 # 每个进程的线程数
# 网络与协议
socket = :3031              # 使用 socket 与 Nginx 通信
http = :8000                # 直接 HTTP 访问(调试时启用)
# 资源与日志
chdir = /path/to/your/project  # 项目根目录
vacuum = true               # 退出时清理临时文件
daemonize = /var/log/uwsgi/myapp.log  # 后台运行并记录日志
pidfile = /tmp/uwsgi.pid    # 主进程 PID 文件

启动命令

uwsgi --ini myapp.ini  # 加载配置文件

方式 3:通过 Emperor 模式管理多应用

uwsgi --emperor /etc/uwsgi/vassals/ --daemonize /var/log/uwsgi/emperor.log
  • 将每个应用的配置(如 myapp.ini)放入 /etc/uwsgi/vassals/
  • uWSGI 自动监控配置变化并重启应用

方式 4:环境变量注入

在配置文件中动态读取环境变量:

[uwsgi]
env = DJANGO_SETTINGS_MODULE=myproject.settings.prod  # 设置环境变量

Nginx 反向代理配置

修改 Nginx 站点配置(/etc/nginx/sites-available/myapp):

server {
    listen 80;
    server_name example.com;
    location / {
        include uwsgi_params;
        uwsgi_pass 127.0.0.1:3031;  # 与 uWSGI socket 端口一致
        uwsgi_read_timeout 300;     # 超时设置
    }
}

重启 Nginx:sudo systemctl restart nginx


安全与性能优化

  1. 安全实践

    • 使用非 root 用户运行:uid = www-data gid = www-data
    • 禁用危险功能:disable-logging = true(关闭冗余日志)
    • 启用 chmod-socket = 660 限制 socket 权限
  2. 性能调优

    processes = $(nproc) * 2  # 按 CPU 核心数调整
    max-requests = 1000       # 防止内存泄漏
    harakiri = 30             # 强制终止超时进程(秒)
    buffer-size = 65536       # 大文件上传支持

常见问题解决

  • 错误:no app loaded
    检查 module 路径是否正确(如 django.core.wsgi:get_wsgi_application())。

  • 502 Bad Gateway
    确保 Nginx 的 uwsgi_pass 端口与 uWSGI 的 socket 一致。

  • 日志排查
    使用 uwsgi --ini myapp.ini --logto /tmp/uwsgi_debug.log 输出详细日志。


系统服务管理(Systemd)

创建服务文件 /etc/systemd/system/uwsgi.service

[Unit]
Description=uWSGI Emperor
After=network.target
[Service]
User=www-data
Group=www-data
ExecStart=/usr/local/bin/uwsgi --emperor /etc/uwsgi/vassals
Restart=always
KillSignal=SIGQUIT
Type=notify
[Install]
WantedBy=multi-user.target

启动服务:

sudo systemctl daemon-reload
sudo systemctl start uwsgi
sudo systemctl enable uwsgi

引用说明

  • uWSGI 官方文档:uWSGI Options Documentation
  • Nginx 配置参考:Module ngx_http_uwsgi_module
  • 安全实践依据:OWASP Deployment Security

通过配置文件管理 uWSGI 是生产环境的最佳实践,结合 Nginx 反向代理和 Systemd 守护进程,可构建高可用、安全的 Web 服务,定期检查日志并更新版本以修复漏洞。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/9445.html

(0)
酷番叔酷番叔
上一篇 2025年7月31日 14:44
下一篇 2025年7月31日 15:01

相关推荐

  • 命令李route命令怎么删除

    Linux中,可使用ip route del 目标网络/子网掩码 via 网关或`route del -net 目标网络 -netmask 子

    2025年8月18日
    3800
  • 安全咨询如何有效落地赋能企业构建主动式安全管理体系并创造价值?

    在数字化浪潮席卷全球的背景下,企业运营高度依赖信息系统,网络攻击、数据泄露、合规风险等安全问题日益凸显,安全咨询作为专业化的安全服务,正成为企业构建主动防御体系、提升安全能力的关键支撑,安全咨询并非简单的技术方案输出,而是通过系统化方法论,结合企业业务场景与战略目标,从风险识别、策略制定、方案设计到落地实施、持……

    2025年10月25日
    1900
  • CAD命令栏消失?一键恢复方法!

    按Ctrl+9快捷键可快速恢复显示,若无效,点击顶部菜单栏“工具” ˃ “命令行”,勾选启用即可调出消失的命令行窗口。

    2025年8月5日
    4700
  • 如何轻松修复APT更新失败问题?

    刷新终端屏幕(清屏)杂乱时,快速清空屏幕:clear # 清屏(实际是向上滚动隐藏内容)reset # 彻底重置终端(修复显示错乱)Ctrl + L # 快捷键等效于clear刷新软件包列表(更新源)更新软件仓库元数据,确保获取最新软件版本:# Red Hat/CentOS (DNF/Yum)sudo dnf……

    2025年7月4日
    6300
  • 如何用DOS命令高效复制文件?

    基础复制命令:copy功能:复制单个或多个文件到指定位置,不支持目录复制,语法:copy [源路径\文件名] [目标路径\文件名] [参数]常用参数/v:验证复制后的文件完整性(适用于重要文件),/y:覆盖目标文件时不提示确认(自动化脚本常用),/d:仅复制源文件比目标文件新的文件(增量备份),典型示例复制文件……

    2025年8月7日
    4700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信