flask重启后端口被占用的问题解决(非kill)
问题描述
我在flask程序中,启动了另一个python程序-test.py:
os.system('nohup python /opt/test/test.py >/dev/null 2>&1 &')
当我结束掉flask程序再启动时,就会报端口被占用的错误:
Port 5000 is already in use
而占用我5000端口的程序,恰恰是我在flask中运行的test.py程序
解决办法一:杀掉占用端口的进程
首先运行netstat命令,找到占用5000端口的pid,然后kill掉进程,再次启动flask
netstat -npl |grep 5000 tcp 0 0 1xx.1xx.xx.xx:5000 0.0.0.0:* LISTEN 9345/python kill -9 9345
网上基本全是这种方法换着花样复制粘贴,虽然能解决问题,但这样的话,我原本启动的test.py程序就不得不被kill掉,显然这并没有解决根本问题,治标不治本。
解决办法二:换用python命令的提交方法
我们现在问题的关键是为什么我在flask中启动的程序,会一直占用我们的端口号,经过不断试验,最终找到了问题所在:之所以端口号被占用,是因为我们用的提交命令:
os.system('nohup python /opt/test/test.py >/dev/null 2>&1 &')
用os.system提交,我们可以理解为运行的test.py程序是flask进程管理的一个分进程,所以当flask结束后,这个分进程依然会占用我的5000端口号。
所以,我们改用如下方式提交:
subprocess.Popen('nohup python /opt/test/test.py >/dev/null 2>&1 &', shell=True)
subprocess是Python 2.4中新增的一个模块,它允许你生成新的进程,跟flask进程没有关系了,因此也就从根本上解决了端口被占用的问题。
到此这篇关于flask重启后端口被占用的问题解决(非kill)的文章就介绍到这了,更多相关flask端口被占用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Python DataFrame.groupby()聚合函数,分组级运算
python的pandas包提供的数据聚合与分组运算功能很强大,也很灵活,本文就带领大家一起来了解groupby技术,感兴趣的朋友跟随小编一起来看下2018-09-09django 解决model中类写不到数据库中,数据库无此字段的问题
这篇文章主要介绍了django 解决model中类写不到数据库中,数据库无此字段的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随想过来看看吧2020-05-05
最新评论