源码安装
1、选择版本下载:https://uwsgi-docs.readthedocs.io/en/latest/Download.html
2、解压和安装
cd /usr/local
tar zxvf uwsgi-2.0.20.tar.gz
cd uwsgi-2.0.20
python3 setup.py install
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi
pip安装
pip install uwsgi
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi
使用
# start
uwsgi --init xxx.ini
# restart
uwsgi --reload xxx.pid
# stop
uwsgi --stop xxx.pid
测试
(1)在用户目录创建一个test.py文件,并插入内容
cd ~
vi test.py
=========插入保存退出============
#!/usr/bin/env python3
def application(env,start_response):
start_response('200 OK',[('Content-Type','text/html')])
return "Hello,world"
(2)编写一个uwsgi的ini配置文件
vi test.ini
=========插入保存退出============
[uwsgi]
# http服务
http-socket=:8080
# 项目目录,同个层级不用更改
#chdir=
# 相对于项目目录,要运行的文件
wsgi-file=test.py
# 指定启动的工作进程数
processes=4
# 指定工作进程中的线程数
threads=2
# 启动一个master主进程来管理其他进程,建议启动这个进程,在管理的时候比较方便;如果kill这个master进程,相当于关闭所有的uwsgi进程。
master=True
uwsgi test.ini // 运行配置文件
uwsgi -d --ini test.ini //后台运行
ps ax | grep uwsgi //查询进程
ps ax | grep uwsgi //查看uwsgi
killall -s INT /usr/bin/uwsgi //停止
(3)使用主机输入地址进行查看
更多配置
1-通信接口:
socket=:8080 -- socket通信速度比http快
http=:8080 -- 官方不推荐使用
http-socket=:8888 -- 一般使用这个
2-项目目录(启动文件所在位置)
chdir=
3-项目中wsgi.py文件的目录,相对于项目目录
wsgi-file=test.py
4-callable的对象就是一个wsgi接口,如Flask中的app,是flask独有的配置项
(django不需要)
callable = WSGIHandler
5-指定启动的工作进程数
processes=4
6-指定工作进程中的线程数
threads=2
7-启动一个master主进程来管理其他进程,建议启动这个进程,在管理的时候
比较方便;如果kill这个master进程,相当于关闭所有的uwsgi进程。
master=True
8-使进程在后台运行,并将日志打到指定的日志文件或者udp服务器
daemonize = uwsgi.log
9-不记录request日志,只记录错误日志
disable-logging = true
10-保存启动之后主进程的pid(保存在uwsgi.pid文件中),防止运行多余程序
pidfile=uwsgi.pid
11-一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,
并且当前处理这个请求的工作进程会被回收再利用(即重启)
harakiri = 60
12-为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,
那么该工作进程就会被回收重用(重启)。
max-requests = 5000
13-这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了
8秒就会被强行结束(忽略之前已经接收到的请求而直接结束)
reload-mercy = 8
14-uwsgi不建议使用root权限去启动uwsgi实例。
可以通过root用户去运行uwsgi文件,当通过uid和gid去修改用户(移除root权限)
uid=1000
gid=1000
15-buffer-size用于uwsgi包解析的内部缓存区大小,默认是4k。这个值可以设置到64k
用于解决报头过大的错误
buffer-size=65536
16-由于GIL的存在,uwsgi默认不支持多线程,不对GIL进行初始化。
但如果希望程序中的线程发挥作用,需要加入
enable-threads=True