[asterisk-bugs] [JIRA] Created: (ASTERISK-20532) AGI script fork()s, Asterisk doesn't keep processing the dialplan when parent dies
Omri Bahumi (JIRA)
noreply at issues.asterisk.org
Mon Oct 8 14:58:27 CDT 2012
AGI script fork()s, Asterisk doesn't keep processing the dialplan when parent dies
----------------------------------------------------------------------------------
Key: ASTERISK-20532
URL: https://issues.asterisk.org/jira/browse/ASTERISK-20532
Project: Asterisk
Issue Type: Bug
Security Level: None
Components: Resources/res_agi
Environment: Debian 6 64bits
Reporter: Omri Bahumi
Severity: Minor
When an AGI script forks, Asterisk won't keep processing the dialplan when the parent dies.
By looking at the AGI code I've noticed it waits for an EOF on the stdout file descriptor, and not for the process to die.
Problematic code (this code uses pyst-0.4.38):
#!/usr/bin/python
import sys, os, time
import asterisk.agi, asterisk.manager
def main():
agi = asterisk.agi.AGI()
agi.hangup()
if os.fork():
# parent process
sys.exit(0)
else:
# child process
os.setsid()
time.sleep(10)
if __name__ == '__main__':
main()
Workaround code (addition: close sys.stdout on child process):
#!/usr/bin/python
import sys, os, time
import asterisk.agi, asterisk.manager
def main():
agi = asterisk.agi.AGI()
agi.hangup()
if os.fork():
# parent process
sys.exit(0)
else:
# child process
os.setsid()
os.close(sys.stdout.fileno())
time.sleep(10)
if __name__ == '__main__':
main()
Problematic example: you'll notice the dialplan stops processing until both the parent and child exit (hence closing stdout fd).
Workaround example: the execution continues when the parent exits and the child closes stdout, not waiting for the entire script execution to terminate.
--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the asterisk-bugs
mailing list