version 1.20, 2004/08/03 19:05:08
|
version 1.25, 2004/10/17 20:39:56
|
|
|
//%2003//////////////////////////////////////////////////////////////////////// |
//%2004//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Development |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// Company, L. P., IBM Corp., The Open Group, Tivoli Systems. |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; | // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; |
// IBM Corp.; EMC Corporation, The Open Group. | // IBM Corp.; EMC Corporation, The Open Group. |
|
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; |
|
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// Author: Dong Xiang, EMC Corporation (xiang_dong@emc.com) | // Author: Dong Xiang, EMC Corporation (xiang_dong@emc.com) |
// | // |
// Modified By: Dan Gorey (djgorey@us.ibm.com) | // Modified By: Dan Gorey (djgorey@us.ibm.com) |
|
// Amit K Arora, IBM (amita@in.ibm.com) for PEP#183 |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
|
if(!_dieNow) | if(!_dieNow) |
{ | { |
#ifdef PEGASUS_USE_23HTTPMONITOR_CLIENT | #ifdef PEGASUS_USE_23HTTPMONITOR_CLIENT |
if(false == _monitor->run(100)) |
if(false == _monitor->run(500000)) |
{ | { |
modulator++; | modulator++; |
if(!(modulator % 5000) ) |
|
{ |
|
try | try |
{ | { |
//MessageQueueService::_check_idle_flag = 1; | //MessageQueueService::_check_idle_flag = 1; |
|
|
{ | { |
} | } |
} | } |
} |
|
/* | /* |
if (handleShutdownSignal) | if (handleShutdownSignal) |
{ | { |
|
|
PEG_METHOD_ENTER(TRC_LISTENER, "CIMListenerService::shutdown()"); | PEG_METHOD_ENTER(TRC_LISTENER, "CIMListenerService::shutdown()"); |
| |
_dieNow = true; | _dieNow = true; |
|
#ifdef PEGASUS_USE_23HTTPMONITOR_CLIENT |
|
_monitor->tickle(); |
|
#endif |
| |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
} | } |
|
|
| |
// tell Monitor to stop listening for client connections | // tell Monitor to stop listening for client connections |
#ifdef PEGASUS_USE_23HTTPMONITOR_CLIENT | #ifdef PEGASUS_USE_23HTTPMONITOR_CLIENT |
_monitor->stopListeningForConnections(); |
_monitor->stopListeningForConnections(true); |
#else | #else |
_monitor->stop(); | _monitor->stop(); |
#endif | #endif |
|
|
// for the wait here is to make sure that the Monitor entries | // for the wait here is to make sure that the Monitor entries |
// are updated before closing the connection sockets. | // are updated before closing the connection sockets. |
// | // |
pegasus_sleep(150); |
// pegasus_sleep(150); Not needed now due to the semaphore in the Monitor |
| |
if(_acceptor!=NULL) | if(_acceptor!=NULL) |
_acceptor->closeConnectionSocket(); | _acceptor->closeConnectionSocket(); |
|
|
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
} | } |
| |
|
Uint32 CIMListenerService::getOutstandingRequestCount() |
|
{ |
|
return _acceptor->getOutstandingRequestCount(); |
|
} |
| |
CIMListenerIndicationDispatcher* CIMListenerService::getIndicationDispatcher() const | CIMListenerIndicationDispatcher* CIMListenerService::getIndicationDispatcher() const |
{ | { |
|
|
#endif | #endif |
svc->runForever(); | svc->runForever(); |
} | } |
|
|
delete svc; | delete svc; |
| |
return 0; | return 0; |
|
|
Boolean removeConsumer(CIMIndicationConsumer* consumer); | Boolean removeConsumer(CIMIndicationConsumer* consumer); |
| |
private: | private: |
|
Boolean waitForPendingRequests(Uint32 shutdownTimeout); |
|
|
Uint32 _portNumber; | Uint32 _portNumber; |
SSLContext* _sslContext; | SSLContext* _sslContext; |
| |
|
|
// Block incoming export requests and unbind the port | // Block incoming export requests and unbind the port |
_svc->stopClientConnection(); | _svc->stopClientConnection(); |
| |
|
// Wait until pending export requests in the server are done. |
|
waitForPendingRequests(10); |
|
|
// Shutdown the CIMListenerService | // Shutdown the CIMListenerService |
_svc->shutdown(); | _svc->shutdown(); |
} | } |
|
|
// Block incoming export requests and unbind the port | // Block incoming export requests and unbind the port |
_svc->stopClientConnection(); | _svc->stopClientConnection(); |
| |
|
// Wait until pending export requests in the server are done. |
|
waitForPendingRequests(10); |
|
|
// Shutdown the CIMListenerService | // Shutdown the CIMListenerService |
_svc->shutdown(); | _svc->shutdown(); |
| |
|
|
return _dispatcher->removeConsumer(consumer); | return _dispatcher->removeConsumer(consumer); |
} | } |
| |
|
Boolean CIMListenerRep::waitForPendingRequests(Uint32 shutdownTimeout) |
|
{ |
|
// Wait for 10 sec max |
|
Uint32 reqCount; |
|
Uint32 countDown = shutdownTimeout * 10; |
|
for (; countDown > 0; countDown--) |
|
{ |
|
reqCount = _svc->getOutstandingRequestCount(); |
|
if (reqCount > 0) |
|
pegasus_sleep(100); |
|
else |
|
return true; |
|
} |
|
|
|
return false; |
|
} |
|
|
///////////////////////////////////////////////////////////////////////////// | ///////////////////////////////////////////////////////////////////////////// |
// CIMListener | // CIMListener |
///////////////////////////////////////////////////////////////////////////// | ///////////////////////////////////////////////////////////////////////////// |