1
zonghua 2016-04-05 11:08:03 +08:00
响应码是什么?没有日志吗?
|
2
clino 2016-04-05 11:14:39 +08:00
除了找出根本原因外,也可以用 uwsgi 来部署来快速规避这个问题,有自动 kill 挂掉的进程的功能,也有一个 --harakiri ,如果一个进程对于请求在给定的时间内不响应就 kill 重启,另外也有占用的内存如果达到给定的上限就 kill 重启
另外你为什么要重启 vps 才能好?应该重启服务进程就行了吧? |
3
peter999 2016-04-05 11:23:37 +08:00
是不是进程挂了,我之前在阿里云上的服务器,如果内存用尽就会被系统 kill 掉。
|
4
strahe 2016-04-05 11:30:50 +08:00
感觉是系统层面的问题 不是 flask 应用层的问题
|
7
zonghua 2016-04-05 11:37:22 +08:00
@clino https://v2ex.com/t/268433 我对使用 uwsgi 有疑问,帮忙看一下谢谢
|
9
yangtukun1412 2016-04-05 13:22:11 +08:00
@cmmulxuk 看描述感觉是数据库连接断了,代码里没做重连处理。
|
10
DeanThompson 2016-04-05 14:09:50 +08:00
我觉得 @yangtukun1412 说的可能是对的。用的是 MySQL 数据库吗,如果两三天都没有访问,数据库连接会断开。不知道你是怎么连接数据库的,可以考虑使用 SQLAlchemy. 另外,卡住了也不需要重启 VPS 的,直接重启应用就可以。
|
11
dynastysea 2016-04-05 14:14:00 +08:00
加调试日志,这种绝对是代码的问题,不知道怎么定位就把日志给加全了
|
12
clarkchen 2016-04-05 14:21:29 +08:00
Flask 是单进程的应用,即使用容器比如 gunicorn 的话,也只是相当于多开几个单进程的服务而已。。。所以如果你量大的话,很可能是后台的处理速度跟不上前台的请求速度了,如果用的是 Flask 架构的话,建议多加机器。。如果量小很可能是数据库的原因, MySQL 和 Mongo 的可能性一半一半, MySQL 处理建议使用 SQLAlchemy , Mongo 的话 pymongo 要加上超时时间
|
13
cmmulxuk OP |
14
neoblackcap 2016-04-05 19:13:14 +08:00
先加日志,看看程序到底为什么不响应
|
15
biexiawo 2016-04-05 22:30:38 +08:00 via Android
你是用的 apache 还是 nginx ?
|
17
minidickcn 2022-11-18 10:48:56 +08:00
我遇到的是开放的端口被其他人扫描了,进程就卡住了,按 Ctrl+C 后恢复正常
|