uwsgi+nginx代理Django無法訪問靜態資源的解決
在部署uwsgi+nginx代理Django的時候,使用uwsgi訪問正常,但是使用nginx代理端口訪問的時候無法訪問靜態資源。
解決方法:
- 查看nginx啟動用戶,將靜態資源賦權給改用戶訪問即可。
- 如我的靜態資源目錄:/data/django/static
- 賦權:ch
mod 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!
推薦閱讀:
- centos+nginx+uwsgi部署django項目上線
- Django+Nginx+uWSGI 定時任務的實現方法
- 淺談Python項目的服務器部署
- 一文教會你用nginx+uwsgi部署自己的django項目
- Nginx解決history模式下頁面刷新404問題示例