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端口被占用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Pytorch如何加载自己的数据集(使用DataLoader读取Dataset)
这篇文章主要介绍了Pytorch如何加载自己的数据集(使用DataLoader读取Dataset)问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-12-12
python面试题Python2.x和Python3.x的区别
这篇文章主要介绍了python面试题Python2.x和Python3.x的区别 ,在面试中也经常会问到,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-05-05
简单聊聊PyTorch里面的torch.nn.Parameter()
torch.nn.parameter是一个被用作神经网络模块参数的tensor,这是一种tensor的子类,下面这篇文章主要给大家介绍了关于PyTorch里面的torch.nn.Parameter()的相关资料,需要的朋友可以参考下2022-02-02
python 使用poster模块进行http方式的文件传输到服务器的方法
今天小编就为大家分享一篇python 使用poster模块进行http方式的文件传输到服务器的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-01-01


最新评论