Django 和 wsgi - 在 debian 8 上设置
Django & wsgi - setting on debian 8
我是 Django 的新手,我想用 apache2 配置我的应用程序。我只是按照指南和另一个问题,但我想不通!
我的简单配置文件 sites-available/000-default.conf:
<VirtualHost *:80>
WSGIScriptAlias / /var/www/html/mysite/mysite/wsgi.py
WSGIPythonPath /var/www/html/mysite
<Directory /var/www/html/mysite/mysite>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
</VirtualHost>
apache2 重启后 WSGIPythonPath
中出现语法错误
如果我将 WSGIPythonPath 放在 apache2.conf 文件中,应用程序将无法运行。有什么问题?
我遵循 https://docs.djangoproject.com/en/1.10/howto/deployment/wsgi/modwsgi/ 但 WSGIDaemonProcess 似乎不起作用
好吧,推荐它不是很有用,所以这里是你的nginx和gunicorn的基本配置。
为了简单起见,我们假设您的应用程序位于此目录中:/home/root/app/src/
并且我们将使用 root
用户(但您应该为您的应用程序创建单独的用户)
首先你的nginx。您必须在 /etc/nginx/sites-enabled/yourapp.conf
中插入一个新文件,如果有一个名为 default.conf
的文件 - 将其删除。
下面我正在 post 创建一个 nginx conf 文件,它将尝试 运行 您的服务使用 gunicorn.sock:
upstream yourappname {
server unix:/home/root/app/src/gunicorn.sock fail_timeout=0;
}
server {
root /home/root/app/src/;
listen 80;
server_name yourdomain.com *.yourdomain.com
charset utf-8;
client_max_body_size 100m;
access_log /home/root/app/src/logs/nginx-access.log; #you have to have logs folder in src
error_log /home/root/app/src/logs/nginx-error.log;
location /static/ {
alias /home/root/app/src/static/;
}
location /media/ {
alias /home/root/app/src/media/;
}
}
现在 gunicorn 启动脚本。
#!/bin/bash
ME="root"
DJANGODIR=/home/root/app/src
SOCKFILE=/home/root/app/src/gunicorn.sock
USER=root
GROUP=webapps
NUM_WORKERS=3
DJANGO_SETTINGS_MODULE=yourapp.yoursettings
DJANGO_WSGI_MODULE=yourapp.wsgi
echo "Starting $NAME as `whoami`"
# Activate the virtual environment
cd $DJANGODIR
source /home/root/app/env/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH
# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR
# Start your Django Unicorn
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
exec /home/root/app/env/bin/gunicorn ${DJANGO_WSGI_MODULE}:application \
--name root \
--workers $NUM_WORKERS \
--user=$USER --group=$GROUP \
--bind=unix:$SOCKFILE \
--log-level=debug \
--log-file=-
现在好了,为了能够 运行 你的 gunicorn 启动脚本,它必须启用执行模型,所以
sudo chmod u+x gunicorn_start
现在您只需使用 ./gunicorn_start
即可启动您的 gunicorn 服务器
除此之外,我还会 post supervisor conf,它会在应用失败或系统启动时尝试启动您的应用。
首先安装supervisor。
然后在主目录 /etc/supervisor/conf.d/your_conf_file.conf
中创建一个 .conf
文件
内插:
[program:yourappname]
command = /home/root/app/src/gunicorn_start
user = root
stdout_logfile = /home/root/app/src/logs/gunicorn_supervisor.log
redirect_stderr = true
所以完成后我们必须告诉我们的主管我们刚刚添加了新的配置文件。只需 运行 这些命令:
sudo supervisorctl reread
sudo supervisorctl update
为了检查您的应用是否 运行 正确 运行
sudo supervisorctl status yourappname
希望对您有所帮助,如有任何问题,请提问
需要检查的一些事项:是否加载了 wsgi 模块?
LoadModule wsgi_module modules/mod_wsgi.so
同时在 Apache2 配置中寻找这个答案和一个潜在的问题:403 Forbidden error with Django and mod_wsgi
我是 Django 的新手,我想用 apache2 配置我的应用程序。我只是按照指南和另一个问题,但我想不通! 我的简单配置文件 sites-available/000-default.conf:
<VirtualHost *:80>
WSGIScriptAlias / /var/www/html/mysite/mysite/wsgi.py
WSGIPythonPath /var/www/html/mysite
<Directory /var/www/html/mysite/mysite>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
</VirtualHost>
apache2 重启后 WSGIPythonPath
中出现语法错误如果我将 WSGIPythonPath 放在 apache2.conf 文件中,应用程序将无法运行。有什么问题?
我遵循 https://docs.djangoproject.com/en/1.10/howto/deployment/wsgi/modwsgi/ 但 WSGIDaemonProcess 似乎不起作用
好吧,推荐它不是很有用,所以这里是你的nginx和gunicorn的基本配置。
为了简单起见,我们假设您的应用程序位于此目录中:/home/root/app/src/
并且我们将使用 root
用户(但您应该为您的应用程序创建单独的用户)
首先你的nginx。您必须在 /etc/nginx/sites-enabled/yourapp.conf
中插入一个新文件,如果有一个名为 default.conf
的文件 - 将其删除。
下面我正在 post 创建一个 nginx conf 文件,它将尝试 运行 您的服务使用 gunicorn.sock:
upstream yourappname {
server unix:/home/root/app/src/gunicorn.sock fail_timeout=0;
}
server {
root /home/root/app/src/;
listen 80;
server_name yourdomain.com *.yourdomain.com
charset utf-8;
client_max_body_size 100m;
access_log /home/root/app/src/logs/nginx-access.log; #you have to have logs folder in src
error_log /home/root/app/src/logs/nginx-error.log;
location /static/ {
alias /home/root/app/src/static/;
}
location /media/ {
alias /home/root/app/src/media/;
}
}
现在 gunicorn 启动脚本。
#!/bin/bash
ME="root"
DJANGODIR=/home/root/app/src
SOCKFILE=/home/root/app/src/gunicorn.sock
USER=root
GROUP=webapps
NUM_WORKERS=3
DJANGO_SETTINGS_MODULE=yourapp.yoursettings
DJANGO_WSGI_MODULE=yourapp.wsgi
echo "Starting $NAME as `whoami`"
# Activate the virtual environment
cd $DJANGODIR
source /home/root/app/env/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH
# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR
# Start your Django Unicorn
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
exec /home/root/app/env/bin/gunicorn ${DJANGO_WSGI_MODULE}:application \
--name root \
--workers $NUM_WORKERS \
--user=$USER --group=$GROUP \
--bind=unix:$SOCKFILE \
--log-level=debug \
--log-file=-
现在好了,为了能够 运行 你的 gunicorn 启动脚本,它必须启用执行模型,所以
sudo chmod u+x gunicorn_start
现在您只需使用 ./gunicorn_start
除此之外,我还会 post supervisor conf,它会在应用失败或系统启动时尝试启动您的应用。
首先安装supervisor。
然后在主目录 /etc/supervisor/conf.d/your_conf_file.conf
.conf
文件
内插:
[program:yourappname]
command = /home/root/app/src/gunicorn_start
user = root
stdout_logfile = /home/root/app/src/logs/gunicorn_supervisor.log
redirect_stderr = true
所以完成后我们必须告诉我们的主管我们刚刚添加了新的配置文件。只需 运行 这些命令:
sudo supervisorctl reread
sudo supervisorctl update
为了检查您的应用是否 运行 正确 运行
sudo supervisorctl status yourappname
希望对您有所帮助,如有任何问题,请提问
需要检查的一些事项:是否加载了 wsgi 模块?
LoadModule wsgi_module modules/mod_wsgi.so
同时在 Apache2 配置中寻找这个答案和一个潜在的问题:403 Forbidden error with Django and mod_wsgi