CentOS 4.8 配置 nginx 和 fastcgi 运行 django 应用(下)

四、安装 flup 支持 FastCGI
nginx 默认已经整合了mod_fastcgi,所以我们只需要安装 flup
# tar zxvf flup-1.0.2.tar.gz
复制文件到 flup 目录
# cp flup-1.0.2-py2.5.egg flup-1.0.2/
# cd flup-1.0.2
# python setup.py install

打开 nginx 配置文件 conf/nginx.conf 修改为:
……
location / {
fastcgi_pass unix:/opt/mysite/mysite.sock; // 只能在 linux 或 unix 使用
fastcgi_pass 127.0.0.1:8501; // 通用,包括 windows 也可以使用
include fastcgi_params; // 注释文件中的SCRIPT_NAME
}
……

重启启动 nginx
# /usr/local/nginx/sbin/nginx -s reload
运行 FastCGI,在 /opt/mysite 项目下执行
# python manage.py runfcgi method=threaded host=127.0.0.1 port=8501

在系统中查看 python 进程
# ps -ef | grep python
root 22976 1 4 21:47 00:00:00 python manage.py runfcgi host=127.0.0.1 port=8501
root 22977 22976 0 21:47 00:00:00 python manage.py runfcgi host=127.0.0.1 port=8501
root 22978 22976 0 21:47 00:00:00 python manage.py runfcgi host=127.0.0.1 port=8501
root 22979 22976 0 21:47 00:00:00 python manage.py runfcgi host=127.0.0.1 port=8501
root 22980 22976 0 21:47 00:00:00 python manage.py runfcgi host=127.0.0.1 port=8501
root 22981 22976 0 21:47 00:00:00 python manage.py runfcgi host=127.0.0.1 port=8501

以上说明启动成功,再通过浏览器访问 nginx 即可出现 django 的主界面。

补充:也可以利用负载均衡的方式配置,修改 nginx.conf 文件,关键几点如下:
worker_processes 2;#开2个nginx进程,在任务管理器可以看到这2个子进程和一个nginx主进程,一般按CPU数配置
events {
worker_connections 64;#每个进程链接队列长度,可按实际设置
}
http {
... # 省略其它配置
# upstream 段要放在 http 段中
# 和后端的2个 fastcgi 服务通讯,weight是权重
upstream fastcgi {
server 127.0.0.1:8051 weight=1;
server 127.0.0.1:8052 weight=1;
}
server {
listen 80;
server_name localhost;
...# 省略其它配置
location / {
# 指定 fastcgi 的主机和端口,这里的 fastcgi 指的是上面的upstream
fastcgi_pass fastcgi;
fastcgi_index index;
fastcgi_param SCRIPT_FILENAME /script$fastcgi_script_name;
include fastcgi_params;
}
...# 省略其它配置
}
...# 省略其它内容
}

运行2个fastcgi服务,开 2 个命令窗口,在 /opt/mysite 目录下运行:
# python manage.py runfcgi host=127.0.0.1 port=8501 method=threaded daemonize=false
# python manage.py runfcgi host=127.0.0.1 port=8502 method=threaded daemonize=false

开 2个 fastcgi 的命令窗口,终止其中一个访问看看,其实没有任何影响。再把运行的停止,停止的启动看看,还是能访问。若2个都终止,发现不能访问。
在 nginx 的集群配置中,nginx 使用最简单的平均分配规则给集群中的每个节点分配请求。一旦某个节点失效时,或者重新起效时,nginx 都会非常及时的处理状态的变化,以保证不会影响到用户的访问。


五、安装 uWSGI 代替 FastCGI
uwsgi 是一个用 c 语言开发的一个 wsgi 服务器,旨在提供专业的 Python web 应用发布和开发,网上测评性能高于 FastCGI
官方网站:http://projects.unbit.it/uwsgi/
下载最新的版本,编译安装
# tar zxvf uwsgi-0.9.6.8.tar.gz
# cd uwsgi-0.9.6.8
# make
将编译的二进制文件复制到系统路径
# cp uwsgi /usr/bin

修改 nginx 配置文件:
……
location / {
include uwsgi_params;
uwsgi_pass 0.0.0.0:9000;
}
……
修改完成后,重新启动 nginx

与 fastcgi 不同的是它需要一个启动文件,位置 /opt/uwsgi/mysite.py
#!/usr/bin/env python
#encoding=utf-8
import os,sys
import django.core.handlers.wsgi

os.environ['DJANGO_SETTINGS_MODULE'] = 'mysite.settings'

path = '/opt'
if path not in sys.path:
sys.path.append(path)
print sys.path

application = django.core.handlers.wsgi.WSGIHandler()

启动 uwsgi ,注意 mysite 不要扩展名 .py
# uwsgi -s :9000 -w /opt/uwsgi/mysite

其它启动参数:
并发4个线程
uwsgi -s :9000 -w myapp -p 4
主控制线程+4个线程
uwsgi -s :9000 -w myapp -M -p 4
执行超过30秒的client直接放弃
uwsgi -s :9000 -w myapp -M -p 4 -t 30
限制内存空间128M
uwsgi -s :9000 -w myapp -M -p 4 -t 30 --limit-as 128
服务超过10000个req自动respawn
uwsgi -s :9000 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000
后台运行等
uwsgi -s :9000 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000 -d uwsgi.log
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值