Commit 3f82ef6d authored by unknown's avatar unknown

bug-4586


ndb/src/kernel/blocks/dbacc/Dbacc.hpp:
  Disallow expand during redo log execution and reeanble it after
ndb/src/kernel/blocks/dbacc/DbaccMain.cpp:
  Disallow expand during redo log execution and reeanble it after
ndb/src/kernel/blocks/dblqh/Dblqh.hpp:
  Maintain list of fragment which should be reenabled after redo log execution
ndb/src/kernel/blocks/dblqh/DblqhInit.cpp:
  Maintain list of fragment which should be reenabled after redo log execution
ndb/src/kernel/blocks/dblqh/DblqhMain.cpp:
  Reenable when send START_RECCONF
parent 3d8b8bae
...@@ -1192,6 +1192,7 @@ private: ...@@ -1192,6 +1192,7 @@ private:
void reportMemoryUsage(Signal* signal, int gth); void reportMemoryUsage(Signal* signal, int gth);
void lcp_write_op_to_undolog(Signal* signal); void lcp_write_op_to_undolog(Signal* signal);
void reenable_expand_after_redo_log_exection_complete(Signal*);
// Initialisation // Initialisation
...@@ -1561,11 +1562,9 @@ private: ...@@ -1561,11 +1562,9 @@ private:
Uint32 cexcPrevforward; Uint32 cexcPrevforward;
Uint32 clocalkey[32]; Uint32 clocalkey[32];
Uint32 ckeys[2048]; Uint32 ckeys[2048];
Uint32 c_errorInsert3000_TableId; Uint32 c_errorInsert3000_TableId;
Uint32 cSrUndoRecords[5]; Uint32 cSrUndoRecords[5];
Uint32 c_no_fragment_allocated;
}; };
#endif #endif
...@@ -599,7 +599,6 @@ void Dbacc::ndbrestart1Lab(Signal* signal) ...@@ -599,7 +599,6 @@ void Dbacc::ndbrestart1Lab(Signal* signal)
for (Uint32 tmp = 0; tmp < ZMAX_UNDO_VERSION; tmp++) { for (Uint32 tmp = 0; tmp < ZMAX_UNDO_VERSION; tmp++) {
csrVersList[tmp] = RNIL; csrVersList[tmp] = RNIL;
}//for }//for
c_no_fragment_allocated = 0;
return; return;
}//Dbacc::ndbrestart1Lab() }//Dbacc::ndbrestart1Lab()
...@@ -1361,8 +1360,6 @@ void Dbacc::releaseDirIndexResources(Signal* signal, FragmentrecPtr regFragPtr) ...@@ -1361,8 +1360,6 @@ void Dbacc::releaseDirIndexResources(Signal* signal, FragmentrecPtr regFragPtr)
void Dbacc::releaseFragRecord(Signal* signal, FragmentrecPtr regFragPtr) void Dbacc::releaseFragRecord(Signal* signal, FragmentrecPtr regFragPtr)
{ {
ndbrequire(c_no_fragment_allocated > 0);
c_no_fragment_allocated--;
regFragPtr.p->nextfreefrag = cfirstfreefrag; regFragPtr.p->nextfreefrag = cfirstfreefrag;
cfirstfreefrag = regFragPtr.i; cfirstfreefrag = regFragPtr.i;
initFragGeneral(regFragPtr); initFragGeneral(regFragPtr);
...@@ -2342,13 +2339,14 @@ void Dbacc::execACC_COMMITREQ(Signal* signal) ...@@ -2342,13 +2339,14 @@ void Dbacc::execACC_COMMITREQ(Signal* signal)
fragrecptr.p->slack += operationRecPtr.p->insertDeleteLen; fragrecptr.p->slack += operationRecPtr.p->insertDeleteLen;
if (fragrecptr.p->slack > fragrecptr.p->slackCheck) { /* TIME FOR JOIN BUCKETS PROCESS */ if (fragrecptr.p->slack > fragrecptr.p->slackCheck) { /* TIME FOR JOIN BUCKETS PROCESS */
if (fragrecptr.p->expandCounter > 0) { if (fragrecptr.p->expandCounter > 0) {
if (fragrecptr.p->expandFlag == 0) { if (fragrecptr.p->expandFlag < 2) {
jam(); jam();
fragrecptr.p->expandFlag = 1;
signal->theData[0] = fragrecptr.i; signal->theData[0] = fragrecptr.i;
signal->theData[1] = fragrecptr.p->p; signal->theData[1] = fragrecptr.p->p;
signal->theData[2] = fragrecptr.p->maxp; signal->theData[2] = fragrecptr.p->maxp;
sendSignal(cownBlockref, GSN_SHRINKCHECK2, signal, 3, JBB); signal->theData[3] = fragrecptr.p->expandFlag;
fragrecptr.p->expandFlag = 2;
sendSignal(cownBlockref, GSN_SHRINKCHECK2, signal, 4, JBB);
}//if }//if
}//if }//if
}//if }//if
...@@ -2362,7 +2360,7 @@ void Dbacc::execACC_COMMITREQ(Signal* signal) ...@@ -2362,7 +2360,7 @@ void Dbacc::execACC_COMMITREQ(Signal* signal)
if (fragrecptr.p->slack >= (Uint32)(1 << 31)) { /* IT MEANS THAT IF SLACK < ZERO */ if (fragrecptr.p->slack >= (Uint32)(1 << 31)) { /* IT MEANS THAT IF SLACK < ZERO */
if (fragrecptr.p->expandFlag == 0) { if (fragrecptr.p->expandFlag == 0) {
jam(); jam();
fragrecptr.p->expandFlag = 1; fragrecptr.p->expandFlag = 2;
signal->theData[0] = fragrecptr.i; signal->theData[0] = fragrecptr.i;
signal->theData[1] = fragrecptr.p->p; signal->theData[1] = fragrecptr.p->p;
signal->theData[2] = fragrecptr.p->maxp; signal->theData[2] = fragrecptr.p->maxp;
...@@ -6334,9 +6332,16 @@ Uint32 Dbacc::checkScanExpand(Signal* signal) ...@@ -6334,9 +6332,16 @@ Uint32 Dbacc::checkScanExpand(Signal* signal)
void Dbacc::execEXPANDCHECK2(Signal* signal) void Dbacc::execEXPANDCHECK2(Signal* signal)
{ {
jamEntry();
if(refToBlock(signal->getSendersBlockRef()) == DBLQH){
jam();
reenable_expand_after_redo_log_exection_complete(signal);
return;
}
DirectoryarrayPtr newDirptr; DirectoryarrayPtr newDirptr;
jamEntry();
fragrecptr.i = signal->theData[0]; fragrecptr.i = signal->theData[0];
tresult = 0; /* 0= FALSE,1= TRUE,> ZLIMIT_OF_ERROR =ERRORCODE */ tresult = 0; /* 0= FALSE,1= TRUE,> ZLIMIT_OF_ERROR =ERRORCODE */
Uint32 tmp = 1; Uint32 tmp = 1;
...@@ -6353,7 +6358,7 @@ void Dbacc::execEXPANDCHECK2(Signal* signal) ...@@ -6353,7 +6358,7 @@ void Dbacc::execEXPANDCHECK2(Signal* signal)
return; return;
}//if }//if
if (cfirstfreepage == RNIL) { if (cfirstfreepage == RNIL) {
if ((cfreepage + c_no_fragment_allocated) >= cpagesize) { if (cfreepage + 10 >= cpagesize) {
jam(); jam();
/*--------------------------------------------------------------*/ /*--------------------------------------------------------------*/
/* WE HAVE TO STOP THE EXPAND PROCESS SINCE THERE ARE NO FREE */ /* WE HAVE TO STOP THE EXPAND PROCESS SINCE THERE ARE NO FREE */
...@@ -6394,6 +6399,10 @@ void Dbacc::execEXPANDCHECK2(Signal* signal) ...@@ -6394,6 +6399,10 @@ void Dbacc::execEXPANDCHECK2(Signal* signal)
return; return;
}//if }//if
}//if }//if
ndbout_c("Expanding tab: %d frag: %d",
fragrecptr.p->myTableId, fragrecptr.p->myfid);
/*--------------------------------------------------------------------------*/ /*--------------------------------------------------------------------------*/
/* WE START BY FINDING THE PAGE, THE PAGE INDEX AND THE PAGE DIRECTORY*/ /* WE START BY FINDING THE PAGE, THE PAGE INDEX AND THE PAGE DIRECTORY*/
/* OF THE NEW BUCKET WHICH SHALL RECEIVE THE ELEMENT WHICH HAVE A 1 IN*/ /* OF THE NEW BUCKET WHICH SHALL RECEIVE THE ELEMENT WHICH HAVE A 1 IN*/
...@@ -6447,6 +6456,7 @@ void Dbacc::execEXPANDCHECK2(Signal* signal) ...@@ -6447,6 +6456,7 @@ void Dbacc::execEXPANDCHECK2(Signal* signal)
} else { } else {
ptrCheckGuard(expPageptr, cpagesize, page8); ptrCheckGuard(expPageptr, cpagesize, page8);
}//if }//if
fragrecptr.p->expReceivePageptr = expPageptr.i; fragrecptr.p->expReceivePageptr = expPageptr.i;
fragrecptr.p->expReceiveIndex = texpReceivedBucket & ((1 << fragrecptr.p->k) - 1); fragrecptr.p->expReceiveIndex = texpReceivedBucket & ((1 << fragrecptr.p->k) - 1);
/*--------------------------------------------------------------------------*/ /*--------------------------------------------------------------------------*/
...@@ -6497,7 +6507,7 @@ void Dbacc::endofexpLab(Signal* signal) ...@@ -6497,7 +6507,7 @@ void Dbacc::endofexpLab(Signal* signal)
/* IT IS STILL NECESSARY TO EXPAND THE FRAGMENT EVEN MORE. START IT FROM HERE */ /* IT IS STILL NECESSARY TO EXPAND THE FRAGMENT EVEN MORE. START IT FROM HERE */
/* WITHOUT WAITING FOR NEXT COMMIT ON THE FRAGMENT. */ /* WITHOUT WAITING FOR NEXT COMMIT ON THE FRAGMENT. */
/* --------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------- */
fragrecptr.p->expandFlag = 1; fragrecptr.p->expandFlag = 2;
signal->theData[0] = fragrecptr.i; signal->theData[0] = fragrecptr.i;
signal->theData[1] = fragrecptr.p->p; signal->theData[1] = fragrecptr.p->p;
signal->theData[2] = fragrecptr.p->maxp; signal->theData[2] = fragrecptr.p->maxp;
...@@ -6506,6 +6516,46 @@ void Dbacc::endofexpLab(Signal* signal) ...@@ -6506,6 +6516,46 @@ void Dbacc::endofexpLab(Signal* signal)
return; return;
}//Dbacc::endofexpLab() }//Dbacc::endofexpLab()
void Dbacc::reenable_expand_after_redo_log_exection_complete(Signal* signal){
tabptr.i = signal->theData[0];
Uint32 fragId = signal->theData[1];
ptrCheckGuard(tabptr, ctablesize, tabrec);
ndbrequire(getrootfragmentrec(signal, rootfragrecptr, fragId));
ndbout_c("reenable expand check for table %d fragment: %d",
tabptr.i, fragId);
for (Uint32 i = 0; i < 2; i++) {
fragrecptr.i = rootfragrecptr.p->fragmentptr[i];
ptrCheckGuard(fragrecptr, cfragmentsize, fragmentrec);
switch(fragrecptr.p->expandFlag){
case 0:
/**
* Hmm... this means that it's alreay has been reenabled...
*/
//ndbassert(false);
continue;
case 1:
/**
* Nothing is going on start expand check
*/
case 2:
/**
* A shrink is running, do expand check anyway
* (to reset expandFlag)
*/
fragrecptr.p->expandFlag = 2;
signal->theData[0] = fragrecptr.i;
signal->theData[1] = fragrecptr.p->p;
signal->theData[2] = fragrecptr.p->maxp;
sendSignal(cownBlockref, GSN_EXPANDCHECK2, signal, 3, JBB);
break;
}
}
}
void Dbacc::execDEBUG_SIG(Signal* signal) void Dbacc::execDEBUG_SIG(Signal* signal)
{ {
jamEntry(); jamEntry();
...@@ -6901,9 +6951,10 @@ void Dbacc::execSHRINKCHECK2(Signal* signal) ...@@ -6901,9 +6951,10 @@ void Dbacc::execSHRINKCHECK2(Signal* signal)
jamEntry(); jamEntry();
fragrecptr.i = signal->theData[0]; fragrecptr.i = signal->theData[0];
Uint32 oldFlag = signal->theData[3];
fragrecptr.p->expandFlag = oldFlag;
tresult = 0; /* 0= FALSE,1= TRUE,> ZLIMIT_OF_ERROR =ERRORCODE */ tresult = 0; /* 0= FALSE,1= TRUE,> ZLIMIT_OF_ERROR =ERRORCODE */
ptrCheckGuard(fragrecptr, cfragmentsize, fragmentrec); ptrCheckGuard(fragrecptr, cfragmentsize, fragmentrec);
fragrecptr.p->expandFlag = 0;
if (fragrecptr.p->slack <= fragrecptr.p->slackCheck) { if (fragrecptr.p->slack <= fragrecptr.p->slackCheck) {
jam(); jam();
/* TIME FOR JOIN BUCKETS PROCESS */ /* TIME FOR JOIN BUCKETS PROCESS */
...@@ -6938,7 +6989,7 @@ void Dbacc::execSHRINKCHECK2(Signal* signal) ...@@ -6938,7 +6989,7 @@ void Dbacc::execSHRINKCHECK2(Signal* signal)
}//if }//if
}//if }//if
if (cfirstfreepage == RNIL) { if (cfirstfreepage == RNIL) {
if (cfreepage + c_no_fragment_allocated >= cpagesize) { if (cfreepage >= cpagesize) {
jam(); jam();
/*--------------------------------------------------------------*/ /*--------------------------------------------------------------*/
/* WE HAVE TO STOP THE SHRINK PROCESS SINCE THERE ARE NO FREE */ /* WE HAVE TO STOP THE SHRINK PROCESS SINCE THERE ARE NO FREE */
...@@ -6984,6 +7035,10 @@ void Dbacc::execSHRINKCHECK2(Signal* signal) ...@@ -6984,6 +7035,10 @@ void Dbacc::execSHRINKCHECK2(Signal* signal)
jam(); jam();
fragrecptr.p->p--; fragrecptr.p->p--;
}//if }//if
ndbout_c("Shrinking tab: %d frag: %d",
fragrecptr.p->myTableId, fragrecptr.p->myfid);
/*--------------------------------------------------------------------------*/ /*--------------------------------------------------------------------------*/
/* WE START BY FINDING THE NECESSARY INFORMATION OF THE BUCKET TO BE */ /* WE START BY FINDING THE NECESSARY INFORMATION OF THE BUCKET TO BE */
/* REMOVED WHICH WILL SEND ITS ELEMENTS TO THE RECEIVING BUCKET. */ /* REMOVED WHICH WILL SEND ITS ELEMENTS TO THE RECEIVING BUCKET. */
...@@ -7176,10 +7231,11 @@ void Dbacc::endofshrinkbucketLab(Signal* signal) ...@@ -7176,10 +7231,11 @@ void Dbacc::endofshrinkbucketLab(Signal* signal)
/* SHRINKING BELOW 2^K - 1 (NOW 63). THIS WAS A BUG THAT */ /* SHRINKING BELOW 2^K - 1 (NOW 63). THIS WAS A BUG THAT */
/* WAS REMOVED 2000-05-12. */ /* WAS REMOVED 2000-05-12. */
/*--------------------------------------------------------------*/ /*--------------------------------------------------------------*/
fragrecptr.p->expandFlag = 1;
signal->theData[0] = fragrecptr.i; signal->theData[0] = fragrecptr.i;
signal->theData[1] = fragrecptr.p->p; signal->theData[1] = fragrecptr.p->p;
signal->theData[2] = fragrecptr.p->maxp; signal->theData[2] = fragrecptr.p->maxp;
signal->theData[3] = fragrecptr.p->expandFlag;
fragrecptr.p->expandFlag = 2;
sendSignal(cownBlockref, GSN_SHRINKCHECK2, signal, 3, JBB); sendSignal(cownBlockref, GSN_SHRINKCHECK2, signal, 3, JBB);
}//if }//if
}//if }//if
...@@ -9196,7 +9252,15 @@ void Dbacc::initFragAdd(Signal* signal, ...@@ -9196,7 +9252,15 @@ void Dbacc::initFragAdd(Signal* signal,
ndbrequire(req->kValue == 6); ndbrequire(req->kValue == 6);
regFragPtr.p->k = req->kValue; /* TK_SIZE = 6 IN THIS VERSION */ regFragPtr.p->k = req->kValue; /* TK_SIZE = 6 IN THIS VERSION */
regFragPtr.p->expandCounter = 0; regFragPtr.p->expandCounter = 0;
regFragPtr.p->expandFlag = 0;
/**
* Only allow shrink during SR
* - to make sure we don't run out of pages during REDO log execution
*
* Is later restored to 0 by LQH at end of REDO log execution
*/
regFragPtr.p->expandFlag = (getNodeState().getSystemRestartInProgress()?1:0);
regFragPtr.p->p = 0; regFragPtr.p->p = 0;
regFragPtr.p->maxp = (1 << req->kValue) - 1; regFragPtr.p->maxp = (1 << req->kValue) - 1;
regFragPtr.p->minloadfactor = minLoadFactor; regFragPtr.p->minloadfactor = minLoadFactor;
...@@ -12775,7 +12839,6 @@ void Dbacc::seizeDirrange(Signal* signal) ...@@ -12775,7 +12839,6 @@ void Dbacc::seizeDirrange(Signal* signal)
/* --------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------- */
void Dbacc::seizeFragrec(Signal* signal) void Dbacc::seizeFragrec(Signal* signal)
{ {
c_no_fragment_allocated++;
fragrecptr.i = cfirstfreefrag; fragrecptr.i = cfirstfreefrag;
ptrCheckGuard(fragrecptr, cfragmentsize, fragmentrec); ptrCheckGuard(fragrecptr, cfragmentsize, fragmentrec);
cfirstfreefrag = fragrecptr.p->nextfreefrag; cfirstfreefrag = fragrecptr.p->nextfreefrag;
......
...@@ -2764,6 +2764,11 @@ private: ...@@ -2764,6 +2764,11 @@ private:
/* ------------------------------------------------------------------------- */ /* ------------------------------------------------------------------------- */
UintR cfirstCompletedFragSr; UintR cfirstCompletedFragSr;
/**
* List of fragment that the log execution is completed for
*/
Uint32 c_redo_log_complete_frags;
/* ------------------------------------------------------------------------- */ /* ------------------------------------------------------------------------- */
/*USED DURING SYSTEM RESTART, INDICATES THE OLDEST GCI THAT CAN BE RESTARTED */ /*USED DURING SYSTEM RESTART, INDICATES THE OLDEST GCI THAT CAN BE RESTARTED */
/*FROM AFTER THIS SYSTEM RESTART. USED TO FIND THE LOG TAIL. */ /*FROM AFTER THIS SYSTEM RESTART. USED TO FIND THE LOG TAIL. */
......
...@@ -65,6 +65,7 @@ void Dblqh::initData() ...@@ -65,6 +65,7 @@ void Dblqh::initData()
cLqhTimeOutCount = 0; cLqhTimeOutCount = 0;
cLqhTimeOutCheckCount = 0; cLqhTimeOutCheckCount = 0;
cbookedAccOps = 0; cbookedAccOps = 0;
c_redo_log_complete_frags = RNIL;
}//Dblqh::initData() }//Dblqh::initData()
void Dblqh::initRecords() void Dblqh::initRecords()
......
...@@ -13642,14 +13642,22 @@ void Dblqh::execSTART_EXEC_SR(Signal* signal) ...@@ -13642,14 +13642,22 @@ void Dblqh::execSTART_EXEC_SR(Signal* signal)
* ALSO SEND START_FRAGCONF TO DIH AND SET THE STATE TO ACTIVE ON THE * ALSO SEND START_FRAGCONF TO DIH AND SET THE STATE TO ACTIVE ON THE
* FRAGMENT. * FRAGMENT.
* ------------------------------------------------------------------- */ * ------------------------------------------------------------------- */
Uint32 next = fragptr.p->nextFrag;
if (prevFragptr.i != RNIL) { if (prevFragptr.i != RNIL) {
jam(); jam();
ptrCheckGuard(prevFragptr, cfragrecFileSize, fragrecord); ptrCheckGuard(prevFragptr, cfragrecFileSize, fragrecord);
prevFragptr.p->nextFrag = fragptr.p->nextFrag; prevFragptr.p->nextFrag = next;
} else { } else {
jam(); jam();
cfirstCompletedFragSr = fragptr.p->nextFrag; cfirstCompletedFragSr = next;
}//if }//if
/**
* Put fragment on list which has completed REDO log
*/
fragptr.p->nextFrag = c_redo_log_complete_frags;
c_redo_log_complete_frags = fragptr.i;
fragptr.p->fragStatus = Fragrecord::FSACTIVE; fragptr.p->fragStatus = Fragrecord::FSACTIVE;
fragptr.p->logFlag = Fragrecord::STATE_TRUE; fragptr.p->logFlag = Fragrecord::STATE_TRUE;
signal->theData[0] = fragptr.p->srUserptr; signal->theData[0] = fragptr.p->srUserptr;
...@@ -13661,7 +13669,7 @@ void Dblqh::execSTART_EXEC_SR(Signal* signal) ...@@ -13661,7 +13669,7 @@ void Dblqh::execSTART_EXEC_SR(Signal* signal)
* THIS IS PERFORMED BY KEEPING PREV_FRAGPTR AS PREV_FRAGPTR BUT MOVING * THIS IS PERFORMED BY KEEPING PREV_FRAGPTR AS PREV_FRAGPTR BUT MOVING
* FRAGPTR TO THE NEXT FRAGMENT IN THE LIST. * FRAGPTR TO THE NEXT FRAGMENT IN THE LIST.
* ------------------------------------------------------------------- */ * ------------------------------------------------------------------- */
fragptr.i = fragptr.p->nextFrag; fragptr.i = next;
}//if }//if
signal->theData[0] = fragptr.i; signal->theData[0] = fragptr.i;
signal->theData[1] = prevFragptr.i; signal->theData[1] = prevFragptr.i;
...@@ -15267,6 +15275,20 @@ void Dblqh::srFourthComp(Signal* signal) ...@@ -15267,6 +15275,20 @@ void Dblqh::srFourthComp(Signal* signal)
conf->startingNodeId = getOwnNodeId(); conf->startingNodeId = getOwnNodeId();
sendSignal(cmasterDihBlockref, GSN_START_RECCONF, signal, sendSignal(cmasterDihBlockref, GSN_START_RECCONF, signal,
StartRecConf::SignalLength, JBB); StartRecConf::SignalLength, JBB);
if(cstartType == NodeState::ST_SYSTEM_RESTART){
fragptr.i = c_redo_log_complete_frags;
ndbout_c("All fragment complete - ");
while(fragptr.i != RNIL){
ptrCheckGuard(fragptr, cfragrecFileSize, fragrecord);
signal->theData[0] = fragptr.p->tabRef;
signal->theData[1] = fragptr.p->fragId;
sendSignal(DBACC_REF, GSN_EXPANDCHECK2, signal, 2, JBB);
ndbout_c("table: %d fragment: %d",
fragptr.p->tabRef, fragptr.p->fragId);
fragptr.i = fragptr.p->nextFrag;
}
}
} else { } else {
ndbrequire(false); ndbrequire(false);
}//if }//if
......
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