此次部署重点不在 Django 项目本身,而是为了测试在 Django 框架中集成的微信框架 Werobot
,作为微信个人订阅号的后台,测试相关功能。
部署软硬件准备
- 腾讯云(学生)服务器 (Windows Server 2012 R2)(1G1核1M)
- Apache 2.4.28 Win64(http-2.4.28-win64-VC14.zip)
- mod_wsgi‑4.5.19+ap24vc14‑cp35‑cp35m‑win_amd64.whl
- Python-3.5
- Django 1.8
Apache、mod_wsgi、Python
版本分别对上,以 mod_wsgi 版本需要为准
。
安装 Python
Python 安装,将 Add Python 3.5 to PATH 选项勾上
,安装完后可免去命令配置:
安装完后打开命令行输入 python,出现如图指令即安装成功:
安装第三方库
在本地调试的 Django 项目中使用 pip freeze > requirements.txt
命令生成需求库:
并且配置 settings.py
文件:
# settings.py
DEBUG = False # 关闭调试模式
ALLOWED_HOSTS = ["119.29.92.184",] # 添加服务器公网IP
将整个 Django 项目复制到服务器的目标文件夹中,在项目的根目录下启动 cmd.exe,输入命令 pip install -r requirements.txt
安装第三方库:
等待全部安装成功:
安装 Mod_wsgi
在 http://www.lfd.uci.edu/~gohlke/pythonlibs/#jsonlib 网站里下载相应版本的 Mod_wsgi 到本地,用 pip install path/to/mod_wsgi
安装,等待安装成功后,使用 mod_wsgi-express module-config
查看 mod_wsgi 配置,保存输出信息。
配置 Apache
将下载好的文件直接解压到 C 盘根目录( C 盘为 Apache 默认的安装路径),运行 bin 文件下的 httpd.exe
,如果弹出的命令行不闪退,再打开浏览器输入公网 IP ,出现下图及表示解压没问题:
接下来,开始正式配置 Django 项目,打开 conf 文件夹
下的 httpd.conf
配置文件进行配置,首先添加之前配置 mod_wsgi 时输出的信息
:
# httpd.conf
LoadFile "c:/users/administrator/appdata/local/programs/python/python35/python35.dll"
LoadModule wsgi_module "c:/users/administrator/appdata/local/programs/python/python35/lib/site-packages/mo
d_wsgi/server/mod_wsgi.cp35-win_amd64.pyd"
WSGIPythonHome "c:/users/administrator/appdata/local/programs/python/python35"
之后再配置 Django 项目目录
:
# httpd.conf 基本配置
WSGIScriptAlias / C:/Zhaha/Django/ServerTest1/ServerTest1/wsgi.py
WSGIPythonPath C:/Zhaha/Django/ServerTest1
<Directory C:/Zhaha/Django/ServerTest1/ServerTest1>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
基本配置后,还需要检查 httpd.conf 配置文件另一些访问权限
:
# httpd.conf
<Directory /> # 当前版本 229-232 行
AllowOverride none
Require all denied
</Directory>
<Files ".ht*"> # 当前版本 287-289 行
Require all denied
</Files>
改为:
<Directory /> # 当前版本 229-232 行
AllowOverride none
Require all granted
</Directory>
<Files ".ht*"> # 当前版本 287-289 行
Require all denied
</Files>
之后运行 httpd.exe
无闪退即运行成功,下面是 Django 项目一些信息:
# urls.py
...
urlpatterns = [
...
url(r'^wechat/', include("wx_develop.urls"), name="wechat"),
url(r'^robot/', make_view(robot)), # 微信框架
]
# views.py
...
def index_of_wechat(request):
return HttpResponse("You're at the wechat index.")
此时,在外网即可访问到 Django 项目:
之后就可以测试 werobot 相关功能,这里不予记录。
在部署遇到问题的时候可以查看 Apache/logs/error.txt
文件,错误日志及提醒都会在里面提示。
此次 Django 部署是基于 Apache 最基本的配置,有些静态文件路径并没有配置到。
Apache 和 mod_wsgi 搭配部署 Django 项目也许并不是最好的组合,但是在学习过程中不需要一步就达到最优解,而是先成型—发现性能不足—再选择方案优化。
参考资料:
How to use Django with Apache and mod_wsgi
mod_wsgi getting started