Django1.4 python2.7 apache mod_python 安装与部署实例
花了四、五天时间终于把Django1.4 + python2.7 + apache + mod_python环境搭好,并通过实例验证。本文整合了网上的可用资源并解决了当前网络没有提到的问题,比如apache部署djang1.4问题。
另外,本文所提到的所有包没有用yum自动安装,都是完全手动安装,这样能够更好地了解整个项目流程,同时锻炼自己linux的熟练程度(特别是对于新手)。
目录:
一、实验环境
二、Gcc安装(RPM手动安装)
三、安装Apache2
四、安装python2.7
五、安装mod_python
六、安装部署django
一、实验环境
Centos5.5
Apache2: httpd-2.2.22.tar.gz
http://www.fayea.com/apache-mirror//httpd/httpd-2.2.22.tar.gz
python2.7: Python-2.7.2.tar.bz2
http://www.python.org/ftp/python/2.7.2/Python-2.7.2.tar.bz2
django1.4: Django-1.4.2.tar.gz
https://www.djangoproject.com/download/1.4.2/tarball/
mod_python: mod_python-3.3.1.tgz
http://archive.apache.org/dist/httpd/modpython/mod_python-3.3.1.tgz
注意1:因为python是用C写的,所以需要用gcc进行编译,所以需要先安装gcc。如果机器没有安装gcc,请先按第二节的内容安装gcc。
注意2:本次实验所用linux kernel版本为centos5.5。最新版本为centos6,编译安装大同小异,步骤都差不多,只是有些包需要更新的版本。相信对linux稍微熟悉的人都应该能搞定,本文不再介绍。
二、Gcc安装(RPM手动安装)
如果机器已装gcc,请跳过此节。
需要的包:
kernel-headers-2.6.18-308.el5.x86_64.rpm
glibc-headers-2.5-49.x86_64.rpm
glibc-devel-2.5-49.x86_64.rpm
libgomp-4.4.0-6.el5.x86_64.rpm
gcc-4.1.2-48.el5.x86_64.rpm
如果还要装c++(optional):
libstdc++-devel-4.1.2-52.el5.x86_64.rpm
cpp-4.1.2-48.el5.x86_64.rpm
安装步骤:
rpm –ivh kernel-headers-2.6.18-308.el5.x86_64.rpm
rpm –ivh glibc-headers-2.5-49.x86_64.rpm
rpm –ivh glibc-devel-2.5-49.x86_64.rpm
rpm –ivh libgomp-4.4.0-6.el5.x86_64.rpm
rpm –ivh gcc-4.1.2-48.el5.x86_64.rpm
这里用rpm –ivh命令进行安装,如果提示系统中已存在较旧版本,先把rpm –ivh替换为rpm –Uvh。
另外,请注意自己机器是64位还是32位的,如果是64位机器,请下载后缀为*.x86_64.rpm的包。如果是32位机器,请下载后缀为*.i386.rpm的包。
安装完后在命令行打rpm -qa|grep gcc。出现
libgcc-4.1.2-48.el5.x86_64
gcc-4.1.2-48.el5.x86_64
之类的结果,证明安装完成。
三、安装Apache2
安装apache听似简单,由于我们应用需要apache模块共享,所以不能按网上的一般配置。
(1)进入httpd-2.2.22.tar.gz所在目录
(2)tar -zvxf httpd-2.2.22.tar.gz
(3)cd httpd-2.2.22
(4) ./configure --prefix=/opt/apache --with-config-file-path=/opt/apache/conf --enable-mods-shared=most --enable-track-vars --enable-cgi --enable-so --enable-file-cache --enable-disk-cache --enable-cache --enable-mem-cache --enable-dumpio --enable-logio --enable-mime-magic --enable-headers --enable-usertrack --enable-version --enable-ssl --enable-http --enable-rewrite --enable-proxy --enable-proxy-connect --enable-proxy-http --enable-proxy-ftp --enable-proxy-ajp --enable-proxy-balancer
(5)make
(6)make install
注意:我们enable了很多功能,以便以后开发其他应用。但上面这样的./configure方面会出现某些包没有的情况。如果不想太麻烦,就把缺少的包的相关选项去掉吧。比如,我的机器没有装openssl,按上面的配置会报错,于是我把—enable-ssl去掉,编译安装通过。
这样,我们就把apapch装到/opt/apache下面了。
相关操作(启动、重启、停止):
首先到apache的bin目录下
#cd bin
启动apache:
#./apachectl start
然后在浏览器中输入http://localhost就可以看见it works!的字样。
重启apache:
#./apachectl restart
关闭apache:
#./apachectl stop
注意1:使用apache过程中如果出现
httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1 for ServerName
之类的错误
解决办法非常简单:
#vim /opt/apache/conf/httpd.conf (在这里/opt/apahce是我安装apache的目录,你默认安装的话应该是/usr/local/apache2/icons)
找到#ServerName www.example.com:80 把#去掉,再重启apache即可没事了。
注意2:如果报的错误是:
Stopping httpd: [FAILED]
Starting httpd: (98)Address already in use: make_sock: could not bind to address [::]:80
(98)Address already in use: make_sock: could not bind to address 0.0.0.0:80
no listening sockets available, shutting down
Unable to open logs
80端口被其他程序占用,
fuser -k -n tcp 80
再重新启动。
四、安装python2.7
Django本身是纯Python编写的,所以安装框架的第一步是确保你已经安装了Python。核心Django框架可以工作在2.x上。对于最新版本的python 3.x,网上有些资料说流行的Django框架暂时还不支持。所以,我们安装python2.7版本。
一般linux系统会自带Python,一般是2.4版本的,我们需要重新安装,这里注意,不要使用yum安装,而要用源码编译的方法安装,不然下面在配置之后会出错。
下面的步骤是整个项目的核心,请集中注意力!!!任何一招棋错,什么都会输!!!
1、安装readline-devel
为什么要装readline-devel?因为自定义安装的python库中没能找到readline相关库,导致安装后退格,方向键无法正常使用。
下载readline-devel-5.1-3.el5.x86_64.rpm
rpm –ivh readline-devel-5.1-3.el5.x86_64.rpm
2、安装python2.7
#tar -xvf Python-2.7.tar.bz2
#cd Python-2.7
#./configure --enable-shared
这里一定要注意,解压完之后要设置enable-shared,这样编译后会链接成共享对象,供apache使用
这里不要急着make && make install!!
django会用到zlib相关的库,所以这里先把zlib库加进来(原理请到http://www.cnblogs.com/lexus/archive/2012/02/23/2365660.html 精读)
#cd Modules/zlib
#./configure --shared 后面这个--shared一定要加,没加它哥哥我调试了几个小时T_T
#make && make install
然后再回到python2.7的目录
#cd ../..
#make && make install
#python setup.py install
相关文章:
http://jisedai.vayn.de/2011/06/28/python-3-installation-note.html
3、运行测试
在命令行打入python。
a) 这时可能会出现以下错误
python: error while loading shared libraries: libpython2.7.so.1.0:
cannot open shared object file: No such file or
解决方案:
新建下面文件
vim /etc/ld.so.conf.d/python2.7.conf
加入内容:
/usr/local/lib
保存退出后运行:
ldconfig
再次执行 python,问题成功解决。
b) 上述问题解决后或是没有出现。再执行python
import zlib >>> exit()
没有问题了。
注意1:如果出现错误:
/usr/local/lib/python2.7/config/libpython2.7.a: could not read symbols: Bad value
collect2: ld returned 1 exit status
apxs:Error: Command failed with rc=65536
这是因为安装python的时候,没有 ./configure --enable-shared
加上后重新编译,然后运行python
注意2:重新编译时出现类似下面错误:
/bin/sh /usr/local/httpd-2.2.3/srclib/apr/libtool --mode=install /usr/bin/install -c -m 755 libaprutil-1.la /usr/local/apache2/lib
libtool: install: error: cannot install `libaprutil-1.la' to a directory not ending in /usr/local/apache22/lib
make[2]: *** [install] Error 1
原因是原先安装编译时候的垃圾文件没有清理。解决方法很简单,回来configure文件所在目录
#make clean
#make distclean
完成后就能重新./configure && make && make install了
五、安装mod_python
本项目决定用mod_python作为apache部署django的模块驱动。但在django的官网上提到mod_python将会成为过去时,在未来的某个django版本中,mod_python将被抛弃,进而用mod_wsgi取代。考虑到时间因素,我们占时使用仍然比较健壮的mod_python+apache+python组合,在未来慢慢改为mod_wsgi。官网资料如下:
https://docs.djangoproject.com/en/1.2/howto/deployment/modpython/
(1) 进入mod_python所在目录
(2)tar -zvxf mod_python-3.3.1.tgz
(3)cd mod_python-3.3.1
(4)./configure --with-apxs=/opt/apache/bin/apxs --with-python=/usr/local/bin/python2.7
(5)make
注意:这里有一个bug
connobject.c: In function '_conn_read':
connobject.c:142: error: request for member 'next' in something not a structure
or union
apxs:Error: Command failed with rc=65536
make[1]: *** [mod_python.so] Error 1
make[1]: Leaving directory `/usr/src/rpm/BUILD/mod_python-3.3.1/src'
make: *** [do_dso] Error 2
需修改mod_python-3.3.1/src/connobject.c中
!(b == APR_BRIGADE_SENTINEL(b)
为
!(b == APR_BRIGADE_SENTINEL(bb)
完毕之后,mod_python 会在 /opt/apache/modules 中添加 mod_python.so 库文件,并且在/usr/local/bin/python2.7/site-packages 中添加 mod_python 包。
如果编译程序没有检测到 apache 和 python,会报错退出。
=====================================================================
上面步骤弄好后
配置 httpd.conf
找到 /opt/apache/conf/httpd.conf 配置文件,在适当(文件中LoadModule所在位置)位置添加:
LoadModule python_module modules/mod_python.so
注意:上面这句话非常非常重要,要跟所有LoadModule 配置放到一起,如果加到最后无法找到这个模块。
相关文章:
http://blog.csdn.net/boycycyzero/article/details/7339500
http://xiaoyu9805119.blog.163.com/blog/static/4209156200731932353684/
六、安装部署django
本项目django版本为1.4.2。虽然网上有很多介绍django安装资料,但由于版本不同,安装django并把django部署到apache上的方法也有差别。换句话说,现在关于django1.4部署到apache上的中文资料只有我这篇文章可靠!!
(1)进入django所在目录
(2)#cd Django-1.4.2
(3)#python2.7 setup.py install
(4)测试,#python>>>import django>>>django.VERSION 出现相关版本号
安装很简单,完成。
配置部署一个项目:
(1)进入你要建立项目的目录,比如/opt/apache/htdocs
(2)建立一个项目
# django-admin.py startproject dongxinpeng
对于早期版本的django来说,执行上述命令会出现一个叫dongxinpeng的文件夹,里面有4个文件:__init__.py, manage.py, settings.py, urls.py
然而,在django1.4中执行上述命令出现的东西不一样,目录结构如下
dongxinpeng
-------manage.py
-------dongxinpeng
--------------settings.py
--------------urls.py
--------------__init__.py
--------------wsgi.py
因此,如果不是完全了解运行机制的话,按网上的配置方法根本行不通!
下面配置 httpd.conf
找到 /opt/apache/conf/httpd.conf 配置文件,在文件中的
# Virtual hosts
#Include conf/extra/httpd-vhosts.conf
后面加上
ServerName www.example.com
SetHandler python-program
PythonHandler django.core.handlers.modpython
PythonPath "['/opt/apache/htdocs/dongxinpeng'] + sys.path"
SetEnv DJANGO_SETTINGS_MODULE dongxinpeng.settings
PythonDebug On
保存,退出。
重启apache。
相关文章:
http://blog.csdn.net/wulei202/article/details/7667473
http://www.cnblogs.com/oubo/archive/2012/04/06/2434961.html
http://blog.csdn.net/wklken/article/details/7389502
(3)测试django
在浏览器中输入http://localhost/dongxinpeng
出现:
It worked!
Congratulations on your first Django-powered page.