运维平台的搭建已经提上日程,而我选用了大家比较常用的“Uwsgi+nginx+django”的架构,这里先记录一下安装Uwsgi的过程。
这里解释一下“Uwsgi+nginx+django”,我们整个流程如下图:
这里我们可以看出,web server是无法与我们的app(django等等)进行直接对话,他需要通过uwsgi这个桥梁,这个桥梁很重要,虽然我们使用django的runserver功能也会打开一个页面,但是这个页面是很脆弱的,小规模使用还好,要是放在网络上供人点击,根本就是脆不经风。
uwsgi是啥,请查看文末的参考资料,写的已经非常好了。我这里就简单说下:
uwsgi 实际上也是一个 http 服务器,只不过它只面向 python 网络应用程序。虽然 uwsgi 也是 http 服务器,但是却不能直接使用它部署 python web 应用程序,否则会出错。
在本文中,uwsgi 所扮演的的角色是后端 http 服务器,nginx 扮演的角色是前端 http 服务器,hello.py 是客户端应用程序。 用户从网页浏览器中发出请求,nginx 服务器收到请求后,会通过它的 uwsgi 模块将用户的请求转发给 uwsgi 服务器,uwsgi 服务器处理完毕后将结果返回给 nginx,浏览器将最终的结果展现给用户。
Uwsgi的安装比较简单,推荐使用#yum install Uwsgi直接下载使用,而不推荐用#pip install uwsgi,因为pip 安装的话,虽然也能成功(如下图红框),是没有uwsgi.ini文件的,其实没有这个uwsgi.ini是无足轻重的,因为这个文件可以自己写,但是对于生手来说,没有这个文件可能会心里发毛,就无法按照攻略继续下去,所以我更推荐用yum安装,如图:
为了纪念我们的金刚狼同志,我们就写一个叫logan.py,里面的内容是这样的:
1
2
3
|
def application( env , start_response):
start_response( '200 OK' , [( 'Content-Type' , 'text/html' )])
return "good bye,Logan..."
|
然后我们就可以启动这个uwsgi看看效果,使用#uwsgi --http :8001 --wsgi-file logan.py,把端口设定为8001,同时指定协议是http,然后加载的文件就是logan.py,启动之后,如图:
遇到这种情况,你就#yum install uwsgi-plugin-python,然后把命令做一点点修改,改成:#uwsgi --plugin python --http-socket :8001 --wsgi-file logan.py
屏幕会出现一大堆文字,然后提示,uwsgi已经启动成功了。在浏览器输入“服务器外网地址:8001”看一下效果,如图:
我们在root目录下再写一个测试的文件,这次我们写一个比较老实的python脚本来测试,这个脚本就叫test.py,里面的内容如图:
1
2
3
4
5
6
7
8
9
10
|
#!/usr/bin/python #coding=utf-8 import os
import sys
def application(environ, start_response): status = '200'
output = 'this is a test for uwsgi,HOHO~'
response_headers = [( 'Content-type' , 'text/plain' ),( 'Content-Length' , str(len(output)))]
start_response(status, response_headers)
return output
|
还是用刚才的方法,依旧可以打开网页,其实上面这个简单的uWSGI程序更好理解整个套路,只需要实现一个名为application的函数就可以了,该函数有两个参数,environ为包含有http请求的环境变量,start_response为一个函数,用来设置http头。在这个函数里,我们只需要调用一次start_response函数,设置一下HTTP返回头,再return一个HTTP body即可。
至此,整个uwsgi就安装成功了。
http://uwsgi-docs.readthedocs.io/en/latest/tutorials/Django_and_nginx.html
本文转自 苏幕遮618 51CTO博客,原文链接:http://blog.51cto.com/chenx1242/1904804