uwsgi+nginx代理Django無法訪問靜態資源的解決

在部署uwsgi+nginx代理Django的時候,使用uwsgi訪問正常,但是使用nginx代理端口訪問的時候無法訪問靜態資源。

解決方法:

  • 查看nginx啟動用戶,將靜態資源賦權給改用戶訪問即可。
  • 如我的靜態資源目錄:/data/django/static
  • 賦權:chmod 755 /data/django/static -R

uwsgi配置:

# uwsig使用配置文件啟動
[uwsgi]
# 項目所在的根目錄
chdir=/data/django/dailyfresh
# 指定項目的application,區別於啟動命令--wsgi-filemysite/wsgi.py
#logsquery自己應用的名字
module=dailyfresh.wsgi:application
#the local unix socket file than commnuincate to Nginx
# 指定sock的文件路徑,這個sock文件會在nginx的uwsgi_pass配置,用來nginx與uwsgi通信
# 支持ip+port模式以及socket file模式
#socket=/etc/uwsgi/uwsgi.sock
socket=127.0.0.1:9001
# 進程個數
processes = 8
# 每個進程worker數
workers=5
procname-prefix-spaced=dailyfresh # uwsgi的進程名稱前綴
py-autoreload=1 # py文件修改,自動加載
# 指定IP端口,web訪問入口
http=0.0.0.0:9000
# 啟動uwsgi的用戶名和用戶組
uid=root
gid=root
# 啟用主進程
master=true
# 自動移除unix Socket和pid文件當服務停止的時候
vacuum=true
# 序列化接受的內容,如果可能的話
thunder-lock=true
# 啟用線程
enable-threads=true
# 設置一個超時,用於中斷那些超過服務器請求上限的額外請求
harakiri=30
# 設置緩沖
post-buffering=4096
# 設置日志目錄
daemonize=/var/log/uwsgi/uwsgi.log
# uWSGI進程號存放
pidfile=/etc/uwsgi/uwsgi.pid

nginx配置:

server {
            listen       9002;
            server_name  192.168.2.100;
            access_log /var/log/test.log;
            error_log /var/log/test.log;
            charset utf-8;
            client_max_body_size 100M;
            location /static{
                    alias /data/django/dailyfresh/static;
            }
            location /media{
                    alias /data/django/dailyfresh/media;
            }
            location /  {
                    include  uwsgi_params;
                    uwsgi_pass 127.0.0.1:9001;
            }
            error_page   500 502 503 504  /50x.html;
            location = /50x.html {
                root   html;
            }
}

到此這篇關於uwsgi+nginx代理Django無法訪問靜態資源的解決的文章就介紹到這瞭,更多相關uwsgi+nginx代理Django無法訪問內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet! 

推薦閱讀: