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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
1fd2e107
Commit
1fd2e107
authored
Jul 23, 2012
by
jani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
New version of mysqld_multi. Building Galera tree fully first time in buildbot
parent
f97e67ff
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
117 additions
and
13 deletions
+117
-13
scripts/mysqld_multi.sh
scripts/mysqld_multi.sh
+117
-13
No files found.
scripts/mysqld_multi.sh
View file @
1fd2e107
...
@@ -38,7 +38,7 @@ use Getopt::Long;
...
@@ -38,7 +38,7 @@ use Getopt::Long;
use POSIX qw
(
strftime getcwd
)
;
use POSIX qw
(
strftime getcwd
)
;
$|
=
1
;
$|
=
1
;
$VER
=
"2.
16
"
;
$VER
=
"2.
20
"
;
my @defaults_options
;
# Leading --no-defaults, --defaults-file, etc.
my @defaults_options
;
# Leading --no-defaults, --defaults-file, etc.
...
@@ -116,6 +116,7 @@ sub main
...
@@ -116,6 +116,7 @@ sub main
print
"will be disabled
\n
and some will be enabled.
\n\n
"
;
print
"will be disabled
\n
and some will be enabled.
\n\n
"
;
}
}
init_log
()
if
(!
defined
(
$opt_log
))
;
$groupids
=
$ARGV
[
1]
;
$groupids
=
$ARGV
[
1]
;
if
(
$opt_version
)
if
(
$opt_version
)
{
{
...
@@ -141,7 +142,6 @@ sub main
...
@@ -141,7 +142,6 @@ sub main
!(
$ARGV
[
0]
=
~ m/^stop
$/
i
)
&&
!(
$ARGV
[
0]
=
~ m/^stop
$/
i
)
&&
!(
$ARGV
[
0]
=
~ m/^report
$/
i
)))
;
!(
$ARGV
[
0]
=
~ m/^report
$/
i
)))
;
init_log
()
if
(!
defined
(
$opt_log
))
;
if
(!
$opt_no_log
)
if
(!
$opt_no_log
)
{
{
w2log
(
"
$my_progname
log file version
$VER
; run: "
,
w2log
(
"
$my_progname
log file version
$VER
; run: "
,
...
@@ -184,9 +184,9 @@ sub main
...
@@ -184,9 +184,9 @@ sub main
}
}
}
}
#
#
###
# Quote word for shell
#
###
Quote word for shell
#
#
###
sub quote_shell_word
sub quote_shell_word
{
{
...
@@ -196,6 +196,10 @@ sub quote_shell_word
...
@@ -196,6 +196,10 @@ sub quote_shell_word
return
$option
;
return
$option
;
}
}
####
#### get options for a group
####
sub defaults_for_group
sub defaults_for_group
{
{
my
(
$group
)
=
@_
;
my
(
$group
)
=
@_
;
...
@@ -297,8 +301,12 @@ sub report_mysqlds
...
@@ -297,8 +301,12 @@ sub report_mysqlds
sub start_mysqlds
()
sub start_mysqlds
()
{
{
my
(
@groups,
$com
,
$tmp
,
$i
, @options,
$j
,
$mysqld_found
,
$info_sent
)
;
my
(
@groups,
$com
,
$com2
,
$tmp
,
$i
, @options,
$j
,
$mysqld_found
,
$info_sent
,
$curdir
,
$mysql_install_db
,
$srcdir
,
$basedir
,
$datadir
)
;
$mysql_install_db
=
undef
()
;
$srcdir
=
undef
()
;
if
(!
$opt_no_log
)
if
(!
$opt_no_log
)
{
{
w2log
(
"
\n
Starting MySQL servers
\n
"
,
"
$opt_log
"
,0,0
)
;
w2log
(
"
\n
Starting MySQL servers
\n
"
,
"
$opt_log
"
,0,0
)
;
...
@@ -312,8 +320,9 @@ sub start_mysqlds()
...
@@ -312,8 +320,9 @@ sub start_mysqlds()
{
{
@options
=
defaults_for_group
(
$groups
[
$i
])
;
@options
=
defaults_for_group
(
$groups
[
$i
])
;
$basedir_found
=
0
;
# The default
my
$basedir_found
=
0
;
# The default
$mysqld_found
=
1
;
# The default
my
$datadir_found
=
0
;
# The default
my
$mysqld_found
=
1
;
# The default
$mysqld_found
=
0
if
(!
length
(
$mysqld
))
;
$mysqld_found
=
0
if
(!
length
(
$mysqld
))
;
$com
=
"
$mysqld
"
;
$com
=
"
$mysqld
"
;
for
(
$j
=
0,
$tmp
=
""
;
defined
(
$options
[
$j
])
;
$j
++
)
for
(
$j
=
0,
$tmp
=
""
;
defined
(
$options
[
$j
])
;
$j
++
)
...
@@ -328,6 +337,47 @@ sub start_mysqlds()
...
@@ -328,6 +337,47 @@ sub start_mysqlds()
$com
=
$options
[
$j
]
;
$com
=
$options
[
$j
]
;
$mysqld_found
=
1
;
$mysqld_found
=
1
;
}
}
elsif
(
"--mysql-install-db="
eq substr
(
$options
[
$j
]
, 0, 19
))
{
# mysql_install_db related option
$options
[
$j
]=
~ s/
\-\-
mysql
\-
install
\-
db
\=
//
;
$mysql_install_db
=
$options
[
$j
]
;
}
elsif
(
"--srcdir="
eq substr
(
$options
[
$j
]
, 0, 9
))
{
# mysql_install_db related option
$options
[
$j
]=
~ s/
\-\-
srcdir
\=
//
;
$srcdir
=
$options
[
$j
]
;
}
elsif
(
"--include-config="
eq substr
(
$options
[
$j
]
, 0, 17
))
{
$options
[
$j
]=
~ s/
\-\-
include
\-
config
\=
//
;
$com2
=
"my_print_defaults --config-file=
$options
[
$j
]
$groups
[
$i
]"
;
# we need to reorder the array so that options in extra config file
# come in the middle. Needed if someone wants to overwrite an option
my
(
$k
, @tmp_array
)
;
for
(
$k
=
$j
+ 1
;
defined
(
$options
[
$k
])
;
$k
++
)
{
push
(
@tmp_array,
$options
[
$k
])
;
undef
(
$options
[
$k
])
;
}
pop
(
@options
)
;
# pop out last null array element
push
(
@options,
`
$com2
`
)
;
chomp
(
@options
)
;
# new lines away
push
(
@options, @tmp_array
)
;
}
elsif
(
"--datadir="
eq substr
(
$options
[
$j
]
, 0, 10
))
{
$datadir
=
$options
[
$j
]
;
$datadir
=
~ s/^--datadir
=
//
;
$datadir_found
=
1
;
$options
[
$j
]=
quote_shell_word
(
$options
[
$j
])
;
$tmp
.
=
"
$options
[
$j
]"
;
}
elsif
(
"--basedir="
eq substr
(
$options
[
$j
]
, 0, 10
))
elsif
(
"--basedir="
eq substr
(
$options
[
$j
]
, 0, 10
))
{
{
$basedir
=
$options
[
$j
]
;
$basedir
=
$options
[
$j
]
;
...
@@ -351,6 +401,25 @@ sub start_mysqlds()
...
@@ -351,6 +401,25 @@ sub start_mysqlds()
print
"wanted mysqld binary.
\n\n
"
;
print
"wanted mysqld binary.
\n\n
"
;
$info_sent
=
1
;
$info_sent
=
1
;
}
}
if
(
defined
(
$mysql_install_db
))
{
$com2
=
"
$mysql_install_db
"
;
$com2
.
=
" --srcdir=
$srcdir
"
if
(
defined
(
$srcdir
))
;
$com2
.
=
" --datadir=
$datadir
"
if
(
$datadir_found
)
;
if
(
-d
"
$datadir
/mysql"
)
{
my
$wstr
=
"WARNING:
$datadir
/mysql already exists. Not going to
\n
"
;
$wstr
.
=
"run
$mysql_install_db
on
$datadir
\n
"
;
print
$wstr
if
(
$opt_verbose
)
;
w2log
(
$wstr
, 0, 0
)
;
}
else
{
w2log
(
"Installing databases on
$datadir
..
\n
"
, 0, 0
)
;
`
$com2
`
;
}
}
$com
.
=
$tmp
;
$com
.
=
$tmp
;
$com
.
=
" >>
$opt_log
2>&1"
if
(!
$opt_no_log
)
;
$com
.
=
" >>
$opt_log
2>&1"
if
(!
$opt_no_log
)
;
$com
.
=
" &"
;
$com
.
=
" &"
;
...
@@ -420,7 +489,7 @@ sub stop_mysqlds()
...
@@ -420,7 +489,7 @@ sub stop_mysqlds()
sub get_mysqladmin_options
sub get_mysqladmin_options
{
{
my
(
$i
, @groups
)=
@_
;
my
(
$i
, @groups
)=
@_
;
my
(
$mysqladmin_found
,
$com
,
$tmp
,
$j
)
;
my
(
$mysqladmin_found
,
$com
,
$
com2
,
$
tmp
,
$j
)
;
@options
=
defaults_for_group
(
$groups
[
$i
])
;
@options
=
defaults_for_group
(
$groups
[
$i
])
;
...
@@ -443,6 +512,25 @@ sub get_mysqladmin_options
...
@@ -443,6 +512,25 @@ sub get_mysqladmin_options
$com= $options[$j];
$com= $options[$j];
$mysqladmin_found= 1;
$mysqladmin_found= 1;
}
}
elsif ("--include-config=" eq substr($options[$j], 0, 17))
{
$options[$j]=~ s/\-\-include\-config\=//;
$com2= "my_print_defaults --config-file=$options[$j] $groups[$i]";
# we need to reorder the array so that options in extra config file
# come in the middle. Needed if someone wants to overwrite an option
my ($k, @tmp_array);
for ($k= $j + 1; defined($options[$k]); $k++)
{
push (@tmp_array, $options[$k]);
undef($options[$k]);
}
pop(@options); # pop out last null array element
push (@options, `$com2`);
chomp(@options); # new lines away
push (@options, @tmp_array);
}
elsif ((($options[$j] =~ m/^(\-\-socket\=)(.*)$/) && !$opt_tcp_ip) ||
elsif ((($options[$j] =~ m/^(\-\-socket\=)(.*)$/) && !$opt_tcp_ip) ||
($options[$j] =~ m/^(\-\-port\=)(.*)$/))
($options[$j] =~ m/^(\-\-port\=)(.*)$/))
{
{
...
@@ -462,8 +550,11 @@ sub get_mysqladmin_options
...
@@ -462,8 +550,11 @@ sub get_mysqladmin_options
return $com;
return $com;
}
}
# Return a list of option files which can be opened. Similar, but not
####
# identical, to behavior of my_search_option_files()
#### Return a list of option files which can be opened. Similar, but not
#### identical, to behavior of my_search_option_files()
####
sub list_defaults_files
sub list_defaults_files
{
{
my %opt;
my %opt;
...
@@ -485,9 +576,11 @@ sub list_defaults_files
...
@@ -485,9 +576,11 @@ sub list_defaults_files
(
$ENV
{
HOME
}
?
"
$ENV
{HOME}/.my.cnf"
: undef
))
;
(
$ENV
{
HOME
}
?
"
$ENV
{HOME}/.my.cnf"
: undef
))
;
}
}
####
#### Takes a specification of GNRs (see --help), and returns a list of matching
#### groups which actually are mentioned in a relevant config file
####
# Takes a specification of GNRs (see --help), and returns a list of matching
# groups which actually are mentioned in a relevant config file
sub find_groups
sub find_groups
{
{
my
(
$raw_gids
)
=
@_
;
my
(
$raw_gids
)
=
@_
;
...
@@ -802,6 +895,17 @@ Using: @{[join ' ', @defaults_options]}
...
@@ -802,6 +895,17 @@ Using: @{[join ' ', @defaults_options]}
question. This will be recognised as a special option and
question. This will be recognised as a special option and
will not be passed to the mysqld. This will allow one to
will not be passed to the mysqld. This will allow one to
start different mysqld versions with mysqld_multi.
start different mysqld versions with mysqld_multi.
--include-config= An optional config file inside a group [mysqld#] which
the program is currently reading. It will read any extra
options of that group from additional file and insert them
where this option was found. Note that the group name
[mysqld#] must be the same in order for options to be found.
--mysql-install-db=...
mysql_install_db script to be used for creating internal
databases. Used when installing datadir for the first time.
This option will be skipped with info in the log file if
'mysql' database already exists in the given datadir.
--srcdir=... srcdir argument for mysql_install_db script. Optional.
--no-log Print to stdout instead of the log file. By default the log
--no-log Print to stdout instead of the log file. By default the log
file is turned on.
file is turned on.
--password=... Password for mysqladmin user.
--password=... Password for mysqladmin user.
...
...
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