guicorn 是什么?

在回答问题之前我们先来看看 web服务器的典型过程[1]
1. 建立链接:如果没有连接,要建立连接
2. 接收请求:对客户端发来的请求进行解析。
3. 处理请求:转发给预定义的处理器。
4. 访问资源、处理资源:
                    访问资源 处理器根据请求访问资源,资源可能存在于数据库中或文件系统中等。
                    处理资源 返回数据,通常根据取出的数据对模板进行渲染(填充模板的过程)然后将渲染了的内容返回
5. 构建响应:构建http响应报文,包括响应状态码,响应头和响应实体。响应实体中包含了数据。
6. 发送响应:将响应发送给客户端,可以做 关闭连接 
7. 日志记录
 
 
我们知道像djangoflasktornado这些web 应用框架(web framework) 负责数据库连接存取,
页面、数据的生成,session的管理, url dispatch等。也就是说,这些web应用框架主要在做第3 第4件事情。
那么1. 2. 5. 中这些相对底层的事情——对http 协议的处理是谁来做的呢?是http服务器。
那么http服务器如何与web 应用之间框架沟通呢?这就需要WSGI了。
 
 
WSGI 类似一种协议,定义了http服务器 和 web 应用 之间的互相沟通的方式。
第2步到第3步,http 请求从http服务器给了web应用,中间需要通过WSGI的沟通,
同样,由第4步到第5步,web应用将响应给了http服务器,中间也需要通过WSGI沟通。
此处如果觉得博主理解得不准,请参考 PEP3333
 
 
显然,它的好处是 web应用框架与 http服务器的解耦。
另外,通过提供统一的接口,使得程序员不必关心http协议的底层处理细节,而专注于 业务逻辑上的开发。
 
 
回到问题,guicorn是什么呢?它实现了WSGI,同时它还是http服务器。
因为gunicorn实现了WSGI, flask 在 gunicorn 上能跑,在其他实现了WSGI的服务器上 也能愉快地运行。
 
 
为啥要用它呢?
django 是有自己的wsgi的,把gunicorn做django的WSGI服务器,可以很灵活地配置worker数量,以提高并发量;
当web应用长时间未响应,会重启worker进程,有『临时』起死回生的功效;其他特性。
 
 以上讲了gunicorn的作用,下面就顺便讲一下gunicorn的配置吧:) 
 

gunicorn的配置

bind 绑定的ip以及端口号。部署后可通过访问该ip及端口号可访问web服务。
但是通常会在gunicorn前加 nginx 做为反向代理。
 
workers 对应 处理进程的数目。是重要的配置。
通过命令 ps aux | grep 'gunicorn' 可以看到进程的数目与配置文件中的数目相符。
有推荐 (2*cpu核数)+1的,实际要看具体情况,请求量小完全不用这么配,以减少不必要的内存消耗。
 
timeout 超时参数,如果web应用服务器超过了此时间仍未响应那么将重启worker,显然,重启期间 服务不可用。
假如web应用服务器在重启前 阻塞住了,那么重启之后阻塞 可能 消失,此时服务可用。但如果阻塞原因没有消除
那么web应用服务器 早晚还是会阻塞,阻塞时间太长了,引起worker再次重启。这就是所谓的『临时』起死回生
 
daemon 是否为守护进程。
pythonpath python路径。
preload_app 配成 True 可在worker 进程fork前加载代码,推荐一试。
其他参数参考 这个
  
讲完了gunicorn的配置,再讲讲guicorn的部署吧!
 

启动gunicorn

举例

/home/venv/bin/python /home/venv/bin/gunicorn -c start_gunicorn.py wsgi:app

其中 -c 指定配置文件

wsgi.py文件中写web 应用程序,请注意下wsgi文件的路径

博主不太懂的地方,在于奇怪的冒号。冒号左边的部分表示定义程序的包或者模块,冒号右边的部分表示包中程序实例的名字[2]
貌似,没有冒号也是可以的;)参考 gunicorn with django
 
 
题外话
web后端 最最简单粗暴的理解:拿到请求,查查数据库,扔回给客户端 (博主遁走
 
观点
1. guicorn = WSGI服务器 + http服务器。
2. 对django来讲,它是一个更好的WSGI服务器(能起多个worker 等),另外 它还能处理http请求。
3. 想充分了解WSGI 看 PEP3333.
 
参考 
[1] http权威指南, 第五章; redis 实战, 第二章
[2] http://www.jianshu.com/p/7bc34e56fa39
 
如果讲的不准,欢迎拍砖 ;)
2016年5月5号

guicorn 是什么的更多相关文章

  1. 基于Java的支持可变QPS的http负载生成器,提供交互界面和RMI接口

    Load generator The load generator is a Java maven project which is implemented using httpclient+thre ...

  2. 『居善地』接口测试 — 6、Httpbin服务介绍

    目录 1.Httpbin服务介绍 2.在Windows系统中部署Httpbin服务 3.在Linux系统中部署Httpbin服务 4.Httpbin访问方式 5.Httpbin常用调试接口 6.总结: ...

随机推荐

  1. ultraedit开发使用技巧

    抛开Mybatis和Hibernate这些dao框架,如果维护老项目时或者不得不用sql拼接时,一个几百行的sql光是去掉navicat中查询的注释或者在sql前后加上双引号就已经很费劲,影响开发效率 ...

  2. Qt 线程基础

    (转自:http://my.oschina.net/laopiao/blog/88158) 何谓线程? 线程与并行处理任务息息相关,就像进程一样.那么,线程与进程有什么区别呢?当你在电子表格上进行数据 ...

  3. SGU 139. Help Needed! 逆序数,奇偶性,分析 难度:0

    139. Help Needed! time limit per test: 0.25 sec. memory limit per test: 4096 KB Little Johnny likes ...

  4. bzoj2134

    题解: 每一题对的概率为min(a[i],a[i+1])/a[i]/a[i+1]; 即可 代码: #include<bits/stdc++.h> using namespace std; ...

  5. 多线程--Thread.join方法

    在Thread类的Api中,Join的作用是让当前线程等待目标线程结束之后才继续执行. thread.Join把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程.  比如在线程B ...

  6. java 生成xml文件

    这里也使用的是import org.w3c.dom.Document; 首先创建document对象,给该对象赋值,然后将document对象使用transformer的transformer转换方法 ...

  7. LoadRunner设置监控Windows系统资源步骤

    一般在客户端通过LoadRunner对服务器进行压力测试,都需要实时监控服务器端的系统资源,本篇主要简单介绍一下如何设置在LoadRunner的Controller中配置监控Windows Resou ...

  8. OMAP4之DSP核(Tesla)软件开发学习(二)Linux内核驱动支持OMAP4 DSP核

    注:必须是Linux/arm 3.0以上内核才支持RPMSG,在此使用的是.config - Linux/arm 3.0.31 Kernel Configuration.(soure code fro ...

  9. AI人工智能专业词汇集

    作为最早关注人工智能技术的媒体,机器之心在编译国外技术博客.论文.专家观点等内容上已经积累了超过两年多的经验.期间,从无到有,机器之心的编译团队一直在积累专业词汇.虽然有很多的文章因为专业性我们没能尽 ...

  10. 使用eclipse启动系统时报错“ java.lang.OutOfMemoryError: PermGen space”问题的解决

    转载请注明出处:http://blog.csdn.net/dongdong9223/article/details/76571611 本文出自[我是干勾鱼的博客] 有的时候,使用eclipse启动系统 ...