wou*_*dnt 5 postgresql sleep fabric
我正在使用Fabric初始化postgres服务器.我必须在命令的末尾添加一个"sleep 1",或者postgres服务器处理die而没有解释或日志中的条目:
sudo('%(pgbin)s/pg_ctl -D %(pgdata)s -l /tmp/pg.log restart && sleep 1' % env, user='postgres')
Run Code Online (Sandbox Code Playgroud)
也就是说,我在终端上看到了这个输出:
[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进程.随着睡眠,一切正常.
(如果我直接在目标机器的命令行上执行相同的命令,它可以在没有睡眠的情况下正常工作.)
由于它的工作,它并不真的无所谓,但我问反正:是否有人知道睡眠是允许发生的,为什么?