0 - 注:进行安装时我使用的用户是超级用户root,如果你不是超级用户在有些命令的前面需要添加sudo,也可以使用su命令切换成超级用户
1 - 先安装python3(不然很多命令都用不了,且依赖没安装也容易报错),看这个帖子:linux安装Python3(一定要先弄)
2 - 安装python虚拟环境和虚拟环境管理(建议安装),点击查看:python虚拟环境virtualenv和virtualenvwrapper的安装和配置(建议弄)
3 - 如果你前面两个都弄好了,执行下面命令:
(1)创建虚拟环境tt(如果安装虚拟环境你没弄就不需要,直接第二步开始即可)
mkvirtualenv tt // 创建名为tt的虚拟环境
workon tt // 进入这个虚拟环境
(2)安装uwsgi模块
pip install uwsgi -i https://mirrors.aliyun.com/pypi/simple/
// 使用镜像源进行安装
4 - 测试uwsgi使用是否正常
(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
(3)进入虚拟环境并运行这个配置文件(如果你没有将uwsgi安装在虚拟环境里,则跳过这一步)
workon tt // 进入虚拟环境
systemctl stop firewalld.service
// 关闭防火墙(虚拟机测试才能使用),服务器需要去管理平台开放端口
uwsgi test.ini // 运行配置文件
(4)使用主机输入地址进行查看
- 服务器···········使用公网IP地址即可
- 虚拟机···········获取虚拟IP地址:linux虚拟机获取ip地址
5-对配置文件参数的额外补充
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
编辑 | sishen
来源 | 前端兔
审核 | @前端兔
关注公众号查看更多前端知识分享~~