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
473e314a
Commit
473e314a
authored
Jan 18, 2006
by
stewart@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/home/stewart/Documents/MySQL/5.0/main
into mysql.com:/home/stewart/Documents/MySQL/5.0/bug12124
parents
e55af527
5cf0ede0
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
238 additions
and
59 deletions
+238
-59
ndb/include/mgmapi/mgmapi.h
ndb/include/mgmapi/mgmapi.h
+16
-0
ndb/include/mgmcommon/ConfigRetriever.hpp
ndb/include/mgmcommon/ConfigRetriever.hpp
+3
-0
ndb/src/common/mgmcommon/ConfigRetriever.cpp
ndb/src/common/mgmcommon/ConfigRetriever.cpp
+3
-0
ndb/src/common/util/SocketServer.cpp
ndb/src/common/util/SocketServer.cpp
+2
-0
ndb/src/kernel/main.cpp
ndb/src/kernel/main.cpp
+4
-1
ndb/src/kernel/vm/Configuration.cpp
ndb/src/kernel/vm/Configuration.cpp
+2
-1
ndb/src/kernel/vm/Configuration.hpp
ndb/src/kernel/vm/Configuration.hpp
+1
-1
ndb/src/mgmapi/mgmapi.cpp
ndb/src/mgmapi/mgmapi.cpp
+19
-0
ndb/src/mgmclient/CommandInterpreter.cpp
ndb/src/mgmclient/CommandInterpreter.cpp
+9
-14
ndb/src/mgmsrv/MgmtSrvr.cpp
ndb/src/mgmsrv/MgmtSrvr.cpp
+132
-7
ndb/src/mgmsrv/MgmtSrvr.hpp
ndb/src/mgmsrv/MgmtSrvr.hpp
+10
-1
ndb/src/mgmsrv/Services.cpp
ndb/src/mgmsrv/Services.cpp
+14
-1
ndb/src/mgmsrv/Services.hpp
ndb/src/mgmsrv/Services.hpp
+1
-0
ndb/src/mgmsrv/main.cpp
ndb/src/mgmsrv/main.cpp
+22
-33
No files found.
ndb/include/mgmapi/mgmapi.h
View file @
473e314a
...
@@ -993,6 +993,22 @@ extern "C" {
...
@@ -993,6 +993,22 @@ extern "C" {
int
ndb_mgm_alloc_nodeid
(
NdbMgmHandle
handle
,
int
ndb_mgm_alloc_nodeid
(
NdbMgmHandle
handle
,
unsigned
version
,
int
nodetype
);
unsigned
version
,
int
nodetype
);
/**
* End Session
*
* This function tells the mgm server to free all resources associated with
* this connection. It will also close it.
*
* This differs from just disconnecting as we now synchronously clean up,
* so that a quickly restarting server that needs the same node id can
* get it when it restarts.
*
* @param handle NDB management handle
* @return 0 on success
*
* @note you still have to destroy the NdbMgmHandle.
*/
int
ndb_mgm_end_session
(
NdbMgmHandle
handle
);
/**
/**
* Get the node id of the mgm server we're connected to
* Get the node id of the mgm server we're connected to
...
...
ndb/include/mgmcommon/ConfigRetriever.hpp
View file @
473e314a
...
@@ -78,6 +78,7 @@ public:
...
@@ -78,6 +78,7 @@ public:
const
char
*
get_connectstring
(
char
*
buf
,
int
buf_sz
)
const
;
const
char
*
get_connectstring
(
char
*
buf
,
int
buf_sz
)
const
;
NdbMgmHandle
get_mgmHandle
()
{
return
m_handle
;
};
NdbMgmHandle
get_mgmHandle
()
{
return
m_handle
;
};
NdbMgmHandle
*
get_mgmHandlePtr
()
{
return
&
m_handle
;
};
NdbMgmHandle
*
get_mgmHandlePtr
()
{
return
&
m_handle
;
};
void
end_session
(
bool
end
)
{
m_end_session
=
end
;
};
Uint32
get_configuration_nodeid
()
const
;
Uint32
get_configuration_nodeid
()
const
;
private:
private:
...
@@ -92,6 +93,8 @@ private:
...
@@ -92,6 +93,8 @@ private:
void
setError
(
ErrorType
,
const
char
*
errorMsg
);
void
setError
(
ErrorType
,
const
char
*
errorMsg
);
Uint32
_ownNodeId
;
Uint32
_ownNodeId
;
bool
m_end_session
;
/*
/*
Uint32 m_mgmd_port;
Uint32 m_mgmd_port;
const char *m_mgmd_host;
const char *m_mgmd_host;
...
...
ndb/src/common/mgmcommon/ConfigRetriever.cpp
View file @
473e314a
...
@@ -52,6 +52,7 @@ ConfigRetriever::ConfigRetriever(const char * _connect_string,
...
@@ -52,6 +52,7 @@ ConfigRetriever::ConfigRetriever(const char * _connect_string,
m_version
=
version
;
m_version
=
version
;
m_node_type
=
node_type
;
m_node_type
=
node_type
;
_ownNodeId
=
0
;
_ownNodeId
=
0
;
m_end_session
=
true
;
m_handle
=
ndb_mgm_create_handle
();
m_handle
=
ndb_mgm_create_handle
();
...
@@ -73,6 +74,8 @@ ConfigRetriever::~ConfigRetriever()
...
@@ -73,6 +74,8 @@ ConfigRetriever::~ConfigRetriever()
{
{
DBUG_ENTER
(
"ConfigRetriever::~ConfigRetriever"
);
DBUG_ENTER
(
"ConfigRetriever::~ConfigRetriever"
);
if
(
m_handle
)
{
if
(
m_handle
)
{
if
(
m_end_session
)
ndb_mgm_end_session
(
m_handle
);
ndb_mgm_disconnect
(
m_handle
);
ndb_mgm_disconnect
(
m_handle
);
ndb_mgm_destroy_handle
(
&
m_handle
);
ndb_mgm_destroy_handle
(
&
m_handle
);
}
}
...
...
ndb/src/common/util/SocketServer.cpp
View file @
473e314a
...
@@ -42,6 +42,8 @@ SocketServer::~SocketServer() {
...
@@ -42,6 +42,8 @@ SocketServer::~SocketServer() {
delete
m_sessions
[
i
].
m_session
;
delete
m_sessions
[
i
].
m_session
;
}
}
for
(
i
=
0
;
i
<
m_services
.
size
();
i
++
){
for
(
i
=
0
;
i
<
m_services
.
size
();
i
++
){
if
(
m_services
[
i
].
m_socket
)
NDB_CLOSE_SOCKET
(
m_services
[
i
].
m_socket
);
delete
m_services
[
i
].
m_service
;
delete
m_services
[
i
].
m_service
;
}
}
}
}
...
...
ndb/src/kernel/main.cpp
View file @
473e314a
...
@@ -307,8 +307,11 @@ int main(int argc, char** argv)
...
@@ -307,8 +307,11 @@ int main(int argc, char** argv)
/**
/**
* We no longer need the mgm connection in this process
* We no longer need the mgm connection in this process
* (as we are the angel, not ndb)
* (as we are the angel, not ndb)
*
* We don't want to purge any allocated resources (nodeid), so
* we set that option to false
*/
*/
theConfig
->
closeConfiguration
();
theConfig
->
closeConfiguration
(
false
);
int
status
=
0
,
error_exit
=
0
,
signum
=
0
;
int
status
=
0
,
error_exit
=
0
,
signum
=
0
;
while
(
waitpid
(
child
,
&
status
,
0
)
!=
child
);
while
(
waitpid
(
child
,
&
status
,
0
)
!=
child
);
...
...
ndb/src/kernel/vm/Configuration.cpp
View file @
473e314a
...
@@ -172,7 +172,8 @@ Configuration::~Configuration(){
...
@@ -172,7 +172,8 @@ Configuration::~Configuration(){
}
}
void
void
Configuration
::
closeConfiguration
(){
Configuration
::
closeConfiguration
(
bool
end_session
){
m_config_retriever
->
end_session
(
end_session
);
if
(
m_config_retriever
)
{
if
(
m_config_retriever
)
{
delete
m_config_retriever
;
delete
m_config_retriever
;
}
}
...
...
ndb/src/kernel/vm/Configuration.hpp
View file @
473e314a
...
@@ -35,7 +35,7 @@ public:
...
@@ -35,7 +35,7 @@ public:
void
fetch_configuration
();
void
fetch_configuration
();
void
setupConfiguration
();
void
setupConfiguration
();
void
closeConfiguration
();
void
closeConfiguration
(
bool
end_session
=
true
);
bool
lockPagesInMainMemory
()
const
;
bool
lockPagesInMainMemory
()
const
;
...
...
ndb/src/mgmapi/mgmapi.cpp
View file @
473e314a
...
@@ -2321,4 +2321,23 @@ int ndb_mgm_report_event(NdbMgmHandle handle, Uint32 *data, Uint32 length)
...
@@ -2321,4 +2321,23 @@ int ndb_mgm_report_event(NdbMgmHandle handle, Uint32 *data, Uint32 length)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
extern
"C"
int
ndb_mgm_end_session
(
NdbMgmHandle
handle
)
{
DBUG_ENTER
(
"ndb_mgm_end_session"
);
CHECK_HANDLE
(
handle
,
0
);
CHECK_CONNECTED
(
handle
,
0
);
SocketOutputStream
s_output
(
handle
->
socket
);
s_output
.
println
(
"end session"
);
s_output
.
println
(
""
);
SocketInputStream
in
(
handle
->
socket
,
handle
->
read_timeout
);
char
buf
[
32
];
in
.
gets
(
buf
,
sizeof
(
buf
));
DBUG_RETURN
(
0
);
}
template
class
Vector
<
const
ParserRow
<
ParserDummy
>
*>
;
template
class
Vector
<
const
ParserRow
<
ParserDummy
>
*>
;
ndb/src/mgmclient/CommandInterpreter.cpp
View file @
473e314a
...
@@ -1000,27 +1000,22 @@ CommandInterpreter::executeShutdown(char* parameters)
...
@@ -1000,27 +1000,22 @@ CommandInterpreter::executeShutdown(char* parameters)
int
result
=
0
;
int
result
=
0
;
result
=
ndb_mgm_stop
(
m_mgmsrv
,
0
,
0
);
result
=
ndb_mgm_stop
(
m_mgmsrv
,
0
,
0
);
if
(
result
<
0
)
{
if
(
result
<
0
)
{
ndbout
<<
"Shutdown of
f NDB Cluster storage
node(s) failed."
<<
endl
;
ndbout
<<
"Shutdown of
NDB Cluster
node(s) failed."
<<
endl
;
printError
();
printError
();
return
result
;
return
result
;
}
}
ndbout
<<
result
<<
" NDB Cluster
storage
node(s) have shutdown."
<<
endl
;
ndbout
<<
result
<<
" NDB Cluster node(s) have shutdown."
<<
endl
;
int
mgm_id
=
0
;
int
mgm_id
=
0
;
for
(
int
i
=
0
;
i
<
state
->
no_of_nodes
;
i
++
)
{
mgm_id
=
ndb_mgm_get_mgmd_nodeid
(
m_mgmsrv
);
if
(
state
->
node_states
[
i
].
node_type
==
NDB_MGM_NODE_TYPE_MGM
&&
state
->
node_states
[
i
].
version
!=
0
){
if
(
mgm_id
==
0
)
if
(
mgm_id
==
0
)
mgm_id
=
state
->
node_states
[
i
].
node_id
;
{
else
{
ndbout
<<
"Unable to locate management server, "
ndbout
<<
"Unable to locate management server, "
<<
"shutdown manually with <id> STOP"
<<
"shutdown manually with <id> STOP"
<<
endl
;
<<
endl
;
return
1
;
return
1
;
}
}
}
}
result
=
ndb_mgm_stop
(
m_mgmsrv
,
1
,
&
mgm_id
);
result
=
ndb_mgm_stop
(
m_mgmsrv
,
1
,
&
mgm_id
);
if
(
result
<=
0
)
{
if
(
result
<=
0
)
{
...
...
ndb/src/mgmsrv/MgmtSrvr.cpp
View file @
473e314a
...
@@ -60,6 +60,9 @@
...
@@ -60,6 +60,9 @@
#include <SignalSender.hpp>
#include <SignalSender.hpp>
extern
bool
g_StopServer
;
extern
bool
g_RestartServer
;
//#define MGM_SRV_DEBUG
//#define MGM_SRV_DEBUG
#ifdef MGM_SRV_DEBUG
#ifdef MGM_SRV_DEBUG
#define DEBUG(x) do ndbout << x << endl; while(0)
#define DEBUG(x) do ndbout << x << endl; while(0)
...
@@ -373,7 +376,8 @@ MgmtSrvr::MgmtSrvr(SocketServer *socket_server,
...
@@ -373,7 +376,8 @@ MgmtSrvr::MgmtSrvr(SocketServer *socket_server,
_ownReference
(
0
),
_ownReference
(
0
),
theSignalIdleList
(
NULL
),
theSignalIdleList
(
NULL
),
theWaitState
(
WAIT_SUBSCRIBE_CONF
),
theWaitState
(
WAIT_SUBSCRIBE_CONF
),
m_event_listner
(
this
)
m_event_listner
(
this
),
m_local_mgm_handle
(
0
)
{
{
DBUG_ENTER
(
"MgmtSrvr::MgmtSrvr"
);
DBUG_ENTER
(
"MgmtSrvr::MgmtSrvr"
);
...
@@ -541,6 +545,8 @@ MgmtSrvr::check_start()
...
@@ -541,6 +545,8 @@ MgmtSrvr::check_start()
bool
bool
MgmtSrvr
::
start
(
BaseString
&
error_string
)
MgmtSrvr
::
start
(
BaseString
&
error_string
)
{
{
int
mgm_connect_result
;
DBUG_ENTER
(
"MgmtSrvr::start"
);
DBUG_ENTER
(
"MgmtSrvr::start"
);
if
(
_props
==
NULL
)
{
if
(
_props
==
NULL
)
{
if
(
!
check_start
())
{
if
(
!
check_start
())
{
...
@@ -578,6 +584,13 @@ MgmtSrvr::start(BaseString &error_string)
...
@@ -578,6 +584,13 @@ MgmtSrvr::start(BaseString &error_string)
DBUG_RETURN
(
false
);
DBUG_RETURN
(
false
);
}
}
if
((
mgm_connect_result
=
connect_to_self
())
<
0
)
{
ndbout_c
(
"Unable to connect to our own ndb_mgmd (Error %d)"
,
mgm_connect_result
);
ndbout_c
(
"This is probably a bug."
);
}
TransporterRegistry
*
reg
=
theFacade
->
get_registry
();
TransporterRegistry
*
reg
=
theFacade
->
get_registry
();
for
(
unsigned
int
i
=
0
;
i
<
reg
->
m_transporter_interface
.
size
();
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
reg
->
m_transporter_interface
.
size
();
i
++
)
{
BaseString
msg
;
BaseString
msg
;
...
@@ -835,9 +848,81 @@ MgmtSrvr::sendVersionReq(int v_nodeId, Uint32 &version, const char **address)
...
@@ -835,9 +848,81 @@ MgmtSrvr::sendVersionReq(int v_nodeId, Uint32 &version, const char **address)
return
0
;
return
0
;
}
}
int
MgmtSrvr
::
sendStopMgmd
(
NodeId
nodeId
,
bool
abort
,
bool
stop
,
bool
restart
,
bool
nostart
,
bool
initialStart
)
{
const
char
*
hostname
;
Uint32
port
;
BaseString
connect_string
;
{
Guard
g
(
m_configMutex
);
{
ndb_mgm_configuration_iterator
iter
(
*
_config
->
m_configValues
,
CFG_SECTION_NODE
);
if
(
iter
.
first
())
return
SEND_OR_RECEIVE_FAILED
;
if
(
iter
.
find
(
CFG_NODE_ID
,
nodeId
))
return
SEND_OR_RECEIVE_FAILED
;
if
(
iter
.
get
(
CFG_NODE_HOST
,
&
hostname
))
return
SEND_OR_RECEIVE_FAILED
;
}
{
ndb_mgm_configuration_iterator
iter
(
*
_config
->
m_configValues
,
CFG_SECTION_NODE
);
if
(
iter
.
first
())
return
SEND_OR_RECEIVE_FAILED
;
if
(
iter
.
find
(
CFG_NODE_ID
,
nodeId
))
return
SEND_OR_RECEIVE_FAILED
;
if
(
iter
.
get
(
CFG_MGM_PORT
,
&
port
))
return
SEND_OR_RECEIVE_FAILED
;
}
if
(
strlen
(
hostname
)
==
0
)
return
SEND_OR_RECEIVE_FAILED
;
}
connect_string
.
assfmt
(
"%s:%u"
,
hostname
,
port
);
DBUG_PRINT
(
"info"
,(
"connect string: %s"
,
connect_string
.
c_str
()));
NdbMgmHandle
h
=
ndb_mgm_create_handle
();
if
(
h
&&
connect_string
.
length
()
>
0
)
{
ndb_mgm_set_connectstring
(
h
,
connect_string
.
c_str
());
if
(
ndb_mgm_connect
(
h
,
1
,
0
,
0
))
{
DBUG_PRINT
(
"info"
,(
"failed ndb_mgm_connect"
));
return
SEND_OR_RECEIVE_FAILED
;
}
if
(
!
restart
)
{
if
(
ndb_mgm_stop
(
h
,
1
,
(
const
int
*
)
&
nodeId
)
<
0
)
{
return
SEND_OR_RECEIVE_FAILED
;
}
}
else
{
int
nodes
[
1
];
nodes
[
0
]
=
(
int
)
nodeId
;
if
(
ndb_mgm_restart2
(
h
,
1
,
nodes
,
initialStart
,
nostart
,
abort
)
<
0
)
{
return
SEND_OR_RECEIVE_FAILED
;
}
}
}
ndb_mgm_destroy_handle
(
&
h
);
return
0
;
}
/*
/*
* Common method for handeling all STOP_REQ signalling that
* Common method for handeling all STOP_REQ signalling that
* is used by Stopping, Restarting and Single user commands
* is used by Stopping, Restarting and Single user commands
*
* In the event that we need to stop a mgmd, we create a mgm
* client connection to that mgmd and stop it that way.
* This allows us to stop mgm servers when there isn't any real
* distributed communication up.
*/
*/
int
MgmtSrvr
::
sendSTOP_REQ
(
NodeId
nodeId
,
int
MgmtSrvr
::
sendSTOP_REQ
(
NodeId
nodeId
,
...
@@ -849,6 +934,8 @@ int MgmtSrvr::sendSTOP_REQ(NodeId nodeId,
...
@@ -849,6 +934,8 @@ int MgmtSrvr::sendSTOP_REQ(NodeId nodeId,
bool
nostart
,
bool
nostart
,
bool
initialStart
)
bool
initialStart
)
{
{
int
error
=
0
;
stoppedNodes
.
clear
();
stoppedNodes
.
clear
();
SignalSender
ss
(
theFacade
);
SignalSender
ss
(
theFacade
);
...
@@ -887,18 +974,34 @@ int MgmtSrvr::sendSTOP_REQ(NodeId nodeId,
...
@@ -887,18 +974,34 @@ int MgmtSrvr::sendSTOP_REQ(NodeId nodeId,
NodeBitmask
nodes
;
NodeBitmask
nodes
;
if
(
nodeId
)
if
(
nodeId
)
{
{
if
(
nodeId
==
getOwnNodeId
())
{
{
int
r
;
if
(
restart
)
if
((
r
=
okToSendTo
(
nodeId
,
true
))
!=
0
)
g_RestartServer
=
true
;
return
r
;
g_StopServer
=
true
;
return
0
;
}
}
if
(
getNodeType
(
nodeId
)
==
NDB_MGM_NODE_TYPE_NDB
)
{
{
int
r
;
if
((
r
=
okToSendTo
(
nodeId
,
true
))
!=
0
)
return
r
;
if
(
ss
.
sendSignal
(
nodeId
,
&
ssig
)
!=
SEND_OK
)
if
(
ss
.
sendSignal
(
nodeId
,
&
ssig
)
!=
SEND_OK
)
return
SEND_OR_RECEIVE_FAILED
;
return
SEND_OR_RECEIVE_FAILED
;
}
}
else
if
(
getNodeType
(
nodeId
)
==
NDB_MGM_NODE_TYPE_MGM
)
{
error
=
sendStopMgmd
(
nodeId
,
abort
,
stop
,
restart
,
nostart
,
initialStart
);
if
(
error
==
0
)
stoppedNodes
.
set
(
nodeId
);
return
error
;
}
else
return
WRONG_PROCESS_TYPE
;
nodes
.
set
(
nodeId
);
nodes
.
set
(
nodeId
);
}
}
else
else
{
while
(
getNextNodeId
(
&
nodeId
,
NDB_MGM_NODE_TYPE_NDB
))
while
(
getNextNodeId
(
&
nodeId
,
NDB_MGM_NODE_TYPE_NDB
))
{
{
if
(
okToSendTo
(
nodeId
,
true
)
==
0
)
if
(
okToSendTo
(
nodeId
,
true
)
==
0
)
...
@@ -908,9 +1011,17 @@ int MgmtSrvr::sendSTOP_REQ(NodeId nodeId,
...
@@ -908,9 +1011,17 @@ int MgmtSrvr::sendSTOP_REQ(NodeId nodeId,
nodes
.
set
(
nodeId
);
nodes
.
set
(
nodeId
);
}
}
}
}
nodeId
=
0
;
while
(
getNextNodeId
(
&
nodeId
,
NDB_MGM_NODE_TYPE_MGM
))
{
if
(
nodeId
==
getOwnNodeId
())
continue
;
if
(
sendStopMgmd
(
nodeId
,
abort
,
stop
,
restart
,
nostart
,
initialStart
)
==
0
)
stoppedNodes
.
set
(
nodeId
);
}
}
// now wait for the replies
// now wait for the replies
int
error
=
0
;
while
(
!
nodes
.
isclear
())
while
(
!
nodes
.
isclear
())
{
{
SimpleSignal
*
signal
=
ss
.
waitFor
();
SimpleSignal
*
signal
=
ss
.
waitFor
();
...
@@ -2456,9 +2567,23 @@ void MgmtSrvr::transporter_connect(NDB_SOCKET_TYPE sockfd)
...
@@ -2456,9 +2567,23 @@ void MgmtSrvr::transporter_connect(NDB_SOCKET_TYPE sockfd)
}
}
}
}
int
MgmtSrvr
::
set_connect_string
(
const
char
*
str
)
int
MgmtSrvr
::
connect_to_self
(
void
)
{
{
return
ndb_mgm_set_connectstring
(
m_config_retriever
->
get_mgmHandle
(),
str
);
int
r
=
0
;
m_local_mgm_handle
=
ndb_mgm_create_handle
();
snprintf
(
m_local_mgm_connect_string
,
sizeof
(
m_local_mgm_connect_string
),
"localhost:%u"
,
getPort
());
ndb_mgm_set_connectstring
(
m_local_mgm_handle
,
m_local_mgm_connect_string
);
if
((
r
=
ndb_mgm_connect
(
m_local_mgm_handle
,
0
,
0
,
0
))
<
0
)
{
ndb_mgm_destroy_handle
(
&
m_local_mgm_handle
);
return
r
;
}
// TransporterRegistry now owns this NdbMgmHandle and will destroy it.
theFacade
->
get_registry
()
->
set_mgm_handle
(
m_local_mgm_handle
);
return
0
;
}
}
...
...
ndb/src/mgmsrv/MgmtSrvr.hpp
View file @
473e314a
...
@@ -471,7 +471,7 @@ public:
...
@@ -471,7 +471,7 @@ public:
int
getConnectionDbParameter
(
int
node1
,
int
node2
,
int
param
,
int
getConnectionDbParameter
(
int
node1
,
int
node2
,
int
param
,
int
*
value
,
BaseString
&
msg
);
int
*
value
,
BaseString
&
msg
);
int
set_connect_string
(
const
char
*
str
);
int
connect_to_self
(
void
);
void
transporter_connect
(
NDB_SOCKET_TYPE
sockfd
);
void
transporter_connect
(
NDB_SOCKET_TYPE
sockfd
);
...
@@ -487,6 +487,13 @@ private:
...
@@ -487,6 +487,13 @@ private:
int
send
(
SignalSender
&
ss
,
SimpleSignal
&
ssig
,
Uint32
node
,
Uint32
node_type
);
int
send
(
SignalSender
&
ss
,
SimpleSignal
&
ssig
,
Uint32
node
,
Uint32
node_type
);
int
sendStopMgmd
(
NodeId
nodeId
,
bool
abort
,
bool
stop
,
bool
restart
,
bool
nostart
,
bool
initialStart
);
int
sendSTOP_REQ
(
NodeId
nodeId
,
int
sendSTOP_REQ
(
NodeId
nodeId
,
NodeBitmask
&
stoppedNodes
,
NodeBitmask
&
stoppedNodes
,
Uint32
singleUserNodeId
,
Uint32
singleUserNodeId
,
...
@@ -629,6 +636,8 @@ private:
...
@@ -629,6 +636,8 @@ private:
// signal arrives.
// signal arrives.
// We wait in receiveOptimisedResponse and signal in handleReceivedSignal.
// We wait in receiveOptimisedResponse and signal in handleReceivedSignal.
NdbMgmHandle
m_local_mgm_handle
;
char
m_local_mgm_connect_string
[
20
];
class
TransporterFacade
*
theFacade
;
class
TransporterFacade
*
theFacade
;
int
sendVersionReq
(
int
processId
,
Uint32
&
version
,
const
char
**
address
);
int
sendVersionReq
(
int
processId
,
Uint32
&
version
,
const
char
**
address
);
...
...
ndb/src/mgmsrv/Services.cpp
View file @
473e314a
...
@@ -203,6 +203,8 @@ ParserRow<MgmApiSession> commands[] = {
...
@@ -203,6 +203,8 @@ ParserRow<MgmApiSession> commands[] = {
MGM_CMD
(
"bye"
,
&
MgmApiSession
::
bye
,
""
),
MGM_CMD
(
"bye"
,
&
MgmApiSession
::
bye
,
""
),
MGM_CMD
(
"end session"
,
&
MgmApiSession
::
endSession
,
""
),
MGM_CMD
(
"set loglevel"
,
&
MgmApiSession
::
setLogLevel
,
""
),
MGM_CMD
(
"set loglevel"
,
&
MgmApiSession
::
setLogLevel
,
""
),
MGM_ARG
(
"node"
,
Int
,
Mandatory
,
"Node"
),
MGM_ARG
(
"node"
,
Int
,
Mandatory
,
"Node"
),
MGM_ARG
(
"category"
,
Int
,
Mandatory
,
"Event category"
),
MGM_ARG
(
"category"
,
Int
,
Mandatory
,
"Event category"
),
...
@@ -723,6 +725,17 @@ MgmApiSession::bye(Parser<MgmApiSession>::Context &,
...
@@ -723,6 +725,17 @@ MgmApiSession::bye(Parser<MgmApiSession>::Context &,
m_stop
=
true
;
m_stop
=
true
;
}
}
void
MgmApiSession
::
endSession
(
Parser
<
MgmApiSession
>::
Context
&
,
Properties
const
&
)
{
if
(
m_allocated_resources
)
delete
m_allocated_resources
;
m_allocated_resources
=
new
MgmtSrvr
::
Allocated_resources
(
m_mgmsrv
);
m_output
->
println
(
"end session reply"
);
}
void
void
MgmApiSession
::
setClusterLogLevel
(
Parser
<
MgmApiSession
>::
Context
&
,
MgmApiSession
::
setClusterLogLevel
(
Parser
<
MgmApiSession
>::
Context
&
,
Properties
const
&
args
)
{
Properties
const
&
args
)
{
...
...
ndb/src/mgmsrv/Services.hpp
View file @
473e314a
...
@@ -79,6 +79,7 @@ public:
...
@@ -79,6 +79,7 @@ public:
void
start
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
start
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
startAll
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
startAll
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
bye
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
bye
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
endSession
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
setLogLevel
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
setLogLevel
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
void
setClusterLogLevel
(
Parser_t
::
Context
&
ctx
,
void
setClusterLogLevel
(
Parser_t
::
Context
&
ctx
,
const
class
Properties
&
args
);
const
class
Properties
&
args
);
...
...
ndb/src/mgmsrv/main.cpp
View file @
473e314a
...
@@ -132,6 +132,7 @@ static MgmGlobals *glob= 0;
...
@@ -132,6 +132,7 @@ static MgmGlobals *glob= 0;
* Global variables
* Global variables
*/
*/
bool
g_StopServer
;
bool
g_StopServer
;
bool
g_RestartServer
;
extern
EventLogger
g_eventLogger
;
extern
EventLogger
g_eventLogger
;
extern
int
global_mgmt_server_check
;
extern
int
global_mgmt_server_check
;
...
@@ -191,7 +192,19 @@ static void usage()
...
@@ -191,7 +192,19 @@ static void usage()
*/
*/
int
main
(
int
argc
,
char
**
argv
)
int
main
(
int
argc
,
char
**
argv
)
{
{
int
mgm_connect_result
;
NDB_INIT
(
argv
[
0
]);
NDB_INIT
(
argv
[
0
]);
int
ho_error
;
#ifndef DBUG_OFF
opt_debug
=
"d:t:O,/tmp/ndb_mgmd.trace"
;
#endif
if
((
ho_error
=
handle_options
(
&
argc
,
&
argv
,
my_long_options
,
ndb_std_get_one_option
)))
exit
(
ho_error
);
start:
glob
=
new
MgmGlobals
;
glob
=
new
MgmGlobals
;
/**
/**
...
@@ -208,14 +221,6 @@ int main(int argc, char** argv)
...
@@ -208,14 +221,6 @@ int main(int argc, char** argv)
const
char
*
load_default_groups
[]
=
{
"mysql_cluster"
,
"ndb_mgmd"
,
0
};
const
char
*
load_default_groups
[]
=
{
"mysql_cluster"
,
"ndb_mgmd"
,
0
};
load_defaults
(
"my"
,
load_default_groups
,
&
argc
,
&
argv
);
load_defaults
(
"my"
,
load_default_groups
,
&
argc
,
&
argv
);
int
ho_error
;
#ifndef DBUG_OFF
opt_debug
=
"d:t:O,/tmp/ndb_mgmd.trace"
;
#endif
if
((
ho_error
=
handle_options
(
&
argc
,
&
argv
,
my_long_options
,
ndb_std_get_one_option
)))
exit
(
ho_error
);
if
(
opt_interactive
||
if
(
opt_interactive
||
opt_non_interactive
||
opt_non_interactive
||
g_print_full_config
)
{
g_print_full_config
)
{
...
@@ -293,34 +298,12 @@ int main(int argc, char** argv)
...
@@ -293,34 +298,12 @@ int main(int argc, char** argv)
goto
error_end
;
goto
error_end
;
}
}
/* Construct a fake connectstring to connect back to ourselves */
char
connect_str
[
20
];
if
(
!
opt_connect_str
)
{
snprintf
(
connect_str
,
20
,
"localhost:%u"
,
glob
->
mgmObject
->
getPort
());
opt_connect_str
=
connect_str
;
}
glob
->
mgmObject
->
set_connect_string
(
opt_connect_str
);
if
(
!
glob
->
mgmObject
->
check_start
()){
if
(
!
glob
->
mgmObject
->
check_start
()){
ndbout_c
(
"Unable to check start management server."
);
ndbout_c
(
"Unable to check start management server."
);
ndbout_c
(
"Probably caused by illegal initial configuration file."
);
ndbout_c
(
"Probably caused by illegal initial configuration file."
);
goto
error_end
;
goto
error_end
;
}
}
/*
* Connect back to ourselves so we can use mgmapi to fetch
* config info
*/
int
mgm_connect_result
;
mgm_connect_result
=
glob
->
mgmObject
->
get_config_retriever
()
->
do_connect
(
0
,
0
,
0
);
if
(
mgm_connect_result
<
0
)
{
ndbout_c
(
"Unable to connect to our own ndb_mgmd (Error %d)"
,
mgm_connect_result
);
ndbout_c
(
"This is probably a bug."
);
}
if
(
opt_daemon
)
{
if
(
opt_daemon
)
{
// Become a daemon
// Become a daemon
char
*
lockfile
=
NdbConfig_PidFileName
(
glob
->
localNodeId
);
char
*
lockfile
=
NdbConfig_PidFileName
(
glob
->
localNodeId
);
...
@@ -361,6 +344,7 @@ int main(int argc, char** argv)
...
@@ -361,6 +344,7 @@ int main(int argc, char** argv)
g_eventLogger
.
info
(
msg
);
g_eventLogger
.
info
(
msg
);
g_StopServer
=
false
;
g_StopServer
=
false
;
g_RestartServer
=
false
;
glob
->
socketServer
->
startServer
();
glob
->
socketServer
->
startServer
();
#if ! defined NDB_OSE && ! defined NDB_SOFTOSE
#if ! defined NDB_OSE && ! defined NDB_SOFTOSE
...
@@ -379,13 +363,18 @@ int main(int argc, char** argv)
...
@@ -379,13 +363,18 @@ int main(int argc, char** argv)
NdbSleep_MilliSleep
(
500
);
NdbSleep_MilliSleep
(
500
);
}
}
if
(
g_RestartServer
)
g_eventLogger
.
info
(
"Restarting server..."
);
else
g_eventLogger
.
info
(
"Shutting down server..."
);
g_eventLogger
.
info
(
"Shutting down server..."
);
glob
->
socketServer
->
stopServer
();
glob
->
socketServer
->
stopServer
();
glob
->
mgmObject
->
get_config_retriever
()
->
disconnect
();
// We disconnect from the ConfigRetreiver mgmd when we delete glob below
glob
->
socketServer
->
stopSessions
(
true
);
glob
->
socketServer
->
stopSessions
(
true
);
g_eventLogger
.
info
(
"Shutdown complete"
);
g_eventLogger
.
info
(
"Shutdown complete"
);
the_end:
the_end:
delete
glob
;
delete
glob
;
if
(
g_RestartServer
)
goto
start
;
ndb_end
(
opt_endinfo
?
MY_CHECK_ERROR
|
MY_GIVE_INFO
:
0
);
ndb_end
(
opt_endinfo
?
MY_CHECK_ERROR
|
MY_GIVE_INFO
:
0
);
return
0
;
return
0
;
error_end:
error_end:
...
...
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