配置步骤
安装Apache httpd
(可参考官方文档) 我的具体步骤:
- 从Apache Haus下载编译好的二进制文件,可以根据系统环境选择适合的版本,因为我使用的是WIN32的Python2.7,与后续使用的mod_wsgi对应版本都是是vc9编译的,为保持一致性,因此此处推荐选择VC9下编译的32位版本httpd-2.4.16-x86.zip
- 将其解压后C盘根目录下,C:\Apache24
- 根据readme_first.html,需要首先安装 Visual C++ 2012 x86 Redistributable Package 保证依赖的的VC运行时库存在在当前系统中
- 安装完成,打开CMD进入C:\Apache24\bin运行httpd.exe,正常情况下没有任何提示表示运行成功。默认绑定的端口是80,如果80端口被占用,会提示出错。可以到配置文件C:\Apache24\conf\httpd.conf中找到80,将其修改为其它指定端口,比如修改为8080:
# Change this to Listen on specific IP addresses as shown below to
# prevent Apache from glomming onto all bound IP addresses.
#
#Listen 12.34.56.78:80
Listen 8080
在浏览器中访问http://localhost:8080/,确认是否配置成功
安装WSGI模块
WSGI是WEB服务器与Python应用程序之间的接口,详细信息请参考PEP-3333或 WSGI文档。 安装文档
-
本文撰写时,mod_wsgi最新版本是mod_wsgi 4.4.12,下载连接为 https://github.com/GrahamDumpleton/mod_wsgi/releases/download/4.4.12/mod_wsgi-windows-4.4.12.tar.gz
-
解压后使用Apache24-win32-VC9/modules/mod_wsgi-py27-VC9.so,将其拷贝到C:\Apache24\modules下面
-
修改http.conf, 添加加载配置,重启httpd
LoadModule wsgi_module modules/mod_wsgi-py27-VC9.so
集成Python Web应用
与Python Web应用的集成主要是对Apache的配置,我的项目用使用的Python Web框架是Pylons Pyramid, 与其它框架的集成配置应该大同小异。
- 安装应用,在应用代码目录C:/Pyramid下运行python setup.py develop
- 在应用代码目录C:/Pyramid下创建pyramid.wsgi,内容如下
from pyramid.paster import get_app, setup_logging
ini_path = 'C:/pyramid/production.ini'
setup_logging(ini_path)
application = get_app(ini_path, 'main')
- 创建一个apache配置文件C:\Apache24\conf\extra\httpd-wsgi.conf,内容如下
### configure for wsgi module
WSGIPassAuthorization On
WSGIScriptAlias / "C:/Pyramid/pyramid.wsgi"
<Directory "C:/Pyramid/">
Require all granted
</Directory>
- 在httpd.conf的结尾外引入该配置文件
<IfModule wsgi_module>
Include conf/extra/httpd-wsgi.conf
</IfModule>
重启apache,在浏览器中验证应用是否能够访问,如果不能访问,可以将apache的日志级别设置成DEBUG级别,查看error.log。
参考文档
How To Serve Django Applications with Apache and mod_wsgi on CentOS 7