Django Admin样式表不会在生产服务器上加载

时间:2015-02-12 18:10:52

标签: django nginx static django-templates django-admin

Django的内置管理站点的样式表没有加载到运行Django 1.6的生产服务器上。我可以看到很多其他人遇到过这个问题,我已经尝试了所有提供给他们的解决方案但没有工作。我的Django站点在Nginx v.1.2.1代理后面的Gunicorn 19.1.1之上运行。

由于我将构建一个仪表板并且将使用管理网站,而不仅仅是管理我的用户,组和模型,我在我的网站中创建了一个“管理”应用程序:

INSTALLED_APPS += ('apps.admin', )

我正在覆盖并扩展Django的一些管理模板,并从django.contrib.admin.templates复制它们:

/www/site/apps/admin/__init__.py
/www/site/apps/admin/models.py
/www/site/apps/admin/views.py
/www/site/apps/admin/urls.py
/www/example/apps/admin/templates/admin/base.html
/www/example/apps/admin/templates/admin/base_site.html
/www/example/apps/admin/templates/admin/index.html
/www/example/apps/admin/templates/admin/my_dashboard.html # mine

以下是我的urls.py文件中的相关设置

from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
    # ...
    url(r'^admin/', include(admin.site.urls)),
    url(r'^admin/dashboard/$',
        'apps.admin.views.dashboard',
        {'template': 'my_dashboard.html'},
        name='dashboard'),
)

这是我的设置。我的网站的实际静态文件位于此处:

/www/example/static/css
/www/example/static/js

这是我的静态根。 Django文档说它应该与静态文件的实际位置不同。

STATIC_ROOT = "/var/www/example/static/"

我的静态网址的前缀:

STATIC_URL = '/static/'

静态文件和查找程序的位置:

STATICFILES_DIRS = (
    '/www/example/static'
)
STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
)

我的Nginx配置文件:

upstream gunicorn {
    server 127.0.0.1:8000 fail_timeout=0;
}
server {
    listen 80;
    server_name www.example.com;
    rewrite ^/(.*) http://example.com/$1 permanent;
}
server {
    listen 80;
    server_name example.com;
    root /www/example;
    client_max_body_size 4G;
    keepalive_timeout 5;
    location /static/ {
        alias /www/example/static/;
    }
    location /media/ {
        alias /var/www/example/media/;
    }
    try_files $uri @django;
    location @django {
        proxy_pass http://gunicorn;
        proxy_redirect off;
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
    error_page 500 502 503 504 /500.html;
    location = /500.html {
        root /www/example/static;
    }
}

我可以看到该网站是服务器我的静态文件正确。例如,我可以看到这个图像:

http://example.com/static/img/small_img.jpg

但是当我尝试访问Django样式表时,Nginx引发了404错误......

http://example.com/static/admin/css/base.css

...即使在我的浏览器中执行查看源显示这些链接:

<link rel="stylesheet" type="text/css" href="/static/admin/css/base.css" />
<link rel="stylesheet" type="text/css" href="/static/admin/css/login.css" />

以下是我做过的其他事情:

  • 我确认“django.contrib.staticfiles”和“django.contrib.admin”在INSTALLED_APPS中。
  • 我进入了Python shell并验证了我的STATIC_ROOT,STATIC_URL和STATICFILES_DIR设置。
  • 我在服务器上运行了“collectstatic”命令并验证它将Django管理站点的静态文件复制到我的STATIC_ROOT。
  • 我尝试在我的nginx配置文件中添加一个额外的位置指令,如here所述,并重新启动了我的Nginx服务。
  • 我尝试创建一个目录/ www / example / static / admin目录,然后在其中创建一个指向静态目录的“静态”符号链接... / django / contrib / admin / static /在我的虚拟环境目录中
  • 我在Chrome中加载了管理员主页,其中可以看到开发者控制台,看看是否发生了奇怪的事情,但它只报告了404错误。

我将通过将Django的静态文件复制到我网站的静态文件目录并更改我的base.html版本中的href来尝试“猴子修补”。但是,这不是一个好的解决方案。

抱歉这么长的帖子。谁能告诉我我做错了什么?除此之外,管理员网站似乎正在运行。它只是不加载的样式表。谢谢!

1 个答案:

答案 0 :(得分:4)

您的STATIC_ROOT似乎与nginx的location /static/别名不匹配。你错过了/var/