首先安装好python2.7 和 apache http server 服务器。
下载 mod_wsgi
什么是mod_wsgi ?
mod_wsgi的目标是实现一个简单的Apache模块,支持任何Python WSGI的接口的Python应用程序的托管。该模块适用于高性能生产的WEB站点,同时也适用于自己维护站点的WEB 服务托管(虚拟主机环境–译者注)。
运行模式
用mod_wsgi来托管应用,有两个主要的模式可以使用,一种是“嵌入式”模式,Mod_wsgi与Mod_python运行方式相同,所有的 python代码都将在apache 子进程中执行。因此当WSGI应用在此模式下运行可以与其他的Apache托管的模块PHP和Perl共享形同进程。
另一个在UNIX Apache 2.*环境下可选替代的daemon模式,这种模式运作的方式在类似的FastCGI / SCGI解决方案,即在不同的进程运行WSGI应用。与FastCGI / SCGI解决方案不同的是,当执行WSGI程序时不需要单独的基础结构(infrastructure),一切都是自动处理的mod_wsgi。
一切都是自动处理的mod_wsgi,影响正常使用的Apache模块的PHP , Perl或其他语言的Apache子进程服务的静态文件和主机应用程序使用大大减少。守护(daemon)进程可能需要时也可以作为一个独特的用户运行以确保WSGI应用程序之间不能互相干扰或获取信息。
服务性能
该mod_wsgi模块是用C代码直接对内部的Apache和Python应用程序接口编程。因此,服务WSGI应用与Apache它具有较低的内存开销和性能优于现有的WSGI适配器mod_python或替代的FastCGI / SCGI / CGI或代理的解决方案。
虽然嵌入式技术模式能够表现得更好, daemon模式通常是最安全的选择使用。这是因为要嵌入模式高性能需要调整apache MPM设置,默认设置偏向于服务静态媒体和PHP应用。如果Apache 的MPM设置未与服务的应用相对应,将会表现出糟糕的性能而不是更好的性能。
因此,除非你非常熟悉Aapache的配置,否则推荐使用daemon模式,总体而言,大型Python Web程序,通常你不能看出嵌入式(embedded mode)和守护模式(daemon mode)明显的差异,因为瓶颈在Python Web和数据库访问上。
支持的应用
mod_wsgi遵循WSGI接口规范,任何符合WSGI接口规范的Python Web框架或者应用都可以被支持。
我们所熟悉的主要的Python web框架或工具,包括CherryPy, Django, Karrigell, Pylons, TurboGears, web.py, Werkzeug 和Zope 运行良好,我们所熟知的主要的Python web应用包括MoinMoin, PyBlosxom 和 Trac 能够很好的运行。
下载地址: http://code.google.com/p/modwsgi/downloads/list
挑选For 2.7的版本下载,改名成mod_wsgi.so,然后扔到apache的modules目录就可以了。
在apache的conf/httpd.conf文件中加入:
LoadModule wsgi_module modules/mod_wsgi.so
在D:\dgwww目录执行:
python C:\Python27\Lib\site-packages\django\bin\django-admin.py startproject mysite
然后在D:\dgwww下分别创建js,media,conf三个目录,在conf下创建文件setting.wsgi,内容如下:
import os
import sys
sys.stdout = sys.stderr
from os.path import abspath, dirname, join
from django.core.handlers.wsgi import WSGIHandler
sys.path.insert(0, abspath(join(dirname(__file__), "../")))
os.environ["DJANGO_SETTINGS_MODULE"] = "mysite.settings" #your settings module
application = WSGIHandler()
至此,整体目录结构如下:
/dgwww/ |~conf/ | `-setting.wsgi |~js/ |~media/ `~mysite/ |-__init__.py |-__init__.pyc |-manage.py |-settings.py |-settings.pyc |-urls.py `-urls.pyc
2)修改setting.py、urls.py
在setting.py中修改:
ADMIN_MEDIA_PREFIX = '/admin_media/'
MEDIA_URL = '/site_media/'
并去掉django.contrib.admin的注释
在urls.py中:
去掉如下注释:
from django.contrib import admin
admin.autodiscover()
(r'^admin/', include(admin.site.urls)),
并执行:
python manage.py syncdb
3)修改httpd.conf
添加NameVirtualHost:
NameVirtualHost *
添加虚拟域名,并配置如下:
<VirtualHost *:80>
ServerName dante.qq.com
WSGIScriptAlias / D:/dgwww/conf/setting.wsgi
<Directory />
Options FollowSymLinks
AllowOverride
Order allow,deny
Allow from all
</Directory>
<Directory "D:\dgwww\mysite">
Order Deny,Allow
Deny from all
</Directory>
Alias /admin_media "C:\Python27\Lib\site-packages\django\contrib\admin\media"
<Directory "C:\Python27\Lib\site-packages\django\contrib\admin\media">
Order allow,deny
Options Indexes
Allow from all
IndexOptions FancyIndexing
</Directory>
#AliasMatch /js/(.*\.(js)) D:/dgwww/js/$1
Alias /js D:/dgwww/js/
<Directory "D:/dgwww/js/">
Order allow,deny
Options Indexes
Allow from all
IndexOptions FancyIndexing
</Directory>
#AliasMatch /site_media/(.*\.(css|gif|png|jpg|jpeg)) D:/dgwww/media/$1
Alias /site_media D:/dgwww/media/
<Directory "D:/dgwww/media/">
Order allow,deny
Options Indexes
Allow from all
IndexOptions FancyIndexing
</Directory>
</VirtualHost>
4)修改host文件:
127.0.0.1 dante.qq.com
配置成功, 至此输入地址 dante.qq.com访问就可以了。
转载: