ndb - bug#24544

  fix so backup message is printed even in case of "ndb_mgm -e"
parent 60b19639
...@@ -20,9 +20,10 @@ ...@@ -20,9 +20,10 @@
bool bool
printBACKUP_REQ(FILE * output, const Uint32 * theData, Uint32 len, Uint16 bno){ printBACKUP_REQ(FILE * output, const Uint32 * theData, Uint32 len, Uint16 bno){
BackupReq* sig = (BackupReq*)theData; BackupReq* sig = (BackupReq*)theData;
fprintf(output, " senderData: %d DataLength: %d\n", fprintf(output, " senderData: %d DataLength: %d flags: %d\n",
sig->senderData, sig->senderData,
sig->backupDataLen); sig->backupDataLen,
sig->flags);
return true; return true;
} }
......
...@@ -119,7 +119,7 @@ public: ...@@ -119,7 +119,7 @@ public:
int executeStatus(int processId, const char* parameters, bool all); int executeStatus(int processId, const char* parameters, bool all);
int executeEventReporting(int processId, const char* parameters, bool all); int executeEventReporting(int processId, const char* parameters, bool all);
int executeDumpState(int processId, const char* parameters, bool all); int executeDumpState(int processId, const char* parameters, bool all);
int executeStartBackup(char * parameters); int executeStartBackup(char * parameters, bool interactive);
int executeAbortBackup(char * parameters); int executeAbortBackup(char * parameters);
int executeStop(Vector<BaseString> &command_list, unsigned command_pos, int executeStop(Vector<BaseString> &command_list, unsigned command_pos,
int *node_ids, int no_of_nodes); int *node_ids, int no_of_nodes);
...@@ -991,7 +991,7 @@ CommandInterpreter::execute_impl(const char *_line, bool interactive) ...@@ -991,7 +991,7 @@ CommandInterpreter::execute_impl(const char *_line, bool interactive)
else if(strcasecmp(firstToken, "START") == 0 && else if(strcasecmp(firstToken, "START") == 0 &&
allAfterFirstToken != NULL && allAfterFirstToken != NULL &&
strncasecmp(allAfterFirstToken, "BACKUP", sizeof("BACKUP") - 1) == 0){ strncasecmp(allAfterFirstToken, "BACKUP", sizeof("BACKUP") - 1) == 0){
m_error= executeStartBackup(allAfterFirstToken); m_error= executeStartBackup(allAfterFirstToken, interactive);
DBUG_RETURN(true); DBUG_RETURN(true);
} }
else if(strcasecmp(firstToken, "ABORT") == 0 && else if(strcasecmp(firstToken, "ABORT") == 0 &&
...@@ -2442,24 +2442,17 @@ CommandInterpreter::executeEventReporting(int processId, ...@@ -2442,24 +2442,17 @@ CommandInterpreter::executeEventReporting(int processId,
return retval; return retval;
} }
/***************************************************************************** /*****************************************************************************
* Backup * Backup
*****************************************************************************/ *****************************************************************************/
int int
CommandInterpreter::executeStartBackup(char* parameters) CommandInterpreter::executeStartBackup(char* parameters, bool interactive)
{ {
struct ndb_mgm_reply reply; struct ndb_mgm_reply reply;
unsigned int backupId; unsigned int backupId;
#if 0 int fd = -1;
int filter[] = { 15, NDB_MGM_EVENT_CATEGORY_BACKUP, 0 };
int fd = ndb_mgm_listen_event(m_mgmsrv, filter);
if (fd < 0)
{
ndbout << "Initializing start of backup failed" << endl;
printError();
return fd;
}
#endif
Vector<BaseString> args; Vector<BaseString> args;
{ {
BaseString(parameters).split(args); BaseString(parameters).split(args);
...@@ -2472,25 +2465,21 @@ CommandInterpreter::executeStartBackup(char* parameters) ...@@ -2472,25 +2465,21 @@ CommandInterpreter::executeStartBackup(char* parameters)
int sz= args.size(); int sz= args.size();
int result; int result;
if (sz == 2 && int flags = 2;
args[1] == "NOWAIT") if (sz == 2 && args[1] == "NOWAIT")
{ {
flags = 0;
result = ndb_mgm_start_backup(m_mgmsrv, 0, &backupId, &reply); result = ndb_mgm_start_backup(m_mgmsrv, 0, &backupId, &reply);
} }
else if (sz == 1 || else if (sz == 1 || (sz == 3 && args[1] == "WAIT" && args[2] == "COMPLETED"))
(sz == 3 &&
args[1] == "WAIT" &&
args[2] == "COMPLETED"))
{ {
flags = 2;
ndbout_c("Waiting for completed, this may take several minutes"); ndbout_c("Waiting for completed, this may take several minutes");
result = ndb_mgm_start_backup(m_mgmsrv, 2, &backupId, &reply);
} }
else if (sz == 3 && else if (sz == 3 && args[1] == "WAIT" && args[2] == "STARTED")
args[1] == "WAIT" &&
args[2] == "STARTED")
{ {
ndbout_c("Waiting for started, this may take several minutes"); ndbout_c("Waiting for started, this may take several minutes");
result = ndb_mgm_start_backup(m_mgmsrv, 1, &backupId, &reply); flags = 1;
} }
else else
{ {
...@@ -2498,16 +2487,33 @@ CommandInterpreter::executeStartBackup(char* parameters) ...@@ -2498,16 +2487,33 @@ CommandInterpreter::executeStartBackup(char* parameters)
return -1; return -1;
} }
/**
* If interactive...event listner is already running
*/
if (flags == 2 && !interactive)
{
int filter[] = { 15, NDB_MGM_EVENT_CATEGORY_BACKUP, 0, 0 };
fd = ndb_mgm_listen_event(m_mgmsrv, filter);
if (fd < 0)
{
ndbout << "Initializing start of backup failed" << endl;
printError();
return fd;
}
}
result = ndb_mgm_start_backup(m_mgmsrv, flags, &backupId, &reply);
if (result != 0) { if (result != 0) {
ndbout << "Backup failed" << endl; ndbout << "Backup failed" << endl;
printError(); printError();
#if 0
if (fd >= 0)
close(fd); close(fd);
#endif
return result; return result;
} }
#if 0
ndbout_c("Waiting for completed, this may take several minutes"); if (fd >= 0)
{
char *tmp; char *tmp;
char buf[1024]; char buf[1024];
{ {
...@@ -2536,7 +2542,8 @@ CommandInterpreter::executeStartBackup(char* parameters) ...@@ -2536,7 +2542,8 @@ CommandInterpreter::executeStartBackup(char* parameters)
} while(tmp && tmp[0] != 0); } while(tmp && tmp[0] != 0);
close(fd); close(fd);
#endif }
return 0; return 0;
} }
......
...@@ -131,15 +131,6 @@ SignalSender::getNoOfConnectedNodes() const { ...@@ -131,15 +131,6 @@ SignalSender::getNoOfConnectedNodes() const {
return theFacade->theClusterMgr->getNoOfConnectedNodes(); return theFacade->theClusterMgr->getNoOfConnectedNodes();
} }
SendStatus
SignalSender::sendSignal(Uint16 nodeId, const SimpleSignal * s){
return theFacade->theTransporterRegistry->prepareSend(&s->header,
1, // JBB
&s->theData[0],
nodeId,
&s->ptr[0]);
}
template<class T> template<class T>
SimpleSignal * SimpleSignal *
SignalSender::waitFor(Uint32 timeOutMillis, T & t) SignalSender::waitFor(Uint32 timeOutMillis, T & t)
......
...@@ -1512,3 +1512,28 @@ void PollGuard::unlock_and_signal() ...@@ -1512,3 +1512,28 @@ void PollGuard::unlock_and_signal()
template class Vector<NodeStatusFunction>; template class Vector<NodeStatusFunction>;
template class Vector<TransporterFacade::ThreadData::Object_Execute>; template class Vector<TransporterFacade::ThreadData::Object_Execute>;
#include "SignalSender.hpp"
SendStatus
SignalSender::sendSignal(Uint16 nodeId, const SimpleSignal * s){
#ifdef API_TRACE
if(setSignalLog() && TRACE_GSN(s->header.theVerId_signalNumber)){
SignalHeader tmp = s->header;
tmp.theSendersBlockRef = getOwnRef();
LinearSectionPtr ptr[3];
signalLogger.sendSignal(tmp,
1,
s->theData,
nodeId, ptr, 0);
signalLogger.flushSignalLog();
}
#endif
return theFacade->theTransporterRegistry->prepareSend(&s->header,
1, // JBB
&s->theData[0],
nodeId,
&s->ptr[0]);
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment