Python-Django Win7上使用Apache24和mod_wsgi部署Django1.11应用程序

简介: Python-Django Win7上使用Apache24和mod_wsgi部署Django1.11应用程序

Win7上使用Apache24mod_wsgi部署Django1.11应用程序


 

测试环境

win7 64

Django-1.11.4.tar.gz

下载地址:https://pan.baidu.com/s/1hsclV5y

 

httpd-2.4.23-win64.zip

下载地址1https://www.apachelounge.com/download/VC10/

下载地址2https://pan.baidu.com/s/1hsclV5y

 

Python 3.4.0

Apache24-win64-VC10|mod_wsgi-py34-VC10.so

下载地址:https://pan.baidu.com/s/1hsclV5y(链接包含不同版本的集合包)

 

软件包依赖VS2010

 

先决条件

注意,部署之前,必须先满足以下几个条件

1、位数要对。操作系统,安装的对应软件,要么统一32位,要么统一用64位,不要混用。

2、安装Python时选择为所有用户安装,而不是仅为安装python的用户安装。

3、使用相同Microsoft C/C++ 编译器编译的ApachePython版本。

4、使用相同Microsoft C/C++ 编译器编译的Apachemod_wsgi版本。

 

以下为Python版本和C/C++编译器的对应关系

   Python 2.6 - VC9

   Python 2.7 - VC9

   Python 3.3 - VC10

   Python 3.4 - VC10

 

以下为Apache版本和mod_wsgi版本的对应关系

Apache22-win32-VC9/modules/mod_wsgi-py26-VC9.so

Apache22-win32-VC9/modules/mod_wsgi-py27-VC9.so

Apache24-win32-VC9/modules/mod_wsgi-py26-VC9.so

Apache24-win32-VC9/modules/mod_wsgi-py27-VC9.so

Apache24-win32-VC10/modules/mod_wsgi-py33-VC10.so

Apache24-win32-VC10/modules/mod_wsgi-py34-VC10.so

Apache24-win64-VC10/modules/mod_wsgi-py33-VC10.so

Apache24-win64-VC10/modules/mod_wsgi-py34-VC10.so

 

参考链接:

https://github.com/GrahamDumpleton/mod_wsgi/blob/develop/win32/README.rst

 

部署操作

项目文件结构

 

 

解压httpd-2.4.23-win64.zip,取出其中的目录(例中Apache24),放到目标路径(不能有空格等),例中D:/Apache24

检查Apache版本是否正确

cd /d D:/Apache24/bin

httpd.exe -V

Server version: Apache/2.4.23 (Win64)

……

修改Apache配置

打开conf/httpd.conf文件,编辑,修改服务器根目录

ServerRoot "c:/Apache24"改成ServerRoot "d:/Apache24"

然后查找所有的"c:/Apache24",全部改成"d:/Apache24"

 

修改监听端口(可选,根据实际需要)

Listen 80改成Listen 8000

 

修改服务器名称(建议)

#ServerName www.example.com:80改成ServerName 192.168.1.101:80

:这里我没有注册域名,直接改成了本机ip

 

去掉#注释,打开访问日志

CustomLog "logs/access.log" common

 

修改#LoadModule rewrite_module modules/mod_rewrite.so 为如下:

LoadModule rewrite_module modules/mod_rewrite.so

说明:加载重写模块,防止出现The requested URL /  was not found on this server的情况。

 

找到如下配置

 

   AllowOverride none

   Require all denied

 

修改为

 

   AllowOverride ALL

   Require all granted

 

说明:配置更改,以防止出现如下情形:

Forbidden

You don't have permission to access / on this server.

 

启动Apache

1)httpd.exe -k install -n Apache2.4 

Installing the 'Apache2.4' service

The 'Apache2.4' service is successfully installed.

Testing httpd.conf....

Errors reported here must be corrected before the service can be started.

注:install:Apache注册为Windows服务,反之uninstall, -n接服务名称

 

2)httpd.exe -kstart

注:start 启动,stop停止

 

浏览器访问

 

 

 

添加mod_wsgi.so模块

mod_wsgi-py34-VC10.so重命名为mod_wsgi.so,放入D:\Apache24\modules目录下。

 

