配置Apache和Django链接的过程可谓是一波三折,在此记录。php
零、基本的安装html
软件环境python
l Linux-3.2.0-4-amd64-x86_64-with-debian-7.7web
l python 2.7.3apache
l django 1.3.7django
l apache 2.2服务器
l mod_wsgi 3.3app
基本指令、模块的安装(需root权限)dom
l curl命令,用于命令行下访问网站,返回html内容curl
apt-get curl
l sudo命令
apt-get sudo
l mod_wsgi
apt-get install libapache2-mod-wsgi
1、使用apache2提供静态页面
Apache 预备知识
可执行程序 /usr/sbin/apache2
配置文件目录 /etc/apache2/
网站(web)文件目录 /var/www
网站文件目录是指站点所对应的文件目录,能够配置。站点的配置文件是在 /etc/apache2/sites-available/目录中的文件里配置的,如/etc/apache2/sites-available/default文件。在这个文件中,字段DocumentRoot后填写网站文件目录,好比网站文件目录改到/var/temp 那么就把这行改为:DocumentRoot /var/temp
配置文件(/etc/apache2/下)
配置文件并非在网上盛传的httpd.conf(这可能在之前的apache版本中有)里面,而是:
apache2.conf 基本的配置信息
ports.conf 端口
固然,也能够配置httpd.conf或者任一的.conf,apache会把配置文件目录下全部.conf结尾的配置文件载入进来。
Apache基本操做
$ su (切换成root用户,而后输入密码)
# service apache2 status # 查看状态
# service apache2 start # 启动
# service apache2 stop # 中止
# service apache2 reload # 从新应用配置文件
# service apache2 restart # 从新启动进程
# a2ensite xx # 激活xx站点
# a2dissite xx # 取消xx站点
# apachectl configtest # 检查一下 apache2 配置文件语法
主机名
主机名是用来指代域名(IP),能够直接输入主机名或域名来访问网站。主机名配置在/etc/hostname或/etc/hosts文件中。在Debian里是后者。
打开/etc/hosts(经过vi /etc/hosts 来打开,须要root权限),可将本地域名的主机名叫作localhost,将本机ip的主机名叫作lei,以下所示:
127.0.0.1 localhost
192.168.131.233 lei
此时开启Apache后,能够访问http://localhost,及http://lei ,将展现 It works!默认界面。
若是Linux的发行版是命令行式的,没有图形界面,就用curl http://localhost和curl http://lei来访问。
配置虚拟主机
上一步中访问的localhost和lei是默认页面,若是想访问本身的页面,须要进行以下配置:
$ cd /etc/apache2 # 进入 apache2 的配置目录
$ ls ./sites-enabled # 查看当前生效的站点
# 返回 000-default , 这是默认启动的站点
$ su
# a2dissite default # 取消默认站点 default
# 这时候sites-enabled目录下没有000-default
# service apache2 reload # 使配置生效
如今刷新一下 http://localhost/,应该已经不能访问了。
如今/etc/apache2/sites-available/目录下,创建一个名为 test的文件,为了清晰,写得尽量简单,具体内容以下:
<VirtualHost *:80>
ServerName localhost
DocumentRoot /var/www
</VirtualHost>
解释:
-------------------------------------------------------------
<VirtualHost *:80> #80是自定义的端口号
#要与/etc/apache2/ports.conf中Listen后的端口号一致
#如Listen 8001,则这里要写成<VirtualHost *:8001>
ServerName localhost #填写以前配置过的主机名
DocumentRoot /var/www #填写站点目录
</VirtualHost>
-------------------------------------------------------------
配置文件创建完毕后,要让它生效:
$ sudo su
# a2ensite test # 激活 test 站点
# ls /etc/apache2/sites-enabled/ # 查看当前生效的站点
# 返回 test ,表示test站点生效
# apachectl configtest # 检查一下 apache2 配置文件语法
返回结果:
apache2: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1 for ServerName
Syntax OK
在 apache2.conf 中增长主机名后,解决报错问题。添加以下:
ServerName localhost
从新检查配置文件语法,并从新载入:
# apachectl configtest # 此次结果应该只有 Syntax OK
# service apache2 reload
如今又可以正常访问 http://localhsot/ 。
2、配置 wsgi 模块
查看版本
$ sudo dpkg -l libapache2-mod-wsgi #查看wsgi的版本
# 结果: libapache2-mod-wsgi 3.3-4+deb7u1
$ a2enmod wsgi #验证模块安装正常
# 结果:Module wsgi already enabled
验证 wsgi
为了验证wsgi的正常使用,准备手工建一个最简单的wsgi应用,实际就是一个py脚本。
在 /var/www/目录下,创建一个名为 main.wsgi 文件,内容以下:
def application(environ, start_response):
status = '200 OK'
output = 'Hello World!'
response_headers = [('Content-type', 'text/plain'),
('Content-Length', str(len(output)))]
start_response(status, response_headers)
return [output]
在 /etc/apache2/sites-available/test中增长一行,同时能够取消DocumentRoot配置,修改后内容以下:
<VirtualHost *:80>
ServerName test
WSGIScriptAlias / /var/www/main.wsgi
</VirtualHost>
应用配置:
$ sudo service apache2 reload
如今刷新 http://localhost 可以返回Hello World! 说明 wsgi 解析正常。
3、配置 wsgi解析django
1. 在django工程目录下新建django.wsgi,并编辑以下:
import os
import sys
HERE = os.path.dirname(__file__)
sys.path.append(HERE)
sys.path.append(os.path.dirname(HERE))
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings'
#settings指工程目录下的settings.py
#若是该文件放在当前目录的xx文件夹下,就写成'xx.settings'
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()
2. 修改 apache2 的配置文件 /etc/apache2/sites-available/test,修改后的内容(其中/home/apache2/lei_web/为django工程目录):
<VirtualHost *:8001>
ServerName localhost
DocumentRoot /home/apache2/lei_web/
<Directory />
Options Indexes FollowSymLinks
AllowOverride None
</Directory>
<Directory /home/apache2/lei_web/>
Order allow,deny
Allow from all
</Directory>
WSGIScriptAlias / /home/apache2/lei_web/django.wsgi
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
3. 从新应用 apache2 配置文件
$ sudo service apache2 reload
访问 http://localhost/ ,可以看到 django 的 It Worked! 页面,说明django安装正常。
4、SVN配置
Apache进程进行svn前的配置
因为在Django工程中有进行svn操做的代码,Apache服务器启动Django后,是以www-data身份作系统中运行,无对应权限。这时须要用sudo以及相关的/etc/sudoers来帮忙。
修改sudo配置文件,直接键入visudo命令编辑配置文件:
1. 注释Defaults requiretty
Defaults requiretty修改成 #Defaults requiretty, 表示不须要控制终端。 不然会出现sudo: sorry, you must have a tty to run sudo。
2. 增长行 Defaults visiblepw
不然会出现 sudo: no tty present and no askpass program specified。sudo-1.6.9p17-5.el5不支持这个参数,sudo-1.7.2p1-10.el5支持。
3.在配置文件靠近尾部的地方有一行root ALL=(ALL) ALL,紧接着这行加入www-data ALL=(ALL) NOPASSWD:/usr/bin/svn *
注:NOPASSWD能够使在命令执行时不须要交互输入www-data用户的密码
参考连接:
django 1.5.1 apache2 wsgi 配置教程 http://blog.chinaunix.net/uid-23500957-id-3838223.html
php如何控制svn更新代码 http://blog.csdn.net/ownfire/article/details/9187177