linux django环境变量,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上的软件包。详细的说明可参考:

下载安装文件[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

使用浏览器,访问网站

1f4cb4b7b88f

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 验证

1f4cb4b7b88f

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值