python 使用 subprocess.Popen() 调用子进程

今天在做一个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


 
我的代码如下:
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

希望对你有用 ^_^
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`subprocess.Popen`是Python中用于启动新进程并与之通信的模块。可以使用`Popen`类来创建进程,并与进程进行复杂的交互。下面是`Popen`的构造函数参数的解释: - `args`:要执行的命令,可以是字符串或序列类型。 - `bufsize`:缓冲区大小,0表示无缓冲,1表示行缓冲,其他正整数表示缓冲区大小。 - `executable`:要执行的可执行文件,如果为None,则使用args。 - `stdin`、`stdout`、`stderr`:分别表示标准输入、标准输出和标准错误输出的文件描述符。如果为None,则使用默认值。 - `preexec_fn`:在子进程开始之前调用的可调用对象。 - `close_fds`:如果为True,则在子进程中关闭所有文件描述符。 - `shell`:如果为True,则在shell中执行命令。 - `cwd`:子进程的当前工作目录。 - `env`:子进程的环境变量。 - `universal_newlines`:如果为True,则将输入和输出流转换为文本模式。 - `startupinfo`:Windows特定的进程启动信息。 - `creationflags`:Windows特定的进程创建标志。 下面是一个简单的例子,演示如何使用`subprocess.Popen`来执行命令并获取输出: ```python import subprocess # 执行命令 result = subprocess.Popen(['ls', '-l'], stdout=subprocess.PIPE) # 获取输出 output = result.communicate()[0] print(output.decode('utf-8')) ``` 这个例子执行了`ls -l`命令,并将输出存储在`output`变量中。`communicate()`方法会等待进程结束并返回标准输出和标准错误输出。在这个例子中,我们只使用了标准输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值