Open GoogleCodeExporter opened 9 years ago
Please attach a complete test case.
Original comment by fullung@gmail.com
on 28 Nov 2008 at 10:01
Original comment by fullung@gmail.com
on 28 Nov 2008 at 10:01
Original comment by fullung@gmail.com
on 28 Nov 2008 at 10:01
I'll create a test case soon (I'm using a wrapper so will have to unpack it).
It seems that the connection.close() and connection.send() are the culprits but
only
as long as there are pending messages on the broker.
Original comment by will.van...@gmail.com
on 28 Nov 2008 at 11:46
test case attached.
It will never reach the "stopped" print statement. I'm not sure why.
Same happens if we try and close the connection.
Original comment by will.van...@gmail.com
on 5 Dec 2008 at 1:42
Attachments:
Okay I have reproduced this issue. Looks like it might be a deadlock involving
AMQCPP
or maybe the GIL.
Original comment by fullung@gmail.com
on 3 Jan 2009 at 10:29
Things go awry when messages are still being delivered to the message handler
while
the connection is stopped at the "same" time.
I think it would be a good idea to rewrite this code against the C++ API so
that we
can make sure that the problem isn't there. If we can't reproduce it, then we
can
think about whether the wrapper needs work.
Original comment by fullung@gmail.com
on 3 Jan 2009 at 10:34
Okay, I think this might be the same bug as issue #25. The main thread is
calling
stop from Python, which locks the GIL and then waits on a mutex for message
listeners
to complete. Meanwhile the code that calls the message listener has locked the
mutex
and is trying to lock the GIL.
Now to figure out how to fix it...
Original comment by fullung@gmail.com
on 4 Jan 2009 at 9:55
Useful documentation: http://docs.python.org/c-api/init.html
Original comment by fullung@gmail.com
on 4 Jan 2009 at 9:59
Here's a patch that seems to fix the problem. We just need to think about
whether
Stoppable::stop is the only function that needs to release the GIL.
Original comment by fullung@gmail.com
on 4 Jan 2009 at 6:20
Attachments:
Patch isn't quite right yet...
Original comment by fullung@gmail.com
on 4 Jan 2009 at 7:50
OK. revisiting AMQ-CPP after a hiatus. Will see if I can figure out more.
Original comment by will.van...@gmail.com
on 5 Mar 2009 at 11:18
The most important thing to do is to show whether we can reproduce this problem
without involving pyactivemq.
Original comment by fullung@gmail.com
on 5 Mar 2009 at 11:40
Original issue reported on code.google.com by
will.van...@gmail.com
on 28 Nov 2008 at 9:59