python 使用 subprocess.Popen() 呼叫子程序
阿新 • • 發佈:2019-02-02
今天在做一個web頁面控制memcached重啟的功能,本以為非常簡單,不就獲取pid,然後kill,在重新啟動memcached就這麼簡單。
沒想到使用subprocess.Popen() 來呼叫命令時竟然發現response確實是返回到客戶端了,但是伺服器端和客戶端的http連線竟然還連線著,一直不斷。
查看了一下python的文件,發現:http://docs.python.org/library/subprocess.html
popen2 closes all file descriptors by default, but you have to specify close_fds=True with Popen
我的程式碼如下:
希望對你有用 ^_^
沒想到使用subprocess.Popen() 來呼叫命令時竟然發現response確實是返回到客戶端了,但是伺服器端和客戶端的http連線竟然還連線著,一直不斷。
查看了一下python的文件,發現:http://docs.python.org/library/subprocess.html
popen2 closes all file descriptors by default, but you have to specify close_fds=True with Popen
我的程式碼如下:
def _restart(port, start_cmd): cmd = 'ps aux | grep "memcached .* %s"' % port p = subprocess.Popen(cmd, shell=True, close_fds=True, # 必須加上close_fds=True,否則子程序會一直存在 stdout=subprocess.PIPE, stderr=subprocess.PIPE) stdoutdata, stderrdata = p.communicate() if p.returncode != 0: return False, error_response(cmd, stderrdata) for r in stdoutdata.split('\n'): if cmd in r: continue break if r: pid = r.split()[1] cmd = 'kill %s' % pid p = subprocess.Popen(cmd, shell=True, close_fds=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) p.communicate() p = subprocess.Popen(start_cmd, shell=True, close_fds=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) stdoutdata, stderrdata = p.communicate() if p.returncode != 0: return False, error_response(cmd, stderrdata) return True, None
希望對你有用 ^_^