云数据库虚拟主机(云服务器云虚拟主机)
183
2022-07-15
在部署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; } }
发表评论
暂时没有评论,来抢沙发吧~