网上关于将django项目部署到apache上文章有很多,这里只将我踩到的一些坑记录下来。
我这里的环境:
操作系统:windows 64位
python环境:python2.7 django1.11
apache: 2.4.29 64位(与我的操作系统位数一致)
条件准备:
1.你的django项目,例如这里的项目名为:untitled3
2.apache安装包
3.适配你当前python版本,apache版本和windows系统的mod_wsgi.so文件。
开始部署:
django项目是你目前已经准备好的。这里就不再多说。下面是安装apache,请在旁边这个网址http://www.apachelounge.com/download/VC14/下载适合你系统的apache的压缩包,比如我的系统版本是windows 64位,则这里我下载的是httpd-2.4.29-win64-VC14.zip,2.4版本的apache,将其压缩包解压安装到硬盘目录下,例如这里我装到了d盘目录下,解压后的目录如下:
为了好配置,我将apache和我的django工程放在了同一个目录下。我在d盘新建了一个文件夹MyDj,将它们放入到里面,目录结构如下:
下面则就是准备需要apache链接工程untitled3的mod_wsgi.so,这个文件必须要跟你的操作系统位数,python版本,还有apache版本相对应。如果不对应,则apache运行时会报错,并且不会加载你的django工程。这个so文件当时也找的我头大,csdn上好不容易只有几个积分,然后积分花光了下下来的用不了,后续其它下载的要的积分老高,对于我这没有积分的只能干望望,终于,不负有心人,在在这个网址下找到了https://github.com/GrahamDumpleton/mod_wsgi/releases?after=4.4.17,这个网址下能下载有多mod_wsgi版本的源码,但这里,我们显然要的不是源码,我们网页往下拉,终于看到一个版本mod_wsgi.4.4.12下还多了一个
mod_wsgi-windows-4.4.12.tar.gz,
没错,下载这个就可以啦,这个就是编译好的。(强烈建议将这个网址收藏或者将这个工程star')
将该压缩文件解压后的目录如下:
根据我的环境,显然这里我需要选择第四个文件夹(apache2.4 ,windows64位),进入那个文件夹一路进去找到mod_wsgi-py27-VC9.so 文件 (我的python是2.7),将其名字改为mod_wsgi.so,复制该文件,黏贴到Apache文件夹目录下的modules文件夹里面,然后在Apache目录下的conf文件夹中的httpd.conf文件,打开找到如下进行更改(注意这里是更改,不是添加)配置:
.....
改成你自己的apache目录的绝对路径
ServerRoot "D:/MyDj/Apache24"
.....
更改端口,如果你的80端口没有被占用,也可以不改
Listen 127.0.0.1:8089
.....
改成你自己的apache路径
DocumentRoot "D:/MyDj/Apache24/htdocs"
.....
ScriptAlias /cgi-bin/ "D:/MyDj/Apache24/cgi-bin/"
...
以上完成后先保存,此时在你的apache24的目录下的bin文件夹目录下找到httpd.exe,双击运行,若出现黑框不闪退,则证明apahe初始运行环境已设好,此时你也可以访问
http://127.0.0.1:8089/进行访问,若出现如下则证明apache初始已配好:
那么现在我们要做的就是将dango工程untitled3配置到apache中,使其可在浏览器中显示。这时,继续打开httpd.conf文件,在其最后面加上(注意这里是添加)如下配置并保存:
添加mod_wsgi.so 模块
LoadModule wsgi_module modules/mod_wsgi.so
指定myweb项目的wsgi.py配置文件路径
WSGIScriptAlias / D:/MyDj/untitled3/untitled3/wsgi.py
指定项目路径
WSGIPythonPath D:/MyDj/untitled3
Require all granted
注意这里我的django工程名字叫untitled3,其路径为:D:/MyDj/untitled3
最后打开django工程untitled3目录下的untitled3目录下的settings.py文件,找到里面的
ALLOWED_HOSTS将其改为:
ALLOWED_HOSTS = ['127.0.0.1', 'localhost']
保存
此时重新启动apache目录下的bin目录下的httpd.exe,此时在浏览器中重新刷新或进入网址http://localhost:8089,就可以看到的django工程的首页了,或者你打开http://localhost:8089/admin网址,会出现如下页面:
好了,到此刻,你的第一步已经大功告成了,值得庆幸一下。但是你会发现,你的django工程的css等静态资源文件根本未加载上来。因此,下一步,我们就是将
静态资源文件让网页能加载出来。
我们在编写django工程时,一些静态文件是django库自带的,一些是我们自己定义的,这里,从网页可以看出,明显它是没有找到静态文件未加载。下面要做的就是将这些静态文件归纳到一起,并让apache找到它。
在django工程untitled项目下找到untitled文件夹中setting.py文件打开(路径为:D:\MyDj\untitled3\untitled3),在其最后一行添加如下:
STATIC_ROOT = "static"
然后cmd下cd到工程untitled下,运行如下命令:
python manage.py collectstatic
第一个是指定静态文件的路径,这里貌似是一个相对路径。第二个命令是收集该工程的所有的静态文件到STATIC_ROOT路径文件夹中,当运行完命令后,你会看到untitled3工程下看到多了一个static名字的文件夹,打开你可以看到里面包含了你定义的和admin的静态文件。
此时我们的静态文件已经收集完,下面一步便是将该静态路径部署到apache中,以让apache可以读到它。打开apache的httpd.conf文件在最后面添加:
Alias /static/ D:/MyDj/untitled3/static/
Require all granted
注意这里上面的路径换成你刚才生成的静态文件夹的绝对路径。第一句Alias的后面的/不要忘了。保存后,重新启动apache下的bin/httpd.exe,浏览器访问http://localhost:8089/admin以及其他的网站,正常情况下,静态文件的资源都会加载出来,如下admin登录界面截图:
最后一步,就是让它被局域网访问。cmd下输入ipconfig,获得你的ipv4地址,假设这里为192.168.xx.xxx,修改apache的httpd.conf中
Listen 192.168.xx.xxx:80
注意这里的端口改成80
Directory />
AllowOverride none
Require all granted
并在untitled3工程的settings.py文件中修改
ALLOWED_HOSTS = ['*']
此为允许哪些网址可以访问该工程,这里*代表所有的,当然你也可以指定那些ip可以访问,重启httpd.exe,这里防火墙会有窗口提示,点击允许访问。浏览器中直接输入你的ipv4地址即可。此时就可以被公网访问了。
该篇文章是我用笔记本边部署边完成的,花了一些时间,若是其中有什么错误,请指出哈!!