WSGI: 全称是
Web Server Gateway Interface
,
WSGI
不是服务器,
python
模块,框架,
API
或者任何软件,只是一种
规范 ,描述
web server
如何与
web application
通信的规范。
server
和
application
的规范在
PEP 3333 中有具体描述。要实现WSGI协议,必须同时实现web server和web application,当前运行在
WSGI
协议之上的
web
框架有
Bottle
,
Flask
,
Django
。
uwsgi: 与
WSGI
一样是一种
通信协议 ,是
uWSGI
服务器的独占协议,用于定义传输信息的类型(
type of information
),每一个
uwsgi packet
前
4byte
为传输信息类型的描述,与WSGI协议是两种东西,据说该协议是
fcgi
协议的10倍快。
uWSGI: 是一个web
服务器 ,实现了WSGI
协议、uwsgi
协议、http
协议等。
来自 https://www.cnblogs.com/yidashi110/p/10489064.html
WSGI是什么? WSGI,全称 Web Server Gateway Interface,或者 Python Web Server Gateway Interface ,是为 Python 语言定义的 Web 服务器和 Web 应用程序或框架之间的一种简单而通用的接口。自从 WSGI 被开发出来以后,许多其它语言中也出现了类似接口。
WSGI 的官方定义是,the Python Web Server Gateway Interface。从名字就可以看出来,这东西是一个Gateway,也就是网关。网关的作用就是在协议之间进行转换。
WSGI 是作为 Web 服务器与 Web 应用程序或应用框架之间的一种低级别的接口 ,以提升可移植 Web 应用开发的共同点。WSGI 是基于现存的 CGI 标准而设计的。
很多框架都自带了 WSGI server ,比如 Flask,webpy,Django、CherryPy等等。当然性能都不好,自带的 web server 更多的是测试用途,发布时则使用生产环境的 WSGI server或者是联合 nginx 做 uwsgi 。
也就是说,WSGI就像是一座桥梁,一边连着web服务器,另一边连着用户的应用。但是呢,这个桥的功能很弱,有时候还需要别的桥来帮忙才能进行处理。WSGI 的作用如图所示:
WSGI的作用
WSGI有两方:“服务器”或“网关”一方,以及“应用程序”或“应用框架”一方。服务方调用应用方,提供环境信息,以及一个回调函数(提供给应用程序用来将消息头传递给服务器方),并接收Web内容作为返回值。
所谓的 WSGI中间件同时实现了API的两方,因此可以在WSGI服务和WSGI应用之间起调解作用:从WSGI服务器的角度来说,中间件扮演应用程序,而从应用程序的角度来说,中间件扮演服务器。“中间件”组件可以执行以下功能:
WSGI 的设计确实参考了 Java 的 servlet。
接下来,我们要介绍的是 uWSGI 。
uWSGI uWSGI是一个Web服务器 ,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。
要注意 WSGI / uwsgi / uWSGI 这三个概念的区分。
uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型(type of information),每一个uwsgi packet前4byte为传输信息类型描述,它与WSGI相比是两样东西。
为什么有了uWSGI为什么还需要nginx?因为nginx具备优秀的静态内容处理能力,然后将动态内容转发给uWSGI服务器,这样可以达到很好的客户端响应。
接下来,我们要看看 uWSGI 的安装配置与使用。
安装
uWSGI 的安装很简单:
现在我们试下将 Django 跑起来。我们先在 virtualenv 创建一个 Django Project:
2
[root@nowamagic nowamagic_venv]
3
(nowamagic_venv)[root@nowamagic nowamagic_venv]
virtualenv 的路径与目录文件如下:
Django Project 的路径与目录文件如下:
测试uwsgi
在你的服务器上写一个test.py:
2
def
application(env, start_response):
3
start_response(
'200 OK'
, [(
'Content-Type'
,
'text/html'
)])
我的 test.py 的路径是 /root/nowamagic_venv/nowamagic_pj/test.py,执行以下命令:
2
[root@nowamagic nowamagic_venv]
3
(nowamagic_venv)[root@nowamagic nowamagic_venv]
访问网页 http://115.28.0.89:8001/ ,OK,显示 Hello World,说明 uwsgi 安装成功。
测试你的 Django 项目 前面我们用 django-admin.py startproject nowamagic_pj 创建了一个项目,现在我们用 Django 自带的 Web 服务器看看我们的项目有没出问题。还是进入我们虚拟环境:
2
[root@nowamagic nowamagic_venv]
3
(nowamagic_venv)[root@nowamagic nowamagic_venv]
执行这个命令报错:No module named django.core.management,原因应该是装了多个版本的Python导致的。命令指定文件路径就行,丑是丑些了:
1
(nowamagic_venv)[root@nowamagic nowamagic_venv]
OK,启动 Django 自带的服务器了,我们再访问 http://115.28.0.89:8002/ ,成功显示:
说明 Djanggo 项目也没问题。
连接Django和uwsgi 最后一步了,我们要把uwsgi与Django连接起来。
编写django_wsgi.py文件,将其放在与文件manage.py同一个目录下。我的放在 /root/nowamagic_venv/nowamagic_pj/ 下:
09
sys.setdefaultencoding(
'utf8'
)
11
os.environ.setdefault(
"DJANGO_SETTINGS_MODULE"
,
"nowamagic_pj.settings"
)
13
from
django.core.handlers.wsgi
import
WSGIHandler
14
application
=
WSGIHandler()
注意不要直接 copy,有个地方要改:注意到语句os.environ.setdefault。比如我的项目为nowamagic_pj,则语句应该是 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "nowamagic_pj.settings")
OK,进入虚拟环境执行指令:
2
[root@nowamagic nowamagic_venv]
3
(nowamagic_venv)[root@nowamagic nowamagic_venv]
成功显示 Django It Works 页面。
这样,你就可以在浏览器中访问你的Django程序了。所有的请求都是经过uwsgi传递给Django程序的。
这里我们介绍了如何把uwsgi与Django连接起来,在下一篇将继续介绍如何将uwsgi与Nginx连接。
上一篇介绍了 uWSGI 来部署 Django 程序,但在在生产环境中单单只有 uWSGI 是不够的,Nginx是必不可少的工具。
先安装 Nginx,可以参照前面的小节:使用RPM安装Nginx 。
Nginx 配置 在 nginx.conf 上加入/修改,我的 server 配置如下(一切从简……):
03
server_name
115.28
.
0.89
;
06
access_log
/
home
/
nowamagic
/
logs
/
access.log;
07
error_log
/
home
/
nowamagic
/
logs
/
error.log;
11
uwsgi_pass
127.0
.
0.1
:
8077
;
13
include
/
etc
/
nginx
/
uwsgi_params;
注意保证配置里写的目录 /home/nowamagic/logs/ 和 /home/nowamagic/logs/ 存在,接下来就没啥问题了,Nginx 配置很简单。
uWSGI 配置 前面我们是直接使用命令行来启动 uWSGI ,在实际部署环境中,我们常用的是配置文件的方式,而非命令行的方式。
我的 Django 程序目录:/root/nowamagic_venv/nowamagic_pj/
这里让 Nginx 采用 8077 端口与 uWSGI 通讯,请确保此端口没有被其它程序采用。
uWSGI 支持多种配置文件格式,比如 xml,ini,json 等等都可以。
1. xml 配置
请确定你在上一节中的django_wsgi.py文件已经存在了。新建一个XML文件:nowamagic_pj.xml,将它放在 /root/nowamagic_venv/nowamagic_pj 目录下
02
<socket>
127.0
.
0.1
:
8077
<
/
socket>
05
<pythonpath>
/
root
/
nowamagic_venv
/
nowamagic_pj<
/
pythonpath>
06
<processes>
1
<
/
processes>
07
<logdate>true<
/
logdate>
08
<daemonize>
/
var
/
log
/
uwsgi.log<
/
daemonize>
09
<plugins>python<
/
plugins>
然后执行命令:
1
uwsgi -x /root/nowamagic_venv/nowamagic_pj/nowamagic_pj.xml
3
/usr/
local
/bin/uwsgi -x /root/nowamagic_venv/nowamagic_pj/nowamagic_pj.xml
加载指定的xml配置文件。当使用命令行参数时,可以使用简化命令“-x”。当然也可以不简写:
1
uwsgi --xml /etc/nowamagic.xml
甚至如果在命令行的最后一个参数以“.xml”结尾,那么就隐含将加载该xml文件作为配置。
1
uwsgi /etc/nowamagic.xml
有时候因各种环境问题,-x --xml 命令识别不了,可以使用下面的 ini 配置方式:
2. ini 配置
04
socket
=
127.0
.
0.1
:
8077
08
wsgi
-
file
=
/
root
/
nowamagic_venv
/
nowamagic_pj
/
nowamagic_pj
/
wsgi.py
09
virtualenv
=
/
root
/
nowamagic_venv
10
chdir
=
/
root
/
nowamagic_venv
/
nowamagic_pj
然后执行命令:
1
uwsgi --ini /root/nowamagic_venv/nowamagic_pj.ini&
uwsgi 这样就启动起来了。如果无意外的话,就能在网上访问你的 Python 项目了。
小插曲 我在配置完 Nginx 和 uWSGI 之后,访问时显示 502 错误。查看 uWSGI 启动信息,发现这么一条:ImportError: No module named django.core.wsgi。
然后推断,我的 CentOS 上的 Python 版本是 2.4.3,然后进入 virtualenv,执行:
3
<<<
from
django.core.wsgi
import
get_wsgi_application
则没报错,因为我的虚拟环境里的 Python 版本是 2.7.5。推断成立,但是虚拟环境里的 Django 会默认调用外部环境的 Python。解决方法:在虚拟环境里 pip install django。
OK,问题解决,一切正常。
附 一些我在配置时用到的命令,省得你去搜索:
1. 关闭 uWSGI:
2
killall -s HUP /var/www/uwsgi
3
killall -s HUP /usr/
local
/bin/uwsgi
2. 列出端口占用情况:
来自 https://blog.csdn.net/midion9/article/details/51354774
## Django 高级实战编程 视频分享地址: [https:// study.163.com/course/in troduction/1209407824.htm?share=2&shareId=400000000535031 ](https:// study.163.com/course/in troduction/1209407824.htm?share=2&shareId=400000000535031 ) 使用上面的链接地址进入 ![Django高级实战编程](https:// edu-image.nosdn.127.net /15de19868c414fed9ea65b202b6b4221.png?imageView&quality=100 )
WSGI是什么? WSGI,全称 Web Server Gateway Interface,或者 Python Web Server Gateway Interface ,是为 Python 语言定义的 Web 服务器和 Web 应用程序或框架之间的一种简单而通用的接口。自从 WSGI 被开发出来以后,许多其它语言中也出现了类似接口。
WSGI 的官方定义是,the Python Web Server Gateway Interface。从名字就可以看出来,这东西是一个Gateway,也就是网关。网关的作用就是在协议之间进行转换。
WSGI 是作为 Web 服务器与 Web 应用程序或应用框架之间的一种低级别的接口,以提升可移植 Web 应用开发的共同点。WSGI 是基于现存的 CGI 标准而设计的。
很多框架都自带了 WSGI server ,比如 Flask,webpy,Django、CherryPy等等。当然性能都不好,自带的 web server 更多的是测试用途,发布时则使用生产环境的 WSGI server或者是联合 nginx 做 uwsgi 。
也就是说,WSGI就像是一座桥梁,一边连着web服务器(如 nginx),另一边连着Python的应用程序Application。但是呢,这个桥的功能很弱,有时候还需要别的桥来帮忙才能进行处理。WSGI 的作用如图所示:
WSGI的作用
WSGI有两方:“服务器”或“网关”一方,以及“应用程序”或“应用框架”一方。服务方调用应用方,提供环境信息,以及一个回调函数(提供给应用程序用来将消息头传递给服务器方),并接收Web内容作为返回值。
所谓的 WSGI中间件同时实现了API的两方,因此可以在WSGI服务和WSGI应用之间起调解作用:从WSGI服务器的角度来说,中间件扮演应用程序,而从应用程序的角度来说,中间件扮演服务器。“中间件”组件可以执行以下功能:
WSGI 的设计确实参考了 Java 的 servlet。
接下来,我们要介绍的是 uWSGI。
uWSGI uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。
要注意 WSGI / uwsgi / uWSGI 这三个概念的区分。
uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型(type of information),每一个uwsgi packet前4byte为传输信息类型描述,它与WSGI相比是两样东西。
为什么有了uWSGI为什么还需要nginx?因为nginx具备优秀的静态内容处理能力,然后将动态内容转发给uWSGI服务器,这样可以达到很好的客户端响应。
接下来,我们要看看 uWSGI 的安装配置与使用。
安装
uWSGI 的安装很简单:
1 pip install
uwsgi
现在我们试下将 Django 跑起来。我们先在 virtualenv 创建一个 Django Project:
请看这篇文章把:uWSGI详解 - CSDN博客
来自 https://zhuanlan.zhihu.com/p/36448645