diff options
| author | Ted Ross <tross@apache.org> | 2008-08-07 13:56:47 +0000 |
|---|---|---|
| committer | Ted Ross <tross@apache.org> | 2008-08-07 13:56:47 +0000 |
| commit | 30061286d69174eb2358eaadc43855f40df58952 (patch) | |
| tree | 9d25fe3ab9ab74243d6122bd80cbf837ed8fba1f /qpid/cpp/src | |
| parent | 4b7aa0f0971af475372d60474ecef9f4d49b3d04 (diff) | |
| download | qpid-python-30061286d69174eb2358eaadc43855f40df58952.tar.gz | |
On broker shutdown, re-join the timer thread outside of a locked scope to prevent deadlock.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@683619 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src')
| -rw-r--r-- | qpid/cpp/src/qpid/management/ManagementBroker.cpp | 32 |
1 files changed, 17 insertions, 15 deletions
diff --git a/qpid/cpp/src/qpid/management/ManagementBroker.cpp b/qpid/cpp/src/qpid/management/ManagementBroker.cpp index 6a3e61cfe4..1bdd8ab836 100644 --- a/qpid/cpp/src/qpid/management/ManagementBroker.cpp +++ b/qpid/cpp/src/qpid/management/ManagementBroker.cpp @@ -90,24 +90,26 @@ ManagementBroker::ManagementBroker () : ManagementBroker::~ManagementBroker () { - Mutex::ScopedLock lock (userLock); - - // Reset the shared pointers to exchanges. If this is not done now, the exchanges - // will stick around until dExchange and mExchange are implicitely destroyed (long - // after this destructor completes). Those exchanges hold references to management - // objects that will be invalid. - dExchange.reset(); - mExchange.reset(); timer.stop(); + { + Mutex::ScopedLock lock (userLock); - moveNewObjectsLH(); - for (ManagementObjectMap::iterator iter = managementObjects.begin (); - iter != managementObjects.end (); - iter++) { - ManagementObject* object = iter->second; - delete object; + // Reset the shared pointers to exchanges. If this is not done now, the exchanges + // will stick around until dExchange and mExchange are implicitely destroyed (long + // after this destructor completes). Those exchanges hold references to management + // objects that will be invalid. + dExchange.reset(); + mExchange.reset(); + + moveNewObjectsLH(); + for (ManagementObjectMap::iterator iter = managementObjects.begin (); + iter != managementObjects.end (); + iter++) { + ManagementObject* object = iter->second; + delete object; + } + managementObjects.clear(); } - managementObjects.clear(); } void ManagementBroker::configure(string _dataDir, uint16_t _interval, Manageable* _broker, int _threads) |
