[Freeswitch-users] Lua: io.popen/read blocking in other incoming calls
Dan
freeswitch-users at digitaldan.com
Tue Jan 19 15:14:04 PST 2010
Thanks for your response, I'm looking through the lua source right now. Am I correct in assuming that each incoming call has its own thread and therefore its own lua vm instance? So the only blocking that would be possible among threads is if they were calling something blocking on the core switch module. That's definitely not happening here, so I'll keep looking around.
Thanks
Dan-
----- Original Message -----
From: "Anthony Minessale" <anthony.minessale at gmail.com>
To: freeswitch-users at lists.freeswitch.org
Sent: Tuesday, January 19, 2010 3:43:59 PM
Subject: Re: [Freeswitch-users] Lua: io.popen/read blocking in other incoming calls
if there is any global lock it would be in the lua lib. I know that would not happen in C so you may want to step it in the debugger and look for any evidence of a global mutex in the lua lib.
On Tue, Jan 19, 2010 at 3:03 PM, Dan < freeswitch-users at digitaldan.com > wrote:
My lua script is calling wget through lua's io.popen to send and receive data from a web service. While the f:read to wget is running, other incoming calls will block on the same io.popen call until the first call closes the pipe (with f:close()).
I had assumed every incoming call was on its own thread and that each had its own lua instance. Is there a global lock happening here? Below is the runCommand call and the two start and stop methods that are getting called in my script when the call begins and ends (notice they even talk to different hosts, so its not the web server hanging). I have put in debugging statements and its definitely hanging trying to call io.popen and not on the f:read. I noticed on the mod_python page ( http://wiki.freeswitch.org/wiki/Mod_python#Known_Bugs ) that it had read issues that were fixed in 12958, could this be related? I'm on svn trunk version 16272 on 32bit debian etch.
Thanks,
Dan-
function runCommand(command)
local f = io.popen(command) -- runs command
local l = f:read("*a") -- read output of command
f:close()
return l
end function notifyStart(id)
local url = " http://host1/start?id= " .. id
local wget = "/usr/bin/wget " .. url local out = runCommand(wget) return out; end
function notifyStop(id)
local url = " http://host2/start?id= " .. id
local wget = "/usr/bin/wget " .. url local out = runCommand(wget) return out; end
_______________________________________________
FreeSWITCH-users mailing list
FreeSWITCH-users at lists.freeswitch.org
http://lists.freeswitch.org/mailman/listinfo/freeswitch-users
UNSUBSCRIBE: http://lists.freeswitch.org/mailman/options/freeswitch-users
http://www.freeswitch.org
--
Anthony Minessale II
FreeSWITCH http://www.freeswitch.org/
ClueCon http://www.cluecon.com/
Twitter: http://twitter.com/FreeSWITCH_wire
AIM: anthm
MSN:anthony_minessale at hotmail.com
GTALK/JABBER/ PAYPAL:anthony.minessale at gmail.com
IRC: irc.freenode.net #freeswitch
FreeSWITCH Developer Conference
sip:888 at conference.freeswitch.org
iax:guest at conference.freeswitch.org/888
googletalk:conf+888 at conference.freeswitch.org
pstn:+19193869900
_______________________________________________
FreeSWITCH-users mailing list
FreeSWITCH-users at lists.freeswitch.org
http://lists.freeswitch.org/mailman/listinfo/freeswitch-users
UNSUBSCRIBE:http://lists.freeswitch.org/mailman/options/freeswitch-users
http://www.freeswitch.org
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.freeswitch.org/pipermail/freeswitch-users/attachments/20100119/13d56395/attachment.html
More information about the FreeSWITCH-users
mailing list