linux搭建 uwsgi服务器,uwsgi服务器部署

使用pip安装uwsgi和uwsgi

pip install uwsgi

pip install uwsgitop

pip安装uwsgi后,Linux命令行敲击uwsgi --help后,提示uwsgi命令找不到?

答:进入python安装环境的bin,然后使用ln -s进行软链接到/usr/bin/下;

web目录规范化(项目中只用预留一个uwsgi文件夹和ini文件,之后配置中要用)

root@root:~/usr/local/project$ ls -l

├── .项目目录其他文件

├── hello.py

├── hello.pyc

├── uwsgi

│ ├── uwsgi.log # 日志文件,通过该文件查看uwsgi的日志

│ ├── uwsgi.pid # pid文件,通过该文件可以控制uwsgi的重启和停止

│ ├── uwsgi.sock # socket文件,配置nginx时候使用

│ └── uwsgi.status # status文件,可以查看uwsgi的运行状态

└── uwsgi.ini

3.uwsgi.ini文件,配置参数详解

master = true

#启动主进程,来管理其他进程,其它的uwsgi进程都是这个master进程的子进程,如果kill这个master进程,相当于重启所有的uwsgi进程。

chdir = /web/www/mysite

#在app加载前切换到当前目录, 指定运行目录

module = mysite.wsgi

# 加载一个WSGI模块,这里加载mysite/wsgi.py这个模块

py-autoreload=1

#监控python模块mtime来触发重载 (只在开发时使用)

lazy-apps=true

#在每个worker而不是master中加载应用

socket = /test/myapp.sock

#指定socket文件,也可以指定为127.0.0.1:9000,这样就会监听到网络套接字

processes = 2 #启动2个工作进程,生成指定数目的worker/进程

buffer-size = 32768

#设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。

daemonize = /var/log/myapp_uwsgi.log

# 使进程在后台运行,并将日志打到指定的日志文件或者udp服务器

log-maxsize = 5000000 #设置最大日志文件大小

disable-logging = true #禁用请求日志记录

vacuum = true #当服务器退出的时候自动删除unix socket文件和pid文件。

listen = 120 #设置socket的监听队列大小(默认:100)

pidfile = /var/run/uwsgi.pid #指定pid文件

enable-threads = true

#允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程

reload-mercy = 8

#设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束)

max-requests = 5000

#为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏

limit-as = 256

#通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。

harakiri = 60

#一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用(即重启)

原文摘自(感谢):https://blog.csdn.net/t8116189520/article/details/88388801

常用命令

uwsgi --ini uwsgi.ini # 启动

uwsgi --reload uwsgi.pid # 重启

uwsgi --stop uwsgi.pid # 关闭

关于uwsgi部署flask报unable to find "application" callable in file这个错误的可能性原因,如下:

unable to find "application" callable in file ./__init__.py

unable to load app 0 (mountpoint='') (callable not found or import error)

*** no app loaded. going in full dynamic mode ***

你的启动文件缺少flask框架的实例,必须暴露变量。

app = Flask(__name__)

uwsgi的配置错误

chdir = /user

wsgi-file = (应该为chdir的相对目录,而不是配置文件的相对目录)

报错unable to load configuration from /opt/bhcrjy/uwsgi的原因:

*** Operational MODE: preforking ***

[init_app]redisPool is 32376

[init_app]redisPool is 32376

* Serving Flask app "uwsgi_file___bhcrjyApp_runserver" (lazy loading)

* Environment: production

WARNING: This is a development server. Do not use it in a production deployment.

Use a production WSGI server instead.

* Debug mode: on

* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)

* Restarting with stat

// 错误在这里,启动后立马停止

unable to load configuration from /opt/bhcrjy/uwsgi

VACUUM: pidfile removed.

原因是因为,你的启动文件中app.run(),应该移除或者单独一个文件中,因为WSGI会自动调用Flask的callable方法去启动。

有点急事,先撤了!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值