Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
1cfd066e
Commit
1cfd066e
authored
Feb 19, 2007
by
jonas@perch.ndb.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge perch.ndb.mysql.com:/home/jonas/src/50-work
into perch.ndb.mysql.com:/home/jonas/src/51-work
parents
4d80c3f6
4c3fef3a
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
68 additions
and
2 deletions
+68
-2
storage/ndb/src/kernel/blocks/dbdih/Dbdih.hpp
storage/ndb/src/kernel/blocks/dbdih/Dbdih.hpp
+1
-0
storage/ndb/src/kernel/blocks/dbdih/DbdihInit.cpp
storage/ndb/src/kernel/blocks/dbdih/DbdihInit.cpp
+1
-0
storage/ndb/src/kernel/blocks/dbdih/DbdihMain.cpp
storage/ndb/src/kernel/blocks/dbdih/DbdihMain.cpp
+22
-0
storage/ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
storage/ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
+1
-2
storage/ndb/test/ndbapi/testNodeRestart.cpp
storage/ndb/test/ndbapi/testNodeRestart.cpp
+43
-0
No files found.
storage/ndb/src/kernel/blocks/dbdih/Dbdih.hpp
View file @
1cfd066e
...
@@ -1381,6 +1381,7 @@ private:
...
@@ -1381,6 +1381,7 @@ private:
Uint32
csystemnodes
;
Uint32
csystemnodes
;
Uint32
currentgcp
;
Uint32
currentgcp
;
Uint32
c_newest_restorable_gci
;
Uint32
c_newest_restorable_gci
;
Uint32
c_set_initial_start_flag
;
enum
GcpMasterTakeOverState
{
enum
GcpMasterTakeOverState
{
GMTOS_IDLE
=
0
,
GMTOS_IDLE
=
0
,
...
...
storage/ndb/src/kernel/blocks/dbdih/DbdihInit.cpp
View file @
1cfd066e
...
@@ -61,6 +61,7 @@ void Dbdih::initData()
...
@@ -61,6 +61,7 @@ void Dbdih::initData()
c_blockCommit
=
false
;
c_blockCommit
=
false
;
c_blockCommitNo
=
1
;
c_blockCommitNo
=
1
;
cntrlblockref
=
RNIL
;
cntrlblockref
=
RNIL
;
c_set_initial_start_flag
=
FALSE
;
}
//Dbdih::initData()
}
//Dbdih::initData()
void
Dbdih
::
initRecords
()
void
Dbdih
::
initRecords
()
...
...
storage/ndb/src/kernel/blocks/dbdih/DbdihMain.cpp
View file @
1cfd066e
...
@@ -677,6 +677,12 @@ done:
...
@@ -677,6 +677,12 @@ done:
Uint32
tmp
=
SYSFILE
->
m_restart_seq
;
Uint32
tmp
=
SYSFILE
->
m_restart_seq
;
memcpy
(
sysfileData
,
cdata
,
sizeof
(
sysfileData
));
memcpy
(
sysfileData
,
cdata
,
sizeof
(
sysfileData
));
SYSFILE
->
m_restart_seq
=
tmp
;
SYSFILE
->
m_restart_seq
=
tmp
;
if
(
c_set_initial_start_flag
)
{
jam
();
Sysfile
::
setInitialStartOngoing
(
SYSFILE
->
systemRestartBits
);
}
}
}
c_copyGCISlave
.
m_copyReason
=
reason
;
c_copyGCISlave
.
m_copyReason
=
reason
;
...
@@ -1337,6 +1343,11 @@ void Dbdih::execNDB_STTOR(Signal* signal)
...
@@ -1337,6 +1343,11 @@ void Dbdih::execNDB_STTOR(Signal* signal)
// The permission is given by the master node in the alive set.
// The permission is given by the master node in the alive set.
/*-----------------------------------------------------------------------*/
/*-----------------------------------------------------------------------*/
createMutexes
(
signal
,
0
);
createMutexes
(
signal
,
0
);
if
(
cstarttype
==
NodeState
::
ST_INITIAL_NODE_RESTART
)
{
jam
();
c_set_initial_start_flag
=
TRUE
;
// In sysfile...
}
break
;
break
;
case
ZNDB_SPH3
:
case
ZNDB_SPH3
:
...
@@ -10804,6 +10815,17 @@ Dbdih::sendLCP_COMPLETE_REP(Signal* signal){
...
@@ -10804,6 +10815,17 @@ Dbdih::sendLCP_COMPLETE_REP(Signal* signal){
sendSignal
(
c_lcpState
.
m_masterLcpDihRef
,
GSN_LCP_COMPLETE_REP
,
signal
,
sendSignal
(
c_lcpState
.
m_masterLcpDihRef
,
GSN_LCP_COMPLETE_REP
,
signal
,
LcpCompleteRep
::
SignalLength
,
JBB
);
LcpCompleteRep
::
SignalLength
,
JBB
);
/**
* Say that an initial node restart does not need to be redone
* once node has been part of first LCP
*/
if
(
c_set_initial_start_flag
&&
c_lcpState
.
m_participatingLQH
.
get
(
getOwnNodeId
()))
{
jam
();
c_set_initial_start_flag
=
FALSE
;
}
}
}
/*-------------------------------------------------------------------------- */
/*-------------------------------------------------------------------------- */
...
...
storage/ndb/src/kernel/blocks/dblqh/DblqhMain.cpp
View file @
1cfd066e
...
@@ -11925,7 +11925,7 @@ void Dblqh::execGCP_SAVEREQ(Signal* signal)
...
@@ -11925,7 +11925,7 @@ void Dblqh::execGCP_SAVEREQ(Signal* signal)
return
;
return
;
}
}
if
(
getNodeState
().
getNodeRestartInProgress
())
if
(
getNodeState
().
getNodeRestartInProgress
()
&&
cstartRecReq
==
ZFALSE
)
{
{
GCPSaveRef
*
const
saveRef
=
(
GCPSaveRef
*
)
&
signal
->
theData
[
0
];
GCPSaveRef
*
const
saveRef
=
(
GCPSaveRef
*
)
&
signal
->
theData
[
0
];
saveRef
->
dihPtr
=
dihPtr
;
saveRef
->
dihPtr
=
dihPtr
;
...
@@ -11972,7 +11972,6 @@ void Dblqh::execGCP_SAVEREQ(Signal* signal)
...
@@ -11972,7 +11972,6 @@ void Dblqh::execGCP_SAVEREQ(Signal* signal)
}
//if
}
//if
ndbrequire
(
ccurrentGcprec
==
RNIL
);
ndbrequire
(
ccurrentGcprec
==
RNIL
);
ccurrentGcprec
=
0
;
ccurrentGcprec
=
0
;
gcpPtr
.
i
=
ccurrentGcprec
;
gcpPtr
.
i
=
ccurrentGcprec
;
ptrCheckGuard
(
gcpPtr
,
cgcprecFileSize
,
gcpRecord
);
ptrCheckGuard
(
gcpPtr
,
cgcprecFileSize
,
gcpRecord
);
...
...
storage/ndb/test/ndbapi/testNodeRestart.cpp
View file @
1cfd066e
...
@@ -1313,6 +1313,46 @@ retry:
...
@@ -1313,6 +1313,46 @@ retry:
return
NDBT_OK
;
return
NDBT_OK
;
}
}
int
runBug26481
(
NDBT_Context
*
ctx
,
NDBT_Step
*
step
)
{
int
result
=
NDBT_OK
;
int
loops
=
ctx
->
getNumLoops
();
int
records
=
ctx
->
getNumRecords
();
NdbRestarter
res
;
int
node
=
res
.
getRandomNotMasterNodeId
(
rand
());
ndbout_c
(
"node: %d"
,
node
);
if
(
res
.
restartOneDbNode
(
node
,
true
,
true
,
true
))
return
NDBT_FAILED
;
if
(
res
.
waitNodesNoStart
(
&
node
,
1
))
return
NDBT_FAILED
;
int
val2
[]
=
{
DumpStateOrd
::
CmvmiSetRestartOnErrorInsert
,
1
};
if
(
res
.
dumpStateOneNode
(
node
,
val2
,
2
))
return
NDBT_FAILED
;
if
(
res
.
insertErrorInNode
(
node
,
7018
))
return
NDBT_FAILED
;
if
(
res
.
startNodes
(
&
node
,
1
))
return
NDBT_FAILED
;
res
.
waitNodesStartPhase
(
&
node
,
1
,
3
);
if
(
res
.
waitNodesNoStart
(
&
node
,
1
))
return
NDBT_FAILED
;
res
.
startNodes
(
&
node
,
1
);
if
(
res
.
waitClusterStarted
())
return
NDBT_FAILED
;
return
NDBT_OK
;
}
NDBT_TESTSUITE
(
testNodeRestart
);
NDBT_TESTSUITE
(
testNodeRestart
);
TESTCASE
(
"NoLoad"
,
TESTCASE
(
"NoLoad"
,
"Test that one node at a time can be stopped and then restarted "
\
"Test that one node at a time can be stopped and then restarted "
\
...
@@ -1654,6 +1694,9 @@ TESTCASE("Bug25984", ""){
...
@@ -1654,6 +1694,9 @@ TESTCASE("Bug25984", ""){
TESTCASE
(
"Bug26457"
,
""
){
TESTCASE
(
"Bug26457"
,
""
){
INITIALIZER
(
runBug26457
);
INITIALIZER
(
runBug26457
);
}
}
TESTCASE
(
"Bug26481"
,
""
){
INITIALIZER
(
runBug26481
);
}
NDBT_TESTSUITE_END
(
testNodeRestart
);
NDBT_TESTSUITE_END
(
testNodeRestart
);
int
main
(
int
argc
,
const
char
**
argv
){
int
main
(
int
argc
,
const
char
**
argv
){
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment