diff options
author | Gordon Sim <gsim@apache.org> | 2010-06-22 15:42:35 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2010-06-22 15:42:35 +0000 |
commit | 943689bc77e922bc6589da53521e40aff5c7677b (patch) | |
tree | 11edee50bb567a4cfa7529f363223de56f805dae /cpp/src | |
parent | 7b97af3ddcc281d7fe52c60e85aafadd77392cfd (diff) | |
download | qpid-python-943689bc77e922bc6589da53521e40aff5c7677b.tar.gz |
Don't hold QueueRegistry lock while iterating over queues to purge them of expired messages.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@956923 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src')
-rw-r--r-- | cpp/src/qpid/broker/QueueCleaner.cpp | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/cpp/src/qpid/broker/QueueCleaner.cpp b/cpp/src/qpid/broker/QueueCleaner.cpp index c80fe89035..ed98468490 100644 --- a/cpp/src/qpid/broker/QueueCleaner.cpp +++ b/cpp/src/qpid/broker/QueueCleaner.cpp @@ -46,9 +46,25 @@ void QueueCleaner::Task::fire() parent.fired(); } +namespace { +struct CollectQueues +{ + std::vector<Queue::shared_ptr>* queues; + CollectQueues(std::vector<Queue::shared_ptr>* q) : queues(q) {} + void operator()(Queue::shared_ptr q) + { + queues->push_back(q); + } +}; +} + void QueueCleaner::fired() { - queues.eachQueue(boost::bind(&Queue::purgeExpired, _1)); + //collect copy of list of queues to avoid holding registry lock while we perform purge + std::vector<Queue::shared_ptr> copy; + CollectQueues collect(©); + queues.eachQueue(collect); + std::for_each(copy.begin(), copy.end(), boost::bind(&Queue::purgeExpired, _1)); task->setupNextFire(); timer.add(task); } |