【问题标题】:How to Mount Django App with uwsgi?如何使用 uwsgi 挂载 Django 应用程序?
【发布时间】:2013-10-28 19:57:08
【问题描述】:

我正在使用 uwsgi 部署一个 Django 应用程序。 我希望通过以下方式访问该应用:

SERVER_URL:PORT/APP_NAME

我的uswgi配置是:

[uwsgi]
http=:PORT
threads = 10
die-on-term=true
chdir = /dir/to/my/app/
home = /dir/to/my/app/
logto = /dir/to/log/LOG.log    
wsgi-file = /dir/to/my/app/main_package/wsgi.py
mount = /APP_NAME=/dir/to/my/app/main_package/wsgi.py

我无法让坐骑工作。 我在SERVER_URL:PORT 下而不是SERVER_URL:PORT/APP_NAME 下获得应用程序。

我得到的日志是:

*** Starting uWSGI 1.9.14 (64bit) on [Sun Oct 20 11:12:49 2013] ***
compiled with version: 4.6.3 on 15 October 2013 13:08:46
os: Linux-3.2.0-29-generic #46-Ubuntu SMP Fri Jul 27 17:03:23 UTC 2012
nodename: SERVER_URL
machine: x86_64
clock source: unix
detected number of CPU cores: 1
current working directory: /
detected binary path: /dir/to/my/app/bin/uwsgi
uWSGI running as root, you can use --uid/--gid/--chroot options
*** WARNING: you are running uWSGI as root !!! (use the --uid flag) *** 
*** WARNING: you are running uWSGI without its master process manager ***
your processes number limit is 15886
your memory page size is 4096 bytes
detected max file descriptor number: 1024
building mime-types dictionary from file /etc/mime.types...530 entry found
lock engine: pthread robust mutexes
uWSGI http bound on :8016 fd 4
spawned uWSGI http 1 (pid: 21029)
uwsgi socket 0 bound to TCP address 127.0.0.1:60322 (port auto-assigned) fd 3
Python version: 2.7.3 (default, Apr 10 2013, 06:31:07)  [GCC 4.6.3]
Set PythonHome to /dir/to/my/app/
Python main interpreter initialized at 0x22c6830
python threads support enabled
your server socket listen backlog is limited to 100 connections
your mercy for graceful operations on workers is 60 seconds
mapped 165584 bytes (161 KB) for 10 cores
*** Operational MODE: threaded ***
WSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x22c6830 pid: 21028 (default app)
mounting /dir/to/my/app/main_package/wsgi.py on /APP_NAME
WSGI app 1 (mountpoint='/APP_NAME') ready in 0 seconds on interpreter 0x276e1b0 pid: 21028
*** uWSGI is running in multiple interpreter mode ***
spawned uWSGI worker 1 (and the only) (pid: 21028, cores: 10)

我还尝试从 uswgi 配置中删除 wsgi-file,只保留 mount 配置。我得到了:

mounting /dir/to/my/app/main_package/wsgi.py on /APP_NAME
WSGI app 0 (mountpoint='/APP_NAME') ready in 0 seconds on interpreter 0x24ae780 pid: 11515 (default app)

应用仍然没有正确安装。

如何挂载我的应用程序?

附: 我想避免使用 nginx。

【问题讨论】:

  • 在原消息中添加
  • 也不知道……希望this 页面有所帮助……顺便说一句,我认为nginx 值得一试。

标签: python django wsgi uwsgi


【解决方案1】:

nginx 无法将正确的 SCRIPT_NAME(和 PATH_INFO)传递给 uWSGI。您需要使用 --manage-script-name 告诉 uWSGI 自己进行翻译

顺便说一下,你不需要 wsgi-file,因为 mount 已经加载了它

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-08-26
    • 1970-01-01
    • 1970-01-01
    • 2012-11-01
    • 2015-01-27
    • 1970-01-01
    • 2012-04-13
    • 1970-01-01
    相关资源
    最近更新 更多