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

来源:互联网 发布:见之不若知之 编辑:程序博客网 时间:2024/05/22 11:45
上篇
一、安装 nginx 
为了确保能在 nginx 中使用正则表达式进行更灵活的配置,安装之前需要确定系统是否安装有 PCRE (Perl Compatible Regular Expressions) 包。 
可以到 ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/ 下载最新的PCRE源码包 
使用下面命令编译和安装: 
# tar zxvf pcre-7.8.tar.gz 
# cd pcre-7.8 
# ./configure 
# make 
# make install 

安装 Nginx,下面是把 Nginx 安装到 /usr/local/nginx 目录下: 
# tar zxvf nginx-0.7.65.tar.gz 
# cd nginx-0.7.65 
去掉 nginx 默认使用 debug 模式编译 
# vi auto/cc/gcc 
…… 
CFLAGS="$CFLAGS -g" //注释掉这一行 
…… 
可以优化的选项 
--with-cc-opt=-O2 
--with-cpu-opt=CPU  build for specified CPU, the valid values:pentium, pentiumpro, pentium3, pentium4,athlon, opteron, sparc32, sparc64, ppc64 
# ./configure --with-http_stub_status_module 
# make 
# make install 

其中参数 --with-http_stub_status_module 是为了启用 nginx 的 NginxStatus 功能,用来监控 nginx 的当前状态。 
其它可选参数: --with-md5=/usr/lib --with-sha1=/usr/lib --with-openssl=/usr/lib/ssl/ --with-http_ssl_module 
安装成功后 /usr/local/nginx 目录下有四个子目录分别是:conf、html、logs、sbin 。其中配置文件位于conf/nginx.conf,程序文件位于 sbin/nginx。 
确保系统的 80 端口没被其他程序占用,运行 sbin/nginx 命令来启动 nginx,打开浏览器访问此机器的IP,如果浏览器出现 Welcome to nginx! 则表示已经安装并运行成功。 

二、安装 Python 和 MySQL-python 
Django1.2.7 推荐 Python 是 2.5 以上的版本,首先要安装 Python 2.5.4 
#t ar zxvf Python-2.5.4.tgz 
# cd Python-2.5.4 
# ./configure 
# make 
# make install 

安装 Python 连接 MySQL 的模块,先需要安装 MySQL,安装路径:/usr/local/mysql5.1 
# tar zxvf MySQL-python-1.2.2.tar.gz 
# cd MySQL-python-1.2.2 
设置 mysql_config 的路径 
#  vi site.cfg 
...... 
mysql_config = /usr/local/mysql5.1/bin/mysql_config 
...... 
# chmod +x setup.py 
# ./setup.py build 
# ./setup.py install 
测试是否安装成功 
# python 
>>>import MySQLdb 
......报错,libmysqlclient_r.so.16 没找到。 
ImportError: libmysqlclient_r.so.16: cannot open shared object file: No such file or directory 
..... 
解决方法 
# updatedb 
# locate libmysqlclient_r.so.16 
/usr/local/mysql5.1/lib/mysql/libmysqlclient_r.so.16.0.0 
/usr/local/mysql5.1/lib/mysql/libmysqlclient_r.so.16 
#vi /etc/ld.so.conf 
加入动态库文件的路径:/usr/local/mysql5.1/lib/mysql/ 
# ldconfig  -v 

再次测试,执行成功! 

动态链接库的管理命令 ldconfig 说明: 
1、ldconfig命令的用途:主要是在默认搜寻目录(/lib 和 /usr/lib)以及动态库配置文件 /etc/ld.so.conf 内所列的目录下,搜索出可共享的动态链接库(格式如前介绍,lib*.so*), 
进而创建出动态装入程序(ld.so)所需的连接和缓存文件。缓存文件默认为 /etc/ld.so.cache,此文件保存已排好序的动态链接库名字列表。 
2、ldconfig通常在系统启动时运行,而当用户安装了一个新的动态链接库时,就需要手工运行这个命令。 

三、安装 Django 
# tar zxvf Django-1.2.7.tar.gz 
# cd Django-1.2.7 
# python setup.py install 

利用 Django 创建新的站点,假设在 /opt 下新建站点 mysite 
# cd /opt 
查看 Django 工具的帮助信息 
# django-admin.py help 

利用 startproject 选项创建站点 mysite 
# django-admin.py startproject mysite 
默认为新建目录 mysite ,该目录下有四个文件:__init__.py  manage.py  settings.py  urls.py 

查看新站点管理工具的帮助信息 
# cd mysite 
# python manage.py help 
启动测试服务器,验证是否安装成功 
# python manage.py runserver 
启动成功则出现如下信息: 
Validating models... 
0 errors found 

Django version 1.0.2 final, using settings 'mysite.settings' 
Development server is running at http://127.0.0.1:8000/ 
Quit the server with CONTROL-C. 

注意测试服务器只能本机访问。
 
下篇
四、安装 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
原创粉丝点击