参考链接:

http://modwsgi.readthedocs.io/en/develop/

https://pypi.python.org/pypi/mod_wsgi

 

再次修改Apache 配置

打开conf/httpd.conf文件,编辑,在末尾添加一下内容:

 

LoadModule wsgi_module modules/mod_wsgi.so

 

WSGIScriptAlias / D:/AutotestPlatform/AutotestPlatform/wsgi.py

WSGIPythonHome "D:/Program Files (x86)/python34"

WSGIPythonPath D:/AutotestPlatform/AutotestPlatform/website

 

Alias /static/ D:/AutotestPlatform/website/static/

<Directory D:/AutotestPlatform/website/static>

   Require all granted

</Directory>

 

<Directory D:/AutotestPlatform/AutotestPlatform/website/>

<Files wsgi.py>

   Require all granted

</Files>

</Directory>

 

说明:

LoadModule 加载模块

WSGIScriptAlias  设置base URL, / 代表应用程序root url

WSGIPythonHome 设置python安装路径,

WSGIPythonPath 用于确保项目包可导入,即import AutotestPlatform 有效。

<Directory> 保证Apache可访问wsgi.py,及其它必要文件。

 

以下设置Apache通过mod_wsgi为静态资源服务

Alias /static D:/AutotestPlatform/AutotestPlatform/website/static/

<Directory D:/AutotestPlatform/AutotestPlatform/website/static>

   Require all granted

</Directory>

 

注意:如果使用的apache低于2.4版本,修改Require all granted 为如下内容:

Order deny,allow

Allow from all

 

参考链接:

https://docs.djangoproject.com/en/1.11/howto/deployment/wsgi/modwsgi/

https://github.com/GrahamDumpleton/mod_wsgi/blob/develop/win32/README.rst

 

收集静态配置文件

1)修改应用的settings.py(例中为D:\AutotestPlatform\AutotestPlatform\settings.py

STATIC_URL = '/static/' 改行下方新增如下内容:

STATIC_ROOT = os.path.join(BASE_DIR, 'static')

2)运行命令,收集静态文件到指定的static目录

cd /d D:\AutotestPlatform

python manage.py collectstatic

You have requested to collect static files at the destination

location as specified in your settings:

   D:\AutotestPlatform\static

This will overwrite existing files!

Are you sure you want to do this?

 

Type 'yes' to continue, or 'no' to cancel: yes #输入yes,回车

 

完成后,把收集的静态文件都放到 D:\AutotestPlatform\static目录下

参考链接:

https://pypi.python.org/pypi/mod_wsgi

 

Django访问IP配置

修改应用的settings.py(例中为D:\AutotestPlatform\AutotestPlatform\settings.py),编辑,找到ALLOWED_HOSTS修改为如下值,其中192.168.1.101Django所在主机ip,也就是客户端浏览器访问用的IP

 

ALLOWED_HOSTS = ['localhost','127.0.0.1','192.168.1.101']

 

修改wsgi.py

如下,新增带背景色内容,以解决找不到AutotestPlatform模块的问题

from django.core.wsgi import get_wsgi_application

import sys

sys.path.append('D:/AutotestPlatform/AutotestPlatform/')

sys.path.append('D:/AutotestPlatform/')

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "AutotestPlatform.settings")

 

application = get_wsgi_application()

 

重启Apache并启动Django应用

D:\Apache24\bin>httpd.exe -k stop

The 'Apache2.4' service is stopping.

The 'Apache2.4' service has stopped.

 

D:\Apache24\bin>httpd.exe -k start

 

说明:到这一步,已经可以浏览器访问了,以下为了看对比效果,同时开启了Django

 

启动Django

python manage.py runserver 0.0.0.0:8001 --insecure

 

浏览器验证

 

 

 


 

