概述
本文章参考书籍:钱彬老师《python web开发从入门到实践》
采用IIS服务器部署相比django提供的开发者服务器具有更好的并发访问能力,性能更加稳定。
一、Python WSGI部署原理
python web项目的部署的基本原理,是基于一种WSGI的框架协议。
WSGI协议主要包括Web服务器和应用服务器两部分。
(1)Web服务器:即HTTP服务器,按照HTTP接受用户HTTP请求并提供并发访问,调用Web应用处理业务逻辑。
(2)Python Web应用:应用程序接受由服务器转发的request,处理对应的请求,并将处理结果返回服务器。
本文章采用IIS+Django的方式构建和部署Web项目。
二、准备部署环境
(1)cmd终端输入:
pip freeze>requirements.txt //搜集python依赖包及对应版本号,生成txt文件
(2)在需要部署项目的服务器上安装依赖包(pip)
pip install -r requirements.txt //文件requirements.txt为上一步cmd命令中生成
这是我自己的python依赖包:(依自己需求安装依赖包)
三、安装和配置IIS
打开windows的“控制面板”→“程序和功能”→“打开或关闭Windows功能”,找到Internet Information Services(Internet 信息服务),按照下图进行勾选。
四、开放端口
我将自己web应用访问端口设置为了8001端口,设置步骤如下。
(1)打开windows的“控制面板”→“系统和安全”→“Windows Defender防火墙”,单机进入防火墙配置界面。然后界面左侧进入高级设置。
(2)进入高级安全Windows Defender防火墙配置界面,选中左侧“入站规则”栏目,在选中右侧操作栏的“新建规则”选项。弹出的向导中选择“端口(o)”。
(3)点击下一步,输入自己要设的端口号(我设置的8001),然后一直点下一步,命名规则,完成。就可以在入站规则看到这个规则。
(4)在浏览器地址输入localhost访问IIS测试,如果出现以下页面,表示安装成功
五、本地部署
(先放文件夹,需要注意的有,在项目根目录和static文件夹中各有一个web.config文件。)
第四部分正文开始:
(1)安装python依赖包wfastcgi,并启动(需管理员权限)
pip install wfastcgi
//启动wfastcgi,, 停止命令为:wfastcgi-disable
wfastcgi-enable
输出:“python路径” 和 “wfastcgi解释器核心脚本路径”,用"|"隔开
已经在配置提交路径“MACHINE/WEBROOT/APPHOST”向“MACHINE/WEBROOT/APPHOST”的“system.webServer/fastCgi”节应用了配置更改
"d:python395python.exe|d:python395libsite-packageswfastcgi.py" can now be used as a FastCGI script processor
(2)配置web.config文件
为了能够让IIS服务器准确的运行项目,需要配置和设定一些参数,包括项目路径、配置文件路径、解析器等。在django项目文件中创建web.config文件(和manage.py在同一文件夹)。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.webServer>
<handlers>
<add name="Python FastCGI"
path="*"
verb="*"
modules="FastCgiModule"
scriptProcessor="d:python395python.exe|d:python395libsite-packageswfastcgi.py"
resourceType="Unspecified"
requireAccess="Script"/>
</handlers>
</system.webServer>
<appSettings>
<add key="WSGI_HANDLER" value="django.core.wsgi.get_wsgi_application()" />
<add key="PYTHONPATH" value="C:UsersyangzDesktopZC_System-V20.6_11-09ZC_System-V20.6" />
<add key="DJANGO_SETTINGS_MODULE" value="ZC_System.settings" />
</appSettings>
</configuration>
有三个参数需要注意:
1、scriptProcessor中冒号部分为前面对应的Python和wfastcgi解释器核心脚本路径。
2、<add key="PYTHONPATH" value="C:UsersyangzDesktopZC_System-V20.6_11-09ZC_System-V20.6" />, (这里跟manage.py同一目录)
3、<add key="DJANGO_SETTINGS_MODULE" value="ZC_System.settings" />,这个.settings文件一开始我配置的时候也没有,可以自己配置。没有该文件的同学可以参考下面链接自行配置。
配置"DJANGO_SETTINGS_MODULE"https://blog.csdn.net/xiaoxinyu316/article/details/46483393?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_title~default-1.no_search_link&spm=1001.2101.3001.4242. (3)静态文件文件迁移
1、进入到static文件夹中创建第二个个web.config文件。该文件用于将项目所有的静态资源文件css,js,img等全部导入到根目录下的static文件夹。方便服务器查找静态文件
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.webServer>
<!-- this configuration overrides the FastCGI handler to let IIS serve the static files -->
<handlers>
<remove name="Python FastCGI"/>
</handlers>
</system.webServer>
</configuration>
2、打开项目配置文件setting.py
将语句“STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]”替换为 “STATIC_BOOT = os.path.join(BASE_DIR, 'static')”。
//原语句注释掉
# STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
//现语句
STATIC_BOOT = os.path.join(BASE_DIR, 'static')
cmd终端进入django项目根目录:执行命令
python manage.py collectstatic
(4)IIS创建网站
“控制面板”→“系统和安全”→“管理工具”→“Internet Information Services (IIS)管理器”,打开后左侧上方选中网站栏目,右键选择添加网站进入配置。
此时配置完成:访问http://127.0.0.1:8001即可进入web应用。
六、问题
(1)[Errno 13] Permission denied: 'C:\Users\yangz\Desktop\ZC_System-V20.6_11-09\ZC_System-V20.6\templates\ShouYe\Login.html'
解决方法:找到django项目文件夹,右键属性,选择安全,编辑用户和组,添加用户“Everyone”并选择完全控制。选择应用。
(2)如果在根目录中没有****.settings问件,会弹出缺少MODULE,
配置***.settings文件https://blog.csdn.net/xiaoxinyu316/article/details/46483393?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_title~default-1.no_search_link&spm=1001.2101.3001.4242.
最后
以上就是欣喜野狼为你收集整理的基于windows系统IIS部署Django项目的全部内容,希望文章能够帮你解决基于windows系统IIS部署Django项目所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复