Мой вопрос в том, является ли это ожидаемым (и почему?) и/или это поведение наблюдается и на других системах?
Окружающая среда:
# cat /etc/*-release
CentOS release 6.6 (Final)
...
# perl -v
This is perl, v5.10.1 (*) built for x86_64-linux-thread-multi
...
# php -v
PHP 5.4.41 (cli) (built: May 14 2015 23:15:28)
...
mini.pl:
#!/usr/bin/perl
exec('/usr/bin/php -v');
Запустите его и просмотрите зависающий процесс PHP:
# perl mini.pl &
[2] 16958
[1] Killed perl mini.pl
# ps ax | grep 16958
16958 pts/2 T 0:00 /usr/bin/php -v
16960 pts/2 S+ 0:00 grep 16958
[2]+ Stopped perl mini.pl
Но если я закрою STDIN:
mini.pl:
#!/usr/bin/perl
close(STDIN);
exec('/usr/bin/php -v');
Он отлично работает:
# perl mini.pl &
[1] 16976
# PHP 5.4.41 (cli) (built: May 14 2015 23:15:28)
...
[1]+ Done perl mini.pl
# ps ax | grep 16976
16978 pts/2 S+ 0:00 grep 16976
Другие примечания:
- Я не могу воспроизвести это поведение висит на Mac OS X (perl 5.18.2, php 5.5.24)
Спасибо,