Linux+Apache+mod_wsgi+Django环境部署

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上的软件包。详细的说明可参考:

pip安装说明

下载安装文件

[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

使用浏览器,访问网站

Linux+Apache+mod_wsgi+Django环境部署_第1张图片

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


 Order deny,allow

 Allow from all

启动http服务

[root@localhost ~]# /etc/init.d/httpd restart

3.4 验证


Linux+Apache+mod_wsgi+Django环境部署_第2张图片

注意:如果不能访问,请确认服务器的防火墙(iptables)和selinux是否配置正确

你可能感兴趣的:(Linux+Apache+mod_wsgi+Django环境部署)