在后台运行的命令行脚本进入停止状态

Lor*_*con 4 php linux bash shell scripting

我有一个简短的PHP实用程序脚本,我只是用cli从cli运行它:

php myscript.php
Run Code Online (Sandbox Code Playgroud)

脚本始终在运行,定期执行某些任务(与问题无关).它不需要用户的任何输入.运行之后,我通常按CTRL+ z然后运行bg将进程放在后台,一切都很好.

如果我运行它:

php myscript.php &
Run Code Online (Sandbox Code Playgroud)

脚本在启动时放在后台,但它也处于停止状态.例:

[1] 11513
[1]+  Stopped                 php myscript.php
Run Code Online (Sandbox Code Playgroud)

即使运行bg在这一点上没有帮助,我得赶紧走fg,然后CTRL+ zbg再次,使其工作.

这是php脚本:

<?
while(true){
    echo 'hi '.time()."\n";
    sleep(30);
}
?>
Run Code Online (Sandbox Code Playgroud)

我的问题是我不能直接在后台运行它,因为系统会停止它,我不明白为什么.我怎样才能解决这个问题?

更新:

我制作了相同脚本的bash版本,它可以运行并放入后台(运行而不是停止),只需使用&在末尾启动它(script.sh &)

script.sh:

#!/bin/bash
while true; do
    echo `date`
    sleep 30
done
Run Code Online (Sandbox Code Playgroud)

为什么php脚本在后台启动后停止,而bash脚本没有?什么可能导致这种不同的行为?

Lor*_*con 20

我找到了造成这个问题的原因.在PHP中,如果启用了readline模块,则任何命令行脚本都会期望输入,即使脚本被写入NOT等待用户输入也是如此.

要检查是否启用了readline支持,只需运行:

php --info |grep "Readline Support"
Run Code Online (Sandbox Code Playgroud)

并检查输出.如果您获得,Readline Support => enabled则启用了readline,您可能会遇到原始问题中描述的问题.

然后使用cli的正确方法是明确指定php没有使用终端输入:

php myscript.php < /dev/null &
Run Code Online (Sandbox Code Playgroud)

更多信息:http://php.net/manual/en/book.readline.php

备择方案:

./test.php >/dev/null &    
Run Code Online (Sandbox Code Playgroud)

或(更有创意):

nohup php test.php > /dev/null 2>&1 &
Run Code Online (Sandbox Code Playgroud)

(ps:我仍然认为这个问题属于ServerFault,顺便说一句..问题解决了!)

  • `php myscript.php </ dev/null&`为我解决了这个问题,感谢readline的解释 (2认同)