我正在使用nginx(通过gunicorn)为烧瓶应用程序提供静态文件.
默认静态文件夹中的静态文件正常工作:
<link rel="stylesheet" href="{{ url_for('static', filename='css/fa/font-awesome.min.css') }}" />
但是对于我想限制登录用户访问的其他静态文件,我使用的是Flask提供的静态文件夹:
app.register_blueprint(application_view)
application_view = Blueprint('application_view', __name__, static_folder='application_static')
在HTML中,我正在调用一个静态文件:
<link rel="stylesheet" href="{{ url_for('application_view.static', filename='css/main.css') }}" />
然后在application / application_static中我有受限制的静态文件.这在本地Flask安装上工作正常,但是当我使用Nginx服务文件从/ static文件夹部署到生产机器时,我得到“NetworkError:404 Not Found-network.com/application_static/main.css”.
有关如何配置Ngix来处理此问题的任何想法?
conf.d / mysitename.conf文件:
upstream app_server_wsgiapp {
server localhost:8000 fail_timeout=0;
}
server {
listen 80;
server_name www.mysitename.com;
rewrite ^(.*) https://$server_name$1 permanent;
}
server {
server_name www.mysitename.com;
listen 443 ssl;
#other ssl config here
access_log /var/log/nginx/www.mysitename.com.access.log;
error_log /var/log/nginx/www.mysitename.com.error.log info;
keepalive_timeout 5;
# nginx serve up static files and never send to the WSGI server
location /static {
autoindex on;
alias /pathtositeonserver/static;
}
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
if (!-f $request_filename) {
proxy_pass http://app_server_wsgiapp;
break;
}
}
# this section allows Nginx to reverse proxy for websockets
location /socket.io {
proxy_pass http://app_server_wsgiapp/socket.io;
proxy_redirect off;
proxy_buffering off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
}
}
nginx.conf:
user www-data;
worker_processes 4;
pid /run/nginx.pid;
events {
worker_connections 768;
# multi_accept on;
}
http {
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include /etc/nginx/mime.types;
default_type application/octet-stream;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
解决方法:
gunicorn将使旧代码仍在运行,除非您重新加载配置文件.
您可以停止并重新启动gunicorn,也可以向gunicorn进程发送HUP信号.