首页 > 代码库 > nginx+Uwsgi+Django总结与分析
nginx+Uwsgi+Django总结与分析
配置与调试nginx与uwsgi
<vacuum/>#退出清理
</uwsgi>
#多个项目时候需要
可能使用的命令
这些内容也就是这几天的了 网站备案时间太长慢慢等吧 这事情可以放一放了
参考:
1.uWSGI其三:uWSGI搭配Nginx使用
2.学习VirtualEnv和Nginx+uwsgi用于django项目部署
3.部署备忘
4.nginx+uwsgi
5.编程小结
6.nginx + uwsgi + django + python 部署
最近三天一直在调试Django+nginx+uwsgi+sqlite3部署的阿里云的服务器,系统是ubuntu的所以下载什么的都很方便sudo spt-get就可以了
所以想着把这几天遇到的问题跟过程fork下来以后或许会遇到
项目tree 命令的话tree -L 2
├── manage.py
├── mysite
│ ├── __init__.py
│ ├── __init__.pyc
│ ├── settings.py
│ ├── settings.pyc
│ ├── urls.py
│ ├── urls.pyc
│ ├── wsgi.py
│ └── wsgi.pyc
├── uwsgi.xml
└── app_name(weixin)
├── admin.py
├── build
├── __init__.py
├── models.py
├── templates
├── tests.py
└── views.py
1.nginx
nginx可以作为WEB Server,反向代理,负载均衡等服务。我用它基本是为了处理static file的
关于/etc/nginx/site-enables/下面可以创建一个文件
----->因为在run service nginx stop时候是运行的默认conf
也就是/etc/nginx/nginx.conf---->这个文件中会导入/etc/nginx/site-enables/下的配置还有/etc/nginx/nginx.d/下的
当然你也可以run指定的配置 nginx -c 即可 如下给出的配置
server {
listen 80;
server_name 10.1.6.79;
#server_name可以是域名如我的zoues.comwww.zoues.com 都可以写但是要空格最后是;
access_log
/var/log/nginx/example_access
.log;
#这边的log覆盖了/etc/nginx/nginx.conf设置的log如果这边不写的话log都在/var/log/nginx下面
error_log
/var/log/nginx/example_error
.log;
root
/var/www/example
;
location / {
uwsgi_pass 127.0.0.1:9001;
#这个是跟uwsgi配置关联 也就是2者的通信口可以是socket-->unix的跟ip方式都可以
但是unix的方式要创建文件
include uwsgi_params;
#一定要包涵
#
uwsgi_param UWSGI_SCHEME $scheme;
#
uwsgi_param SERVER_SOFTWARE nginx/$nginx_version;
}
}
2.uwsgi的选择 因为django特有的uwsgi协议所以选择uwsgi也是情理之中了
uWSGI的主要特点如下:
超快的性能。
低内存占用(实测为apache2的mod_wsgi的一半左右)。
多app管理。
详尽的日志功能(可以用来分析app性能和瓶颈)。
高度可定制(内存大小限制,服务一定次数后重启等)
这配置中关键还是参数的理解
<uwsgi>
<plugin>python</plugin>
<plugin>python</plugin>
# 记下Django所在的Python版本,然后通过下面的命令切换uwsgi的默认Python版本(一般不需要切换)
<socket>127.0.0.1:9001</socket>
<socket>127.0.0.1:9001</socket>
#也就是nginx下配置的uwsgi_pass
<pythonpath>/var/www/example/app/</pythonpath>
<pythonpath>/var/www/example/app/</pythonpath>
#pythonpath很重要 可以配置多个是为了寻找下面的<script>以及<module>的 配置的时候一定要对应你配置的某一个pythonpath 然后写<script>和<module>跟python中from * import *的关系是一致的
#当然你若嫌麻烦的话就使用wsgi-file吧 一站到底啊
<app mountpoint="/">
<script>wsgi_configuration_module</script>
</app>
<master/>
<processes>4</processes>
<reload-mercy>8</reload-mercy>
<cpu-affinity>1</cpu-affinity>
<max-requests>2000</max-requests>
<limit-as>512</limit-as>
<reload-on-as>256</reload-on-as>
<reload-on-rss>192</reload-on-rss>
<app mountpoint="/">
<script>wsgi_configuration_module</script>
</app>
<master/>
<processes>4</processes>
<reload-mercy>8</reload-mercy>
<cpu-affinity>1</cpu-affinity>
<max-requests>2000</max-requests>
<limit-as>512</limit-as>
<reload-on-as>256</reload-on-as>
<reload-on-rss>192</reload-on-rss>
<daemonize>/var/log/uwsgi.log</daemonize>
#这个是日志 最好写上
<no-orphans/><vacuum/>#退出清理
</uwsgi>
这个通过uwsgi -x xxx.xml去运行 需要xml模块(具体不记得了我没遇到不能运行的情况)
下面给出的是ini的配置
# uwsgi_XXX.ini file
[uwsgi]
# Django-related settings
# the base directory (full path)
chdir = /var/www/<project path>
# Django‘s wsgi filemodule = <project name>.wsgi
# the virtualenv (full path)
home = <virtualenv path>
# process-related settings
# master
master = true
# maximum number of worker processes
processes = 10
# the socket (use the full path to be safe
socket = /var/www/<project path>/<project name>.sock
# ... with appropriate permissions - may be needed
# chmod-socket = 664
# clear environment on exit
vacuum = true
daemonize = /var/log/uwsgi.log
pidfile=/var/www/<project path>/uwsgi.pid
列2:这边是直接配置的wsgi-file所以也就没了pythonpath这个配置了
[uwsgi] |
02 | vhost = false |
03 | plugins = python |
04 | socket = 127.0 . 0.1 : 8077 |
05 | master = true |
06 | enable - threads = true |
07 | workers = 1 |
08 | wsgi - file = / root / nowamagic_venv / nowamagic_pj / nowamagic_pj / wsgi.py |
09 | virtualenv = / root / nowamagic_venv |
10 | chdir = / root / nowamagic_venv / nowamagic_pj |
1. 关闭 uWSGI:
1 | killall -9 uwsgi |
2 | killall -s HUP /var/www/uwsgi |
3 | killall -s HUP /usr/ local /bin/uwsgi |
2. 列出端口占用情况:
1 | netstat -lpnt |
下面写论文把那鸟项目做了 酱油打了太多 真是...
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。