我正在使用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进程。随着睡眠,一切正常。
(如果我直接在目标机器的命令行上执行相同的命令,它可以在没有睡眠的情况下正常工作。)
因为它有效,所以真的不重要,但无论如何我都在问:有人知道睡眠是允许发生的,为什么会发生?