diff options
author | Alan Conway <aconway@apache.org> | 2008-09-26 19:22:00 +0000 |
---|---|---|
committer | Alan Conway <aconway@apache.org> | 2008-09-26 19:22:00 +0000 |
commit | 44366590caa13db09e55e2c853bd66b363558fa7 (patch) | |
tree | e6ecd10c956fee5f5e865670911ea9ef46e1ed76 /cpp/src/qpid/cluster/MemberHandler.cpp | |
parent | b22dd47558cc11572d080ac25808012092dda597 (diff) | |
download | qpid-python-44366590caa13db09e55e2c853bd66b363558fa7.tar.gz |
cluster:]
- call updateMemberStats() exactly once for each change in cluster membership.
- fix spurious replication of catch-up connection close events.
Removed unused client/MessageQueue.h
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@699456 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/cluster/MemberHandler.cpp')
-rw-r--r-- | cpp/src/qpid/cluster/MemberHandler.cpp | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/cpp/src/qpid/cluster/MemberHandler.cpp b/cpp/src/qpid/cluster/MemberHandler.cpp index 53a1d13a4d..5f02754443 100644 --- a/cpp/src/qpid/cluster/MemberHandler.cpp +++ b/cpp/src/qpid/cluster/MemberHandler.cpp @@ -52,10 +52,8 @@ void MemberHandler::deliver(Event& e) { cluster.connectionEventQueue.push(e); } -void MemberHandler::update(const MemberId&, const framing::FieldTable& , uint64_t) { - Mutex::ScopedLock l(cluster.lock); - cluster.updateMemberStats(); -} +// Updates are for new joiners. +void MemberHandler::update(const MemberId&, const framing::FieldTable& , uint64_t) {} void MemberHandler::dumpRequest(const MemberId& dumpee, const std::string& urlStr) { Mutex::ScopedLock l(cluster.lock); @@ -75,8 +73,9 @@ void MemberHandler::dumpRequest(const MemberId& dumpee, const std::string& urlSt boost::bind(&MemberHandler::dumpError, this, _1))); } -void MemberHandler::ready(const MemberId& id, const std::string& url) { - cluster.map.ready(id, Url(url)); +void MemberHandler::ready(const MemberId& id, const std::string& urlStr) { + if (cluster.map.ready(id, Url(urlStr))) + cluster.updateMemberStats(); } |