linux安装uwsgi

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)使用主机输入地址进行查看

在这里插入图片描述

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
来源 | 前端兔
审核 | @前端兔

关注公众号查看更多前端知识分享~~
在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值