Windows下django项目部署 通过Apache2.4+mod_wsgi
简述
(请阅读下面的资料,也许能帮到你)
在这几天的部署过程中,遇到蛮多的问题,想记录当时部署的情况,帮助有需要的朋友。
这里说一下其他的问题:
我在之前测试过使用mod_wsgi-cp38 版本与Apache配合,发现django可以正常使用,但是使用中会出现不太稳定数据连接问题。
使用Apache配置两个django项目在同一个服务里面(配置虚拟域名),使用相同的虚拟环境(mod_wsgi配置信息指向的环境位置),会造成数据连接问题,
比如:在启动Apache服务时,两个项目的数据库连接,会出现随机连接其中一个项目的数据库,另一个项目就会使用一样的数据,在登陆网站的时候,数据就会串在一起。
如果有朋友解决了这个问题,还请联系一下我。
django官网有做解释:
注:django官网地址
由于环境变量是进程范围的,因此当您在同一进程中运行多个Django站点时,这将不起作用。这与mod_wsgi一起发生。
为避免此问题,请对每个站点在自己的守护进程中使用mod_wsgi的守护程序模式,或通过在中强制执行来覆盖环境中的值。
os.environ["DJANGO_SETTINGS_MODULE"] = "mysite.settings"wsgi.py
运行环境:
先说下我使用的环境,版本很重要,我是根据mod_wsgi的版本要求下载的各个版本(python,Apache2.4)
下载地址:mod_wsgi
下面这张图说明python与Apache的版本:
版本信息:
Apache2.4VC14 64bit
Python 3.5.2-amd64
Django 2.2 #python3.5不支持django3.0以上版本
MySQL 8.0.19
Apache2.4安装:
在Apache官网上找到对应的安装包
下载地址:Apache2.4-VC14
打开httpd.conf文件(在Apache24/conf目录下)
Define SRVROOT "C:\web\Apache24"
Listen 80
ServerName www.example.com:80
DocumentRoot "C:\web\Apache24\htdocs"
<Directory "C:\web\Apache24\htdocs">
具体如何安装Apache不多说了,下面这几条常用命令还是说明一下:
httpd -k install -n #安装Apache服务
net start/stop Apache2.4 #启动停止Apache服务
sc delete Apache2.4 #删除Apache服务
httpd -k uninstall #卸载Apache
python-3.5安装:
本文略
Mysql-8.0.19安装:
本文略;但运行时mysql库需配置好。
具体mod_wsgi相关配置:
在上述完成之后,Apache启动访问IP地址访问出现 It WORKS! ,开始部署。
在Django项目文件夹下建一个虚拟环境:
pip install virtualenv #下载virtualenv包
virtualenv 1_env #新建环境1_env
activate #须cd到\1_env\Scripts目录下运行activate
先将下载好的mod_wsgi-4.7.0+ap24vc14-cp35-cp35m-win_amd64.whl复制到Scripts目录
pip install "c:\djangomode\1_env\mod_wsgi-4.7.0+ap24vc14-cp35-cp35m-win_amd64.whl" #通过pip安装mod_wsgi
如果安装失败检测自己所下载对应的版本是否有问题,成功的话继续往下走;
mod_wsgi-express module-config #查看mod_wsgi模块的配置信息
查看mod-wsgi的配置信息:
#后面Apache24的httpd.conf配置需要用到这两条信息
#将这两条配置信息保存下来
LoadModule wsgi_module "c:/djangomode/1_env/lib/site-packages/mod_wsgi/server/mod_wsgi.cp35-win_amd64.pyd"
WSGIPythonHome "c:/djangomode/1_env"
注:可能你们看过其他博主输出的是三条配置,不过不要紧,我们无需设置LoadFile "c:/python35/python35.dll
在运行Apache服务时遇到启动不了,查看Apache24/logs/error.log文档发现错误如下:
Fatal Python error: Py_Initialize: unable to load the file system codec
LookupError: no codec search functions registered: can't find encoding
注;Python找不到它的modules目录,所以它当然也可以不加载encodings
解决方法修改windows环境变量配置:
PYTHONPATH="C:\python35\DLLs;C:\python35\Lib;C:\python35\Lib\site-packages" #路径之间用逗号;分开
PYTHONHOME=C:\python35
注意,如果开发环境需要,您可能需要希望将任何其他库路径附加到PYTHONPATH中,但正确设置DLLs、Lib和site-packages是最重要的,也就是之前配置的python环境变量。
Django项目setting.py修改:
这里先说一下原因,setting配置相对路径信息在移到Apache与mod_wsgi运行时,相对路径会访问不了,需要修改为绝对路径。
在我修改为绝对路径时,运行Apache报了一个错
OSError: [Errno 22] Invalid argument: 'C:\\\\Djangomode\\templates\\\\500.html'\r
需要在文件路径前加上 r"filepath"
r"filepath":意思是指为了避免\xx是一个转义字符而导致的错误,也就是说加上r之后,""里的就不再出现转义字符,编程纯的文件地址。
#这里只描述一处,其余相对路径也需改成绝对路径并加上 r
TEMPLATES = [{
'DIRS': [r'C:\Djangomode\templates']
]
在项目正式上线时设置:
DEBUG = False
可指定主机,若元素为'*',表示所有同一局域网内的网络均可被访问:
ALLOWED_HOSTS = ['*']
配置Apache的httpd.conf文件:
DocumentRoot "C:\Djangomode" #Djangomode为项目根目录
<Directory "C:\Djangomode">
在文件底部加上下面代码(需根据实际环境更改参数)
##--------------- Django项目部署配置 ---------------##
LoadModule wsgi_module "c:/djangomode/1_env/lib/site-packages/mod_wsgi/server/mod_wsgi.cp35-win_amd64.pyd"
WSGIPythonHome "c:/djangomode/1_env"
#指定项目的"wsgi.py"配置文件路径
WSGIScriptAlias / "C:\Djangomode\Djangomode\wsgi.py"
#指定Django项目根目录
WSGIPythonPath "C:\Djangomode"
<Directory "C:\Djangomode\Djangomode">
<Files wsgi.py>
Require all granted
</Files>
</Directory>
#项目静态文件地址
Alias /static "C:\Djangomode\static"
<Directory "C:\Djangomode\static">
AllowOverride None
Options None
Require all granted
</Directory>
#项目上传文件根目录
Alias /uploads "C:\Djangomode\uploads"
<Directory "C:\Djangomode\uploads">
AllowOverride None
Options None
Require all granted
</Directory>
修改完之后重启Apache服务,Apache服务属性会被修改,如下图:
在浏览器上输入IP地址端口或主机域名访问Django项目,在httpd.conf中配置的主机域名ServerName
C:\Windows\System32\drivers\etc需加入域名如:
127.0.0.1 Djangomode
检查ip地址或域名是否正常,在cmd窗口输入ping如:
ping www.baidu.com #ping的通则正常
访问成功!祝贺自己,耶!
后续会写一篇关于django使用channels实现websocket连接的文章。
欢迎大家留言