为什么在结构调用pg_ctl restart后需要睡眠

时间:2012-09-06 01:55:24

标签: postgresql sleep fabric

我正在使用Fabric初始化postgres服务器。我必须在命令的末尾添加一个“sleep 1”,或者postgres服务器处理死亡而没有解释或日志中的条目:

sudo('%(pgbin)s/pg_ctl -D %(pgdata)s -l /tmp/pg.log restart && sleep 1' % env, user='postgres')

也就是说,我在终端上看到了这个输出:

  

[dbserv]执行任务'setup_postgres'
  [dbserv]运行:/ bin / bash -l -c“sudo -u postgres /usr/lib/postgresql/9.1/bin/pg_ctl -D / data / pg -l /tmp/pg.log restart&& sleep 1"
  [dbserv] out:等待服务器关闭....完成
  [dbserv] out:服务器停止了   [dbserv] out:服务器开始

没有&& sleep 1,/ tmp /pg.log中没有任何内容(虽然创建了文件),并且没有运行postgres进程。随着睡眠,一切正常。

(如果我直接在目标机器的命令行上执行相同的命令,它可以在没有睡眠的情况下正常工作。)

因为它有效,所以真的不重要,但无论如何我都在问:有人知道睡眠是允许发生的,为什么会发生?

1 个答案:

答案 0 :(得分:4)

您也可以尝试使用pty option将其设置为false,看看它是否与结构处理伪ttys有关。