summaryrefslogtreecommitdiff
path: root/cpp/src/qpidd.cpp
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2008-02-07 21:31:21 +0000
committerAlan Conway <aconway@apache.org>2008-02-07 21:31:21 +0000
commit910fa22beb64c0c4d64221d9485830035c1663ff (patch)
tree77fcbee2777dab502d2e093eaa1e467a363557a0 /cpp/src/qpidd.cpp
parentcbd253b15b5ff540c2766cb52e67e28b58b57364 (diff)
downloadqpid-python-910fa22beb64c0c4d64221d9485830035c1663ff.tar.gz
Clean shutdown of broker: Moved signal unsafe code from Broker::shutdown
to ~Broker, moved shutdown logging from shutdown handler to main() in qpidd.cpp git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@619646 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpidd.cpp')
-rw-r--r--cpp/src/qpidd.cpp20
1 files changed, 5 insertions, 15 deletions
diff --git a/cpp/src/qpidd.cpp b/cpp/src/qpidd.cpp
index 2a5862a4b9..6c20ebc58f 100644
--- a/cpp/src/qpidd.cpp
+++ b/cpp/src/qpidd.cpp
@@ -121,20 +121,9 @@ shared_ptr<Broker> brokerPtr;
auto_ptr<QpiddOptions> options;
void shutdownHandler(int /*signal*/){
- // FIXME aconway 2008-02-07:
- // https://bugzilla.redhat.com/show_bug.cgi?id=431928
-
- // The following commented code is in no
- // way async-signal safe and is causing sporadic hangs on
- // shutdown. This handler should push a shutdown event into the
- // epoll poller (making sure to use only async-safe functions!)
- // and let a poller thread actually do the shutdown.
-
- // QPID_LOG(notice, "Shutting down on signal " << signal);
- // brokerPtr->shutdown();
-
- // For now we just die on the signal, no cleanup.
- exit(0);
+ // Note: do not call any async-signal unsafe functions here.
+ // Do any extra shtudown actions in main() after broker->run()
+ brokerPtr->shutdown();
}
struct QpiddDaemon : public Daemon {
@@ -257,7 +246,8 @@ int main(int argc, char* argv[])
brokerPtr.reset(new Broker(options->broker));
if (options->broker.port == 0)
cout << uint16_t(brokerPtr->getPort()) << endl;
- brokerPtr->run();
+ brokerPtr->run();
+ QPID_LOG(notice, "Shutting down.");
}
return 0;
}