1. 部署环境说明
操作系统:Redhat 6.7
Python版本:2.7.14
Django版本:1.8.18 LTS
Apache版本:2.2.15
2. 软件安装
2.1 安装Python
下载tar包
[root@localhost tools]# wget https://www.python.org/ftp/python/2.7.14/Python-2.7.14.tgz
安装
[root@localhost tools]# tar -zxvf Python-2.7.14.tgz
[root@localhost tools]# cd Python-2.7.14
[root@localhost Python-2.7.14]# ./configure --enable-shared CFLAGS=-fPIC ; make; make install
注意:本人使用的是root用户,如果使用普通用户请使用sudo执行make install。
默认的安装路径在/usr/local/bin/目录下。如果系统中有老版本的Python版本,对于普通用户而言,采用该方式安装即可。
[wangyd@localhost ~]$ python --version
Python 2.7.14
注意:如果执行Python命令时,提示libpython2.7.so找不到,可执行以下命令,将库的路径追加到环境变量中
[root@localhost HelloWorld]# echo "/usr/local/lib" >> /etc/ld.so.conf
[root@localhost HelloWorld]# ldconfig
但对于root用户而言,根据root默认的环境变量顺序,在执行python命令时,系统会优先从/usr/bin/目录下查找对应的执行程序,所以执行的还是老版本的python。想要让系统执行最新版本的python有三种方式:
① 使用全路径的方式/usr/local/bin/python
② 建立/usr/bin/python软连接,将其指向/usr/bin/local/python
③ 在root用户配置文件中(/root/.bash_profile)增加alias,
alias python='/usr/local/bin/python'
2.2 安装pip
pip是一个Python包管理工具,主要是用于安装PyPI上的软件包。详细的说明可参考:
下载安装文件
[root@localhost tools]# wget https://bootstrap.pypa.io/get-pip.py
安装
[root@localhost tools]# /usr/local/bin/python get-pip.py
确认
[root@localhost tools]# pip --version
pip 9.0.1 from /usr/local/lib/python2.7/site-packages (python 2.7)
2.3 安装Django
安装
[root@localhost tools]# pip install Django==1.8.18
确认
[root@localhost tools]# /usr/local/bin/python
Python 2.7.14 (default, Dec 1 2017, 16:48:54)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-16)] on linux2 Type "help", "copyright", "credits" or "license" for more information.
>>> import django
>>> django.VERSION (1, 8, 18, 'final', 0)
2.4 Apache
安装
略(系统默认已经安装Apache,故不再记述)
确认
[root@localhost tools]# apachectl -v
Server version: Apache/2.2.15 (Unix)
Server built: Mar 3 2015 12:06:14
2.5 mod_wsgi
安装
[root@localhost mod_wsgi-4.5.22]# pip install mod_wsgi
ps:如果执行失败请确认Python安装过程中,选项是否正确(--enable-shared CFLAGS=-fPIC)
确认
[root@localhost HelloWorld]# ls /usr/local/lib/python2.7/site-packages/mod_wsgi/server/ | grep mod_wsgi
mod_wsgi-py27.so
3. 部署&配置
3.1 测试Django
生成
[wangyd@localhost ~]$ mkdir workspace_python
[wangyd@localhost ~]$ cd workspace_python/
[wangyd@localhost workspace_python]$ django-admin startproject HelloWorld
修改配置
修改HelloWorld/settings.py,运行任何IP访问该网站
ALLOWED_HOSTS = ['*']
测试
[wangyd@localhost HelloWorld]$ python manage.py runserver 0.0.0.0:8000
使用浏览器,访问网站
3.2 移动部署文件
为避免权限访问的问题,可将已开发的网站文件拷贝到/var/www/文件夹下:
[root@localhost HelloWorld]# cp -r /home/wangyd/workspace_python/HelloWorld /var/www/
修改文件夹权限:
[root@localhost www]# chown -R apache HelloWorld
目录结构:
[root@localhost www]# ls -R /var/www/HelloWorld/
/var/www/HelloWorld/:
db.sqlite3
HelloWorld
manage.py
/var/www/HelloWorld/HelloWorld:
__init__.py
__init__.pyc
settings.py
settings.pyc
urls.py
urls.pyc
wsgi.py
wsgi.pyc
3.3 配置Apache&mod_wsgi
配置mod_wsgi:
修改/etc/httpd/conf.d/wsgi.conf文件,将以下内容复制到文件中:
#LoadModule wsgi_module modules/mod_wsgi.so
LoadModule wsgi_module modules/mod_wsgi-py27.so
WSGIScriptAlias / /var/www/HelloWorld/HelloWorld/wsgi.py
#WSGIPythonHome /root/ENV
WSGIPythonPath /var/www/HelloWorld
<Directory /var/www/HelloWorld>
<Files wsgi.py>
Order deny,allow
Allow from all
</Files>
</Directory>
启动http服务
[root@localhost ~]# /etc/init.d/httpd restart
3.4 验证
注意:如果不能访问,请确认服务器的防火墙(iptables)和selinux是否配置正确