Nginx没有将流量转发给Gunicorn

时间:2017-08-19 20:52:13

标签: python nginx flask

我有一个Flask应用程序,我正试图主持Gunicorn和Nginx。我已经遵循了几个教程,我似乎无法让Nginx停止渲染“欢迎使用Nginx”页面。

我已经确认主管成功启动了三名Gunicorn工作人员,Nginx也在后台运行。 SSL已确认正在运行,Nginx在端口443上获取流量。我试图将Nginx添加到与拥有Gunicorn和Nginx共享的袜子的用户相同的组中。

这是主管用来启动Gunicorn的bash脚本。这证实有效。

#!/bin/bash

NAME="Simon"                                  
FLASKDIR=/var/www/Simon            
SOCKFILE=/var/www/Simon/simon.sock
USER=glen                                        
GROUP=glen                                   
NUM_WORKERS=3
FLASK_SETTINGS_MODULE=config.py         
FLASK_WSGI_MODULE=Simon.wsgi
echo "Starting $NAME as `whoami`"

# Activate the virtual environment
cd $FLASKDIR
source Simon/bin/activate
export FLASK_SETTINGS_MODULE=$FLASK_SETTINGS_MODULE
export PYTHONPATH=$FLASKDIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

exec gunicorn Simon:simon \
  --name $NAME \
  --workers $NUM_WORKERS \
  --user=$USER --group=$GROUP \
  --bind=unix:$SOCKFILE \
  --log-level=debug \

这是网站配置:

upstream simon_server {
  # fail_timeout=0 means we always retry an upstream even if it failed
  # to return a good HTTP response (in case the Unicorn master nukes a
  # single worker for timing out).

  server unix:/var/www/Simon/simon.sock fail_timeout=0;
}

server {

    listen   443 ssl;
    server_name glencoverx.com;

    client_max_body_size 4G;

    access_log /var/www/Simon/logs/nginx-access.log;
    error_log /var/www/Simon/logs/nginx-error.log;

    location /static/ {
        alias   /var/www/Simon/static/;
    }

    location / {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;
        proxy_set_header Host $http_host;
        proxy_redirect off;

    if ($scheme != "https") {
        return 301 https://$host$request_uri;}

} 
    ssl_certificate /etc/letsencrypt/live/glencoverx.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/glencoverx.com/privkey.pem; # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
}

奇怪的是,日志显示没有问题。我已经完全删除了Nginx默认站点配置并删除了它的符号链接。我不明白为什么Nginx不会与Gunicorn沟通。

1 个答案:

答案 0 :(得分:0)

首先,如果你做的事情会有所帮助: listen 443 default ssl; 这将使该网站成为默认网站。

如果您还没有service nginx restart,请确保清除缓存。尝试使用telnet来确保它仍然启用。

检查你的nginx / conf.d和启用网站的目录,看看符号链接或默认网站是否仍在那里。