mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-24 07:13:33 +03:00 
			
		
		
		
	Merge willster.(none):/home/stewart/Documents/MySQL/5.0/ndb
into willster.(none):/home/stewart/Documents/MySQL/5.1/ndb storage/ndb/src/mgmsrv/MgmtSrvr.cpp: Auto merged storage/ndb/src/mgmsrv/MgmtSrvr.hpp: Auto merged storage/ndb/src/mgmsrv/Services.cpp: Auto merged storage/ndb/src/kernel/blocks/backup/Backup.cpp: manual merge storage/ndb/src/mgmclient/CommandInterpreter.cpp: manual merge storage/ndb/src/ndbapi/ClusterMgr.cpp: manual merge storage/ndb/src/ndbapi/ClusterMgr.hpp: manual merge
This commit is contained in:
		| @@ -229,14 +229,23 @@ Backup::execCONTINUEB(Signal* signal) | |||||||
|  |  | ||||||
|     BackupRecordPtr ptr; |     BackupRecordPtr ptr; | ||||||
|     c_backupPool.getPtr(ptr, ptr_I); |     c_backupPool.getPtr(ptr, ptr_I); | ||||||
|  |  | ||||||
|  |     if (tabPtr_I == RNIL) | ||||||
|  |     { | ||||||
|  |       closeFiles(signal, ptr); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     jam(); | ||||||
|     TablePtr tabPtr; |     TablePtr tabPtr; | ||||||
|     ptr.p->tables.getPtr(tabPtr, tabPtr_I); |     ptr.p->tables.getPtr(tabPtr, tabPtr_I); | ||||||
|  |     jam(); | ||||||
|  |     if(tabPtr.p->fragments.getSize()) | ||||||
|  |     { | ||||||
|       FragmentPtr fragPtr; |       FragmentPtr fragPtr; | ||||||
|       tabPtr.p->fragments.getPtr(fragPtr, fragPtr_I); |       tabPtr.p->fragments.getPtr(fragPtr, fragPtr_I); | ||||||
|  |  | ||||||
|       BackupFilePtr filePtr; |       BackupFilePtr filePtr; | ||||||
|       ptr.p->files.getPtr(filePtr, ptr.p->ctlFilePtr); |       ptr.p->files.getPtr(filePtr, ptr.p->ctlFilePtr); | ||||||
|  |  | ||||||
|       const Uint32 sz = sizeof(BackupFormat::CtlFile::FragmentInfo) >> 2; |       const Uint32 sz = sizeof(BackupFormat::CtlFile::FragmentInfo) >> 2; | ||||||
|       Uint32 * dst; |       Uint32 * dst; | ||||||
|       if (!filePtr.p->operation.dataBuffer.getWritePtr(&dst, sz)) |       if (!filePtr.p->operation.dataBuffer.getWritePtr(&dst, sz)) | ||||||
| @@ -259,6 +268,8 @@ Backup::execCONTINUEB(Signal* signal) | |||||||
|       filePtr.p->operation.dataBuffer.updateWritePtr(sz); |       filePtr.p->operation.dataBuffer.updateWritePtr(sz); | ||||||
|  |  | ||||||
|       fragPtr_I++; |       fragPtr_I++; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (fragPtr_I == tabPtr.p->fragments.getSize()) |     if (fragPtr_I == tabPtr.p->fragments.getSize()) | ||||||
|     { |     { | ||||||
|       signal->theData[0] = tabPtr.p->tableId; |       signal->theData[0] = tabPtr.p->tableId; | ||||||
| @@ -2040,6 +2051,12 @@ Backup::sendDropTrig(Signal* signal, BackupRecordPtr ptr) | |||||||
|         TablePtr tabPtr; |         TablePtr tabPtr; | ||||||
|         ptr.p->tables.first(tabPtr); |         ptr.p->tables.first(tabPtr); | ||||||
|  |  | ||||||
|  |         if(tabPtr.i == RNIL) | ||||||
|  |         { | ||||||
|  |           closeFiles(signal, ptr); | ||||||
|  |           return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         signal->theData[0] = BackupContinueB::BACKUP_FRAGMENT_INFO; |         signal->theData[0] = BackupContinueB::BACKUP_FRAGMENT_INFO; | ||||||
|         signal->theData[1] = ptr.i; |         signal->theData[1] = ptr.i; | ||||||
|         signal->theData[2] = tabPtr.i; |         signal->theData[2] = tabPtr.i; | ||||||
|   | |||||||
| @@ -161,8 +161,15 @@ private: | |||||||
|   int try_reconnect; |   int try_reconnect; | ||||||
|   int m_error; |   int m_error; | ||||||
|   struct NdbThread* m_event_thread; |   struct NdbThread* m_event_thread; | ||||||
|  |   NdbMutex *m_print_mutex; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | struct event_thread_param { | ||||||
|  |   NdbMgmHandle *m; | ||||||
|  |   NdbMutex **p; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | NdbMutex* print_mutex; | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Facade object for CommandInterpreter |  * Facade object for CommandInterpreter | ||||||
| @@ -340,6 +347,7 @@ CommandInterpreter::CommandInterpreter(const char *_host,int verbose) | |||||||
|   m_connected= false; |   m_connected= false; | ||||||
|   m_event_thread= 0; |   m_event_thread= 0; | ||||||
|   try_reconnect = 0; |   try_reconnect = 0; | ||||||
|  |   m_print_mutex= NdbMutex_Create(); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -348,6 +356,7 @@ CommandInterpreter::CommandInterpreter(const char *_host,int verbose) | |||||||
| CommandInterpreter::~CommandInterpreter()  | CommandInterpreter::~CommandInterpreter()  | ||||||
| { | { | ||||||
|   disconnect(); |   disconnect(); | ||||||
|  |   NdbMutex_Destroy(m_print_mutex); | ||||||
| } | } | ||||||
|  |  | ||||||
| static bool  | static bool  | ||||||
| @@ -384,11 +393,13 @@ CommandInterpreter::printError() | |||||||
|  |  | ||||||
| static int do_event_thread; | static int do_event_thread; | ||||||
| static void* | static void* | ||||||
| event_thread_run(void* m) | event_thread_run(void* p) | ||||||
| { | { | ||||||
|   DBUG_ENTER("event_thread_run"); |   DBUG_ENTER("event_thread_run"); | ||||||
|  |  | ||||||
|   NdbMgmHandle handle= *(NdbMgmHandle*)m; |   struct event_thread_param param= *(struct event_thread_param*)p; | ||||||
|  |   NdbMgmHandle handle= *(param.m); | ||||||
|  |   NdbMutex* printmutex= *(param.p); | ||||||
|  |  | ||||||
|   int filter[] = { 15, NDB_MGM_EVENT_CATEGORY_BACKUP, |   int filter[] = { 15, NDB_MGM_EVENT_CATEGORY_BACKUP, | ||||||
| 		   1, NDB_MGM_EVENT_CATEGORY_STARTUP, | 		   1, NDB_MGM_EVENT_CATEGORY_STARTUP, | ||||||
| @@ -406,8 +417,12 @@ event_thread_run(void* m) | |||||||
|       { |       { | ||||||
| 	const char ping_token[]= "<PING>"; | 	const char ping_token[]= "<PING>"; | ||||||
| 	if (memcmp(ping_token,tmp,sizeof(ping_token)-1)) | 	if (memcmp(ping_token,tmp,sizeof(ping_token)-1)) | ||||||
|  | 	  if(tmp && strlen(tmp)) | ||||||
|  |           { | ||||||
|  |             Guard g(printmutex); | ||||||
|             ndbout << tmp; |             ndbout << tmp; | ||||||
|           } |           } | ||||||
|  |       } | ||||||
|     } while(do_event_thread); |     } while(do_event_thread); | ||||||
|     NDB_CLOSE_SOCKET(fd); |     NDB_CLOSE_SOCKET(fd); | ||||||
|   } |   } | ||||||
| @@ -459,8 +474,11 @@ CommandInterpreter::connect() | |||||||
|     assert(m_event_thread == 0); |     assert(m_event_thread == 0); | ||||||
|     assert(do_event_thread == 0); |     assert(do_event_thread == 0); | ||||||
|     do_event_thread= 0; |     do_event_thread= 0; | ||||||
|  |     struct event_thread_param p; | ||||||
|  |     p.m= &m_mgmsrv2; | ||||||
|  |     p.p= &m_print_mutex; | ||||||
|     m_event_thread = NdbThread_Create(event_thread_run, |     m_event_thread = NdbThread_Create(event_thread_run, | ||||||
|                                       (void**)&m_mgmsrv2, |                                       (void**)&p, | ||||||
|                                       32768, |                                       32768, | ||||||
|                                       "CommandInterpreted_event_thread", |                                       "CommandInterpreted_event_thread", | ||||||
|                                       NDB_THREAD_PRIO_LOW); |                                       NDB_THREAD_PRIO_LOW); | ||||||
| @@ -547,6 +565,7 @@ CommandInterpreter::execute(const char *_line, int _try_reconnect, | |||||||
|   int result= execute_impl(_line); |   int result= execute_impl(_line); | ||||||
|   if (error) |   if (error) | ||||||
|     *error= m_error; |     *error= m_error; | ||||||
|  |  | ||||||
|   return result; |   return result; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -626,6 +645,7 @@ CommandInterpreter::execute_impl(const char *_line) | |||||||
|     DBUG_RETURN(true); |     DBUG_RETURN(true); | ||||||
|  |  | ||||||
|   if (strcasecmp(firstToken, "SHOW") == 0) { |   if (strcasecmp(firstToken, "SHOW") == 0) { | ||||||
|  |     Guard g(m_print_mutex); | ||||||
|     executeShow(allAfterFirstToken); |     executeShow(allAfterFirstToken); | ||||||
|     DBUG_RETURN(true); |     DBUG_RETURN(true); | ||||||
|   } |   } | ||||||
| @@ -853,6 +873,7 @@ CommandInterpreter::executeForAll(const char * cmd, ExecuteFunction fun, | |||||||
|     ndbout_c("Trying to start all nodes of system."); |     ndbout_c("Trying to start all nodes of system."); | ||||||
|     ndbout_c("Use ALL STATUS to see the system start-up phases."); |     ndbout_c("Use ALL STATUS to see the system start-up phases."); | ||||||
|   } else { |   } else { | ||||||
|  |     Guard g(m_print_mutex); | ||||||
|     struct ndb_mgm_cluster_state *cl= ndb_mgm_get_status(m_mgmsrv); |     struct ndb_mgm_cluster_state *cl= ndb_mgm_get_status(m_mgmsrv); | ||||||
|     if(cl == 0){ |     if(cl == 0){ | ||||||
|       ndbout_c("Unable get status from management server"); |       ndbout_c("Unable get status from management server"); | ||||||
|   | |||||||
| @@ -77,7 +77,6 @@ | |||||||
|     }\ |     }\ | ||||||
|   } |   } | ||||||
|  |  | ||||||
| extern int global_flag_send_heartbeat_now; |  | ||||||
| extern int g_no_nodeid_checks; | extern int g_no_nodeid_checks; | ||||||
| extern my_bool opt_core; | extern my_bool opt_core; | ||||||
|  |  | ||||||
| @@ -1450,6 +1449,12 @@ MgmtSrvr::exitSingleUser(int * stopCount, bool abort) | |||||||
|  |  | ||||||
| #include <ClusterMgr.hpp> | #include <ClusterMgr.hpp> | ||||||
|  |  | ||||||
|  | void | ||||||
|  | MgmtSrvr::updateStatus() | ||||||
|  | { | ||||||
|  |   theFacade->theClusterMgr->forceHB(); | ||||||
|  | } | ||||||
|  |  | ||||||
| int  | int  | ||||||
| MgmtSrvr::status(int nodeId,  | MgmtSrvr::status(int nodeId,  | ||||||
|                  ndb_mgm_node_status * _status,  |                  ndb_mgm_node_status * _status,  | ||||||
| @@ -2260,7 +2265,7 @@ MgmtSrvr::alloc_node_id(NodeId * nodeId, | |||||||
|   if (found_matching_type && !found_free_node) { |   if (found_matching_type && !found_free_node) { | ||||||
|     // we have a temporary error which might be due to that  |     // we have a temporary error which might be due to that  | ||||||
|     // we have got the latest connect status from db-nodes.  Force update. |     // we have got the latest connect status from db-nodes.  Force update. | ||||||
|     global_flag_send_heartbeat_now= 1; |     updateStatus(); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   BaseString type_string, type_c_string; |   BaseString type_string, type_c_string; | ||||||
| @@ -2603,7 +2608,7 @@ MgmtSrvr::Allocated_resources::~Allocated_resources() | |||||||
|   if (!m_reserved_nodes.isclear()) { |   if (!m_reserved_nodes.isclear()) { | ||||||
|     m_mgmsrv.m_reserved_nodes.bitANDC(m_reserved_nodes);  |     m_mgmsrv.m_reserved_nodes.bitANDC(m_reserved_nodes);  | ||||||
|     // node has been reserved, force update signal to ndb nodes |     // node has been reserved, force update signal to ndb nodes | ||||||
|     global_flag_send_heartbeat_now= 1; |     m_mgmsrv.updateStatus(); | ||||||
|  |  | ||||||
|     char tmp_str[128]; |     char tmp_str[128]; | ||||||
|     m_mgmsrv.m_reserved_nodes.getText(tmp_str); |     m_mgmsrv.m_reserved_nodes.getText(tmp_str); | ||||||
|   | |||||||
| @@ -485,6 +485,8 @@ public: | |||||||
|   void get_connected_nodes(NodeBitmask &connected_nodes) const; |   void get_connected_nodes(NodeBitmask &connected_nodes) const; | ||||||
|   SocketServer *get_socket_server() { return m_socket_server; } |   SocketServer *get_socket_server() { return m_socket_server; } | ||||||
|  |  | ||||||
|  |   void updateStatus(); | ||||||
|  |  | ||||||
|   //************************************************************************** |   //************************************************************************** | ||||||
| private: | private: | ||||||
|   //************************************************************************** |   //************************************************************************** | ||||||
|   | |||||||
| @@ -972,6 +972,7 @@ printNodeStatus(OutputStream *output, | |||||||
| 		MgmtSrvr &mgmsrv, | 		MgmtSrvr &mgmsrv, | ||||||
| 		enum ndb_mgm_node_type type) { | 		enum ndb_mgm_node_type type) { | ||||||
|   NodeId nodeId = 0; |   NodeId nodeId = 0; | ||||||
|  |   mgmsrv.updateStatus(); | ||||||
|   while(mgmsrv.getNextNodeId(&nodeId, type)) { |   while(mgmsrv.getNextNodeId(&nodeId, type)) { | ||||||
|     enum ndb_mgm_node_status status; |     enum ndb_mgm_node_status status; | ||||||
|     Uint32 startPhase = 0,  |     Uint32 startPhase = 0,  | ||||||
|   | |||||||
| @@ -37,8 +37,8 @@ | |||||||
| #include <mgmapi_configuration.hpp> | #include <mgmapi_configuration.hpp> | ||||||
| #include <mgmapi_config_parameters.h> | #include <mgmapi_config_parameters.h> | ||||||
|  |  | ||||||
| int global_flag_send_heartbeat_now= 0; |  | ||||||
| int global_flag_skip_invalidate_cache = 0; | int global_flag_skip_invalidate_cache = 0; | ||||||
|  | //#define DEBUG_REG | ||||||
|  |  | ||||||
| // Just a C wrapper for threadMain | // Just a C wrapper for threadMain | ||||||
| extern "C"  | extern "C"  | ||||||
| @@ -68,6 +68,8 @@ ClusterMgr::ClusterMgr(TransporterFacade & _facade): | |||||||
|   DBUG_ENTER("ClusterMgr::ClusterMgr"); |   DBUG_ENTER("ClusterMgr::ClusterMgr"); | ||||||
|   ndbSetOwnVersion(); |   ndbSetOwnVersion(); | ||||||
|   clusterMgrThreadMutex = NdbMutex_Create(); |   clusterMgrThreadMutex = NdbMutex_Create(); | ||||||
|  |   waitForHBCond= NdbCondition_Create(); | ||||||
|  |   waitingForHB= false; | ||||||
|   noOfAliveNodes= 0; |   noOfAliveNodes= 0; | ||||||
|   noOfConnectedNodes= 0; |   noOfConnectedNodes= 0; | ||||||
|   theClusterMgrThread= 0; |   theClusterMgrThread= 0; | ||||||
| @@ -80,6 +82,7 @@ ClusterMgr::~ClusterMgr() | |||||||
| { | { | ||||||
|   DBUG_ENTER("ClusterMgr::~ClusterMgr"); |   DBUG_ENTER("ClusterMgr::~ClusterMgr"); | ||||||
|   doStop(); |   doStop(); | ||||||
|  |   NdbCondition_Destroy(waitForHBCond); | ||||||
|   NdbMutex_Destroy(clusterMgrThreadMutex); |   NdbMutex_Destroy(clusterMgrThreadMutex); | ||||||
|   DBUG_VOID_RETURN; |   DBUG_VOID_RETURN; | ||||||
| } | } | ||||||
| @@ -153,6 +156,70 @@ ClusterMgr::doStop( ){ | |||||||
|   DBUG_VOID_RETURN; |   DBUG_VOID_RETURN; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void | ||||||
|  | ClusterMgr::forceHB() | ||||||
|  | { | ||||||
|  |     theFacade.lock_mutex(); | ||||||
|  |  | ||||||
|  |     if(waitingForHB) | ||||||
|  |     { | ||||||
|  |       NdbCondition_WaitTimeout(waitForHBCond, theFacade.theMutexPtr, 1000); | ||||||
|  |       theFacade.unlock_mutex(); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     waitingForHB= true; | ||||||
|  |  | ||||||
|  |     NodeBitmask ndb_nodes; | ||||||
|  |     ndb_nodes.clear(); | ||||||
|  |     waitForHBFromNodes.clear(); | ||||||
|  |     for(Uint32 i = 0; i < MAX_NODES; i++) | ||||||
|  |     { | ||||||
|  |       if(!theNodes[i].defined) | ||||||
|  |         continue; | ||||||
|  |       if(theNodes[i].m_info.m_type == NodeInfo::DB) | ||||||
|  |       { | ||||||
|  |         ndb_nodes.set(i); | ||||||
|  |         const ClusterMgr::Node &node= getNodeInfo(i); | ||||||
|  |         waitForHBFromNodes.bitOR(node.m_state.m_connected_nodes); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     waitForHBFromNodes.bitAND(ndb_nodes); | ||||||
|  |  | ||||||
|  | #ifdef DEBUG_REG | ||||||
|  |     char buf[128]; | ||||||
|  |     ndbout << "Waiting for HB from " << waitForHBFromNodes.getText(buf) << endl; | ||||||
|  | #endif | ||||||
|  |     NdbApiSignal signal(numberToRef(API_CLUSTERMGR, theFacade.ownId())); | ||||||
|  |  | ||||||
|  |     signal.theVerId_signalNumber   = GSN_API_REGREQ; | ||||||
|  |     signal.theReceiversBlockNumber = QMGR; | ||||||
|  |     signal.theTrace                = 0; | ||||||
|  |     signal.theLength               = ApiRegReq::SignalLength; | ||||||
|  |  | ||||||
|  |     ApiRegReq * req = CAST_PTR(ApiRegReq, signal.getDataPtrSend()); | ||||||
|  |     req->ref = numberToRef(API_CLUSTERMGR, theFacade.ownId()); | ||||||
|  |     req->version = NDB_VERSION; | ||||||
|  |  | ||||||
|  |     int nodeId= 0; | ||||||
|  |     for(int i=0; | ||||||
|  |         NodeBitmask::NotFound!=(nodeId= waitForHBFromNodes.find(i)); | ||||||
|  |         i= nodeId+1) | ||||||
|  |     { | ||||||
|  | #ifdef DEBUG_REG | ||||||
|  |       ndbout << "FORCE HB to " << nodeId << endl; | ||||||
|  | #endif | ||||||
|  |       theFacade.sendSignalUnCond(&signal, nodeId); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     NdbCondition_WaitTimeout(waitForHBCond, theFacade.theMutexPtr, 1000); | ||||||
|  |     waitingForHB= false; | ||||||
|  | #ifdef DEBUG_REG | ||||||
|  |     ndbout << "Still waiting for HB from " << waitForHBFromNodes.getText(buf) << endl; | ||||||
|  | #endif | ||||||
|  |     theFacade.unlock_mutex(); | ||||||
|  | } | ||||||
|  |  | ||||||
| void | void | ||||||
| ClusterMgr::threadMain( ){ | ClusterMgr::threadMain( ){ | ||||||
|   NdbApiSignal signal(numberToRef(API_CLUSTERMGR, theFacade.ownId())); |   NdbApiSignal signal(numberToRef(API_CLUSTERMGR, theFacade.ownId())); | ||||||
| @@ -174,9 +241,6 @@ ClusterMgr::threadMain( ){ | |||||||
|     /** |     /** | ||||||
|      * Start of Secure area for use of Transporter |      * Start of Secure area for use of Transporter | ||||||
|      */ |      */ | ||||||
|     int send_heartbeat_now= global_flag_send_heartbeat_now; |  | ||||||
|     global_flag_send_heartbeat_now= 0; |  | ||||||
|  |  | ||||||
|     if (m_cluster_state == CS_waiting_for_clean_cache) |     if (m_cluster_state == CS_waiting_for_clean_cache) | ||||||
|     { |     { | ||||||
|       theFacade.m_globalDictCache.lock(); |       theFacade.m_globalDictCache.lock(); | ||||||
| @@ -209,8 +273,7 @@ ClusterMgr::threadMain( ){ | |||||||
|       } |       } | ||||||
|        |        | ||||||
|       theNode.hbCounter += timeSlept; |       theNode.hbCounter += timeSlept; | ||||||
|       if (theNode.hbCounter >= theNode.hbFrequency || |       if (theNode.hbCounter >= theNode.hbFrequency) { | ||||||
| 	  send_heartbeat_now) { |  | ||||||
| 	/** | 	/** | ||||||
| 	 * It is now time to send a new Heartbeat | 	 * It is now time to send a new Heartbeat | ||||||
| 	 */ | 	 */ | ||||||
| @@ -219,7 +282,7 @@ ClusterMgr::threadMain( ){ | |||||||
| 	  theNode.hbCounter = 0; | 	  theNode.hbCounter = 0; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| #if 0  | #ifdef DEBUG_REG | ||||||
| 	ndbout_c("ClusterMgr: Sending API_REGREQ to node %d", (int)nodeId); | 	ndbout_c("ClusterMgr: Sending API_REGREQ to node %d", (int)nodeId); | ||||||
| #endif | #endif | ||||||
| 	theFacade.sendSignalUnCond(&signal, nodeId); | 	theFacade.sendSignalUnCond(&signal, nodeId); | ||||||
| @@ -272,7 +335,7 @@ ClusterMgr::execAPI_REGREQ(const Uint32 * theData){ | |||||||
|   const ApiRegReq * const apiRegReq = (ApiRegReq *)&theData[0]; |   const ApiRegReq * const apiRegReq = (ApiRegReq *)&theData[0]; | ||||||
|   const NodeId nodeId = refToNode(apiRegReq->ref); |   const NodeId nodeId = refToNode(apiRegReq->ref); | ||||||
|  |  | ||||||
| #if 0 | #ifdef DEBUG_REG | ||||||
|   ndbout_c("ClusterMgr: Recd API_REGREQ from node %d", nodeId); |   ndbout_c("ClusterMgr: Recd API_REGREQ from node %d", nodeId); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -313,7 +376,7 @@ ClusterMgr::execAPI_REGCONF(const Uint32 * theData){ | |||||||
|   const ApiRegConf * const apiRegConf = (ApiRegConf *)&theData[0]; |   const ApiRegConf * const apiRegConf = (ApiRegConf *)&theData[0]; | ||||||
|   const NodeId nodeId = refToNode(apiRegConf->qmgrRef); |   const NodeId nodeId = refToNode(apiRegConf->qmgrRef); | ||||||
|    |    | ||||||
| #if 0  | #ifdef DEBUG_REG | ||||||
|   ndbout_c("ClusterMgr: Recd API_REGCONF from node %d", nodeId); |   ndbout_c("ClusterMgr: Recd API_REGCONF from node %d", nodeId); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -342,6 +405,17 @@ ClusterMgr::execAPI_REGCONF(const Uint32 * theData){ | |||||||
|   }//if |   }//if | ||||||
|   node.m_info.m_heartbeat_cnt = 0; |   node.m_info.m_heartbeat_cnt = 0; | ||||||
|   node.hbCounter = 0; |   node.hbCounter = 0; | ||||||
|  |  | ||||||
|  |   if(waitingForHB) | ||||||
|  |   { | ||||||
|  |     waitForHBFromNodes.clear(nodeId); | ||||||
|  |  | ||||||
|  |     if(waitForHBFromNodes.isclear()) | ||||||
|  |     { | ||||||
|  |       waitingForHB= false; | ||||||
|  |       NdbCondition_Broadcast(waitForHBCond); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|   node.hbFrequency = (apiRegConf->apiHeartbeatFrequency * 10) - 50; |   node.hbFrequency = (apiRegConf->apiHeartbeatFrequency * 10) - 50; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -371,6 +445,10 @@ ClusterMgr::execAPI_REGREF(const Uint32 * theData){ | |||||||
|   default: |   default: | ||||||
|     break; |     break; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   waitForHBFromNodes.clear(nodeId); | ||||||
|  |   if(waitForHBFromNodes.isclear()) | ||||||
|  |     NdbCondition_Signal(waitForHBCond); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
|   | |||||||
| @@ -50,6 +50,8 @@ public: | |||||||
|   void doStop(); |   void doStop(); | ||||||
|   void startThread(); |   void startThread(); | ||||||
|  |  | ||||||
|  |   void forceHB(); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|   void threadMain(); |   void threadMain(); | ||||||
|    |    | ||||||
| @@ -91,6 +93,11 @@ private: | |||||||
|   Uint32        noOfConnectedNodes; |   Uint32        noOfConnectedNodes; | ||||||
|   Node          theNodes[MAX_NODES]; |   Node          theNodes[MAX_NODES]; | ||||||
|   NdbThread*    theClusterMgrThread; |   NdbThread*    theClusterMgrThread; | ||||||
|  |  | ||||||
|  |   NodeBitmask   waitForHBFromNodes; // used in forcing HBs | ||||||
|  |   NdbCondition* waitForHBCond; | ||||||
|  |   bool          waitingForHB; | ||||||
|  |  | ||||||
|   enum Cluster_state m_cluster_state; |   enum Cluster_state m_cluster_state; | ||||||
|   /** |   /** | ||||||
|    * Used for controlling start/stop of the thread |    * Used for controlling start/stop of the thread | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user