1、uwsgi的安装

pip install uwsgi

2、uwsgi的基本测试:

创建一个test.py文件,内容如下:

def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return "Hello World" 启动uwsgi:
uwsgi --http :9000 --wsgi-file test.py 通过浏览器访问http://127.0.0.1:9000,会输出"Hello World"

3、编写uwsgi配置文件/etc/uwsgi.ini,内容如下:

[uwsgi]
uid = nginx
gid = nginx master = true
processes = 2
listen = 120
socket = 127.0.0.1:9000
pidfile = /var/run/uwsgi.pid
vacuum = true
daemonize = /var/log/uwsgi.log

各配置项说明如下:

uid = nginx #使用nginx用户和组
gid = nginx
#chdir = /webser/www/demosite #指定项目目录,在配置多站点时,不要启用
#module = demosite.wsgi #加载demosite/wsgi.py这个模块,在配置多站点时,不要启用
master = true #启动主进程。
processes = 2 #启动2个工作进程
listen = 120 #设置socket的监听队列大小(默认:100)
socket = /test/myapp.sock #指定socket文件,也可以指定为127.0.0.1:9000,这样就会监听到网络套接字
pidfile = /var/run/uwsgi.pid #指定pid文件
vacuum = true #当服务器退出的时候自动删除unix socket文件和pid文件。
enable-threads = true #允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程
buffer-size = 32768 #设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。
reload-mercy = 8 #设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束)
max-requests = 5000 #为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏
limit-as = 256 #通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。
harakiri = 60 #一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用(即重启)
daemonize = /var/log/myapp_uwsgi.log # 使进程在后台运行,并将日志打到指定的日志文件或者udp服务器

启动uwsgi:

uwsgi --ini /etc/uwsgi.ini

4、nginx配置文件

server {
listen 80;
server_name localhost;
index index.html index.htm;
client_max_body_size 35m;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:9090;
uwsgi_param UWSGI_SCRIPT demosite.wsgi; #指定加载的模块
uwsgi_param UWSGI_CHDIR /webser/www/demosite; #指定项目目录
}
}
05-28 16:32