设为首页 收藏本站
查看: 1141|回复: 0

[经验分享] Nginx与django+uwsgi成功勾搭的始末(下)

[复制链接]

尚未签到

发表于 2018-11-8 10:01:02 | 显示全部楼层 |阅读模式
  前文连接:
  记录Uwsgi与Django成功勾搭的始末 http://chenx1242.blog.51cto.com/10430133/1906056
  Nginx与django+uwsgi成功勾搭的始末(上)
  http://chenx1242.blog.51cto.com/10430133/1907430
  正文内容:
  在“Nginx与django+uwsgi成功勾搭的始末(上)”里我们已经实现了可以用浏览器访问我们django里的静态文件,注意,是django里的文件,而不是nginx里的。也就是说我们打开nginx是可以访问django里的静态文件,而不能访问django里的其他内容,只有我们启动了nginx同时也启动了django,才会访问django里的动态文件。
  这篇文章的内容是验证socket是否可以连接起nginx和uwsgi。
  在/home/下面我记得我们是有一个叫logan.py,里面的内容是这样的:
def application(env, start_response):  
    start_response('200 OK', [('Content-Type','text/html')])
  
    return ["Good bye,Logan..."] # python2

  现在我们来到home文件夹,ps -ef一下确认后台进程nginx是没有的,uwsgi也是没有的,使用#uwsgi --plugin python --socket :8001 --wsgi-file logan.py。然后在浏览器里测试“外网地址:8001”,发现网页无法打开,同时服务器终端提示:“invalid request block>  这是因为在#uwsgi --plugin python --socket :8001 --wsgi-file logan.py这个命令里,我们用 socket的方式去打开logan.py,这个方式默认是tcp的,而我们在浏览器访问却是走的http协议,自然会失败了。而我们在前面已经知道用#uwsgi --plugin python --http-socket :8001 --wsgi-file logan.py是可以打开的,但是我们的目的是要验证“socket是否可以连接起nginx和uwsgi”。怎么办?
  此时,我们还是需要启动nginx,但是要用我们之前的mysite_nginx.conf,于是我们#nginx -c /etc/nginx/sites-enabled/mysite_nginx.conf
  然后我们再试试#uwsgi --plugin python --socket :8001 --wsgi-file logan.py,在浏览器里输入“外网地址:8000”,发现浏览器里出现了"Good bye,Logan...",不仅这个界面OK,就连我们之前的那个电影海报(media/logan.jpg)也是OK的。
  至此我们可以大吼一声:
Web Client  Web Server(nginx)  The Socket  uWSGI  Python  这条通道已经彻底打通了!
  打通了还没完,我们需要进去搞事情。现在我们修改一下mysite_nginx.conf,把里面的server改成这样:
server unix:///django/logan/logan.sock;  然后#uwsgi --plugin python --socket /django/logan/logan.sock --wsgi-file logan.py,这样规定它使用socket去代替那些协议去启动那个py文件。估计看到这里很多人会有疑问,为啥凭空出现了一个logan.sock?这是什么鬼?
  因为这个logan.sock是在uwsgi启动之后自动生成的,当我们执行了#uwsgi --plugin python --socket /django/logan/logan.sock --wsgi-file logan.py之后,来到/django/logan里就会发现里面多了一个粉嫩的logan.sock,默认权限是755:
DSC0000.png

  现在我们去浏览器里试试“外网地址:8000”,发现却是502,bad gateway:
DSC0001.png

  不要虚,去查看一下nginx的error.log,里面的反馈是这样的:
2017/03/17 16:57:06 [crit] 29123#0: *9 connect() to unix:///django/logan/logan.sock failed (13: Permission denied) while connecting to upstream, client: 60.191.94.120, server: 121.40.52.61, request: "GET / HTTP/1.1", upstream: "uwsgi://unix:///django/logan/logan.sock:", host: "121.40.52.61:8000"  既然说权限不足,nginx无法调用这个socket文件,那就#chmod 666 logan.sock加权限好了。
  然后我们再试试#uwsgi --plugin python --socket /django/logan/logan.sock --wsgi-file logan.py --chmod-socket=666,在浏览器上刷新一下“外网地址:8000”,就看到了logan.py里的“Good bye,Logan...”了,现在我们应该也可以用这个方法启动一下我们的django project,命令就是#uwsgi --plugin python --socket /django/logan/logan.sock --chdir /django/logan/ --wsgi-file  /django/logan/logan/wsgi.py  --chmod-socket=666
  现在我们在浏览器里打开“外网地址:8000/admin”,就会看到django的页面:
DSC0002.png

  当然了,打开media/logan.jpg一样会看到那张《金刚狼3》的电影海报。
  不过uwsgi启动命令太长了,uwsgi可以使用ini或者xml两个文件方式来简化启动命令,我们在/django/logan里建立一个uwsgi_logan.ini,里面的内容是这样的:
# mysite_uwsgi.ini file  
[uwsgi]
  
# Django-related settings
  
plugin          = python
  
# the base directory (full path)
  
chdir           = /django/logan/
  
# Django's wsgi file
  
wsgi-file          = /django/logan/logan/wsgi.py
  
# the virtualenv (我的python只有一个版本所以没有用这个,有的话这里需要填写全路径)
  
# home            = /path/to/virtualenv
  
# process-related settings
  
# master
  
master          = true
  
# maximum number of worker processes(这里的数字请根据自己实际情况填写,4个已经够用了)
  
processes       = 4
  
# the socket (填写全路径)
  
socket          = /django/logan/logan.sock
  
# ... with appropriate permissions - may be needed
  
chmod-socket    = 666
  
# clear environment on exit(退出的时候会清理)
  
vacuum          = true
  
pidfile = /django/logan/uwsgi_logan.pid    #确定pid的文件
  
daemonize = /django/logan/uwsgi_logan.log    #确定日志文件
  然后使用#uwsgi --ini /django/logan/uwsgi_logan.ini,来启动django吧。
  参考资料:http://uwsgi-docs.readthedocs.io/en/latest/tutorials/Django_and_nginx.html
  参考资料:http://stackoverflow.com/questions/23148082/in-django-nginx-wsgi-what-is-a-mysite-sock



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-632269-1-1.html 上篇帖子: FreeBSD+Nginx+Zabbix 下篇帖子: FreeBSD+nginx+php+fcgi配置步骤
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表