目录
相关文章
|
3月前
|
人工智能 Linux 开发工具
Python从零到一:手把手带你写出第一个实用程序
Python语法简洁易懂,适合编程新手入门。它广泛应用于人工智能、自动化办公、Web开发等领域。学习Python可快速搭建项目,拥有丰富库支持和强大社区资源。通过本教程,你将掌握基础语法、环境搭建、程序逻辑控制及实战项目开发,开启编程之旅。
345 0
|
2月前
|
设计模式 决策智能 Python
Python条件控制:让程序学会"思考"的魔法
本文深入浅出地讲解Python条件控制,从基础if语句到多分支、嵌套结构,再到简洁的三元表达式与Python 3.10新增的match-case模式匹配,结合电商折扣、会员等级、ATM系统等实战案例,全面掌握程序“智能决策”的核心逻辑。
327 0
|
6月前
|
人工智能 并行计算 开发者
CUDA重大更新:原生Python可直接编写高性能GPU程序
NVIDIA在2025年GTC大会上宣布CUDA并行计算平台正式支持原生Python编程,消除了Python开发者进入GPU加速领域的技术壁垒。这一突破通过重新设计CUDA开发模型,引入CUDA Core、cuPyNumeric、NVMath Python等核心组件,实现了Python与GPU加速的深度集成。开发者可直接用Python语法进行高性能并行计算,显著降低门槛,扩展CUDA生态,推动人工智能、科学计算等领域创新。此更新标志着CUDA向更包容的语言生态系统转型,未来还将支持Rust、Julia等语言。
467 3
CUDA重大更新:原生Python可直接编写高性能GPU程序
|
5月前
|
PyTorch 算法框架/工具 C++
人工智能算法python程序运行环境安装步骤整理
本教程详细介绍Python与AI开发环境的配置步骤,涵盖软件下载、VS2017安装、Anaconda配置、PyCharm设置及组件安装等内容,适用于Windows系统,助你快速搭建开发环境。
|
5月前
|
Linux 数据库 数据安全/隐私保护
Python web Django快速入门手册全栈版,共2590字,短小精悍
本教程涵盖Django从安装到数据库模型创建的全流程。第一章介绍Windows、Linux及macOS下虚拟环境搭建与Django安装验证;第二章讲解项目创建、迁移与运行;第三章演示应用APP创建及项目汉化;第四章说明超级用户创建与后台登录;第五章深入数据库模型设计,包括类与表的对应关系及模型创建步骤。内容精炼实用,适合快速入门Django全栈开发。
209 1
|
5月前
|
机器学习/深度学习 前端开发 API
python3如何使用QT编写基础的对话框程序
Qt与Python结合形成了PyQt/PySide,为桌面应用开发提供强大支持。通过简单安装PyQt5或PySide6,开发者可快速搭建跨平台GUI应用。本文从创建基础对话框入手,介绍布局管理、信号与槽机制、对话框模式及样式表美化等核心功能,并探讨模态窗口、事件驱动编程和资源打包等内容。最后,引导读者探索模型视图架构、多线程处理等进阶技术,逐步掌握用Python+Qt开发高效桌面应用的技能。
177 0
|
7月前
|
前端开发 JavaScript 关系型数据库
基于python的租房网站-房屋出租租赁系统(python+django+vue)源码+运行
该项目是基于python/django/vue开发的房屋租赁系统/租房平台,作为本学期的课程作业作品。欢迎大家提出宝贵建议。
227 6
|
1月前
|
人工智能 数据处理 API
阿里云、Ververica、Confluent 与 LinkedIn 携手推进流式创新,共筑基于 Apache Flink Agents 的智能体 AI 未来
Apache Flink Agents 是由阿里云、Ververica、Confluent 与 LinkedIn 联合推出的开源子项目,旨在基于 Flink 构建可扩展、事件驱动的生产级 AI 智能体框架,实现数据与智能的实时融合。
299 6
阿里云、Ververica、Confluent 与 LinkedIn 携手推进流式创新,共筑基于 Apache Flink Agents 的智能体 AI 未来
|
存储 Cloud Native 数据处理
从嵌入式状态管理到云原生架构:Apache Flink 的演进与下一代增量计算范式
本文整理自阿里云资深技术专家、Apache Flink PMC 成员梅源在 Flink Forward Asia 新加坡 2025上的分享,深入解析 Flink 状态管理系统的发展历程,从核心设计到 Flink 2.0 存算分离架构,并展望未来基于流批一体的通用增量计算方向。
267 0
从嵌入式状态管理到云原生架构:Apache Flink 的演进与下一代增量计算范式