0

我有一个带有 nginx+gunicorn+supervisor 的 django 应用程序设置,并且工作正常。但我需要创建一个子域用于分期或开发,如“dev.domain.com”。我在 nginx.conf 中为我的子域添加了另一个服务器块。但是我的子域 url 总是指向主域站点。所以我按照其他帖子的建议更改了 proxy_pass 中的端口号。但由于 gunicorn 和 supervisord,我需要在“/etc/supervisord/conf.d/subdomain.conf”中为此子域添加另一个 conf 文件,但是当我重新加载 supervisord 时,它无法启动我的子域程序。下面是我的 nginx.conf、subdomain.conf、script.sh: nginx.conf

http {
include       mime.types;
default_type  application/octet-stream;

#log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
#                  '$status $body_bytes_sent "$http_referer" '
#                  '"$http_user_agent" "$http_x_forwarded_for"';

#access_log  logs/access.log  main;

sendfile        on;
#tcp_nopush     on;

#keepalive_timeout  0;
keepalive_timeout  65;

gzip  on;
gzip_static  on;
gzip_types application/x-javascript text/css text/html application/json text/css text/json;

server {
listen   80;
server_name domain_name
# no security problem here, since / is alway passed to upstream
root /home/path/to/project/base
# serve directly - analogous for static/staticfiles
location /static/ {
    # if asset versioning is used
    if ($query_string) {
        expires max;
    }
    autoindex off;
    root /home/path/to/static/;
}
location / {
    proxy_pass_header Server;
    proxy_set_header Host $http_host;
    proxy_redirect off;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Scheme $scheme;
    proxy_connect_timeout 10;
    proxy_read_timeout 10;
proxy_pass http://localhost:8000/;
    proxy_set_header X-Forwarded-For $remote_addr;
}
}

server {
listen   80;
server_name subdomain_name
# no security problem here, since / is alway passed to upstream
root /home/path/to/subdomain_directory(which is different, you can say it is fully differnt project which i want to run as development project);
# serve directly - analogous for static/staticfiles


location / {
    proxy_pass_header Server;
    proxy_set_header Host $http_host;
    proxy_redirect off;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Scheme $scheme;
    proxy_connect_timeout 10;
    proxy_read_timeout 10;
    proxy_pass http://localhost:9000/;
    proxy_set_header X-Forwarded-For $remote_addr;
}
}
}

脚本.sh

set -e
NUM_WORKERS=4
# user/group to run as
USER=user_name
#GROUP=your_unix_group
cd /home/path/to/subdomain_base
source subdomain_virtualenv_activation
LOGFILE=log_file_path
LOGDIR=$(dirname $LOGFILE)
test -d $LOGDIR || mkdir -p $LOGDIR
exec virtualenvironment/bin/gunicorn_django -w $NUM_WORKERS \
--user=$USER --log-level=debug \
--log-file=$LOGFILE 2>>$LOGFILE

子域.conf

[program:programname]
directory = /home/path/to/subdomainbase/
user = user_name
command = /home/path/to/script.sh
stdout_logfile = /home/path/to/log
stderr_logfile = /home/path/to/log

我也有一个 procfile,如 gunicorn 中所建议的那样,它位于基本目录 Procfile 中

./manage.py runserver_plus 0.0.0.0:$PORT

好的,这些是我的配置。请检查我在哪里做错了。我只想将我的开发服务器作为不同的项目运行,但在与子域相同的域下。毕竟,无论我在做什么更改,主域都可以在相同的过程中正常工作。如果您需要有关此错误的更多信息,请告诉我。

4

1 回答 1

1

编辑

我正在再次阅读您的帖子,并且...您不应该在您的 gunicorn 脚本中设置 ADDRESS 吗?gunicorn 默认使用端口 8000,也许您的子域正在尝试使用相同的端口?

结束编辑

我有两个使用 nginx、gunicorn 和 supervisor 运行的 Django 应用程序,就像你想做的那样(嗯,不一样,但非常相似,我有两个域和一个子域)。我看不出你的错误在哪里,我认为一定是在 nginx 配置中。也许是“根”行?

当您尝试使用“supervisorctl”命令启动它时,您是否看到 supervisord 是否返回错误?

我可以向您展示我的配置,您可以进行比较:

我有两个 .conf 文件用于nginx

域1.conf:

server {
    listen  80;
    server_name  domain1.net;
    return 301 $scheme://www.domain1.net$request_uri;    
}

server {
    listen 80;
    server_name www.domain1.net;
    access_log /var/log/nginx/domain1.log;

    location /static {
        alias /var/www/domain1/media/;
        autoindex on;
        access_log off;
    }

    location / {
        proxy_pass_header Server;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        proxy_set_header X-Forwarded-For  $remote_addr;
        proxy_set_header X-Scheme $scheme;
        proxy_connect_timeout 10;
        proxy_read_timeout 10;
        proxy_pass http://127.0.0.1:8000/;
    }

}

和 domain2.conf:

server {
    listen 80;
    server_name subdomain.domain2.es;
    access_log /var/log/nginx/domain2.log;

    location /static {
        alias /var/www/dev/domain2/domain2/static/;
        autoindex on;
        access_log off;
    }

    location / {
        proxy_pass_header Server;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        proxy_set_header X-Forwarded-For  $remote_addr;
        proxy_set_header X-Scheme $scheme;
        proxy_connect_timeout 10;
        proxy_read_timeout 10;
        proxy_pass http://127.0.0.1:8005/;
    }

}

我的两个gunicor 脚本是相同的,只是在其中一个中更改了路径和地址:

#!/bin/bash
set -e
LOGFILE=/var/log/gunicorn/domain1.log
LOGDIR=$(dirname $LOGFILE)
NUM_WORKERS=1
# user/group to run as
USER=user
GROUP=user
ADDRESS=127.0.0.1:8005
cd /var/www/dev/domain1
source /path/to/venv/domain1/bin/activate
test -d $LOGDIR || mkdir -p $LOGDIR
exec gunicorn_django -w $NUM_WORKERS --bind=$ADDRESS \
  --user=$USER --group=$GROUP --log-level=debug \
  --log-file=$LOGFILE 2>>$LOGFILE

我的两个主管脚本也相同:

[program:domain1]
directory = /var/www/dev/domain1/
user = user
command = /path/to/bin/gunicorn_domain1.sh
stdout_logfile = /var/log/nginx/domain1.log
stderr_logfile = /var/log/nginx/domain1.log

我希望你觉得这很有帮助。

于 2013-03-18T17:11:08.973 回答