@@ -18,17 +18,25 @@ message "Building Mariadb Server from $color_yellow$MDB_SOURCE_PATH$color_normal
18
18
19
19
BUILD_TYPE_OPTIONS=(" Debug" " RelWithDebInfo" )
20
20
DISTRO_OPTIONS=(" Ubuntu" " CentOS" " Debian" " Rocky" )
21
+
22
+ cd $SCRIPT_LOCATION
23
+ CURRENT_BRANCH=$( git rev-parse --abbrev-ref HEAD)
21
24
BRANCHES=($( git branch --list --no-color| grep " [^* ]+" -Eo) )
25
+ cd -
26
+
22
27
23
28
optparse.define short=t long=build-type desc=" Build Type: ${BUILD_TYPE_OPTIONS[*]} " variable=MCS_BUILD_TYPE
24
29
optparse.define short=d long=distro desc=" Choouse your OS: ${DISTRO_OPTIONS[*]} " variable=OS
25
- optparse.define short=s long=skip -deps desc=" Skip install dependences" variable=SKIP_DEPS default=false value=true
30
+ optparse.define short=D long=install -deps desc=" Install dependences" variable=INSTALL_DEPS default=false value=true
26
31
optparse.define short=C long=force-cmake-reconfig desc=" Force cmake reconfigure" variable=FORCE_CMAKE_CONFIG default=false value=true
27
32
optparse.define short=S long=skip-columnstore-submodules desc=" Skip columnstore submodules initialization" variable=SKIP_SUBMODULES default=false value=true
28
33
optparse.define short=u long=skip-unit-tests desc=" Skip UnitTests" variable=SKIP_UNIT_TESTS default=false value=true
29
34
optparse.define short=B long=run-microbench=" Compile and run microbenchmarks " variable=RUN_BENCHMARKS default=false value=true
30
- optparse.define short=b long=branch desc=" Choouse git branch ('none' for menu) " variable=BRANCH
35
+ optparse.define short=b long=branch desc=" Choose git branch. For menu use -b \"\" " variable=BRANCH default= $CURRENT_BRANCH
31
36
optparse.define short=D long=without-core-dumps desc=" Do not produce core dumps" variable=WITHOUT_COREDUMPS default=false value=true
37
+ optparse.define short=A long=asan desc=" Build with ASAN" variable=ASAN default=false value=true
38
+ optparse.define short=v long=verbose desc=" Verbose makefile commands" variable=MAKEFILE_VERBOSE default=false value=true
39
+ optparse.define short=P long=report-path desc=" Path for storing reports and profiles" variable=REPORT_PATH default=" /core"
32
40
33
41
source $( optparse.build )
34
42
@@ -45,27 +53,34 @@ INSTALL_PREFIX="/usr/"
45
53
DATA_DIR=" /var/lib/mysql/data"
46
54
CMAKE_BIN_NAME=cmake
47
55
CTEST_BIN_NAME=ctest
56
+ CONFIG_DIR=" /etc/my.cnf.d"
57
+
58
+ if [[ $OS = ' Ubuntu' || $OS = ' Debian' ]]; then
59
+ CONFIG_DIR=" /etc/mysql/mariadb.conf.d"
60
+ fi
61
+
48
62
49
63
select_branch ()
50
64
{
65
+ cd $SCRIPT_LOCATION
66
+ CURRENT_BRANCH=$( git rev-parse --abbrev-ref HEAD)
67
+
51
68
if [[ ! " ${BRANCHES[*]} " =~ " ${BRANCH} " ]]; then
52
- if [[ $BRANCH = ' none ' ]]; then
69
+ if [[ $BRANCH = " " ]]; then
53
70
getChoice -q " Select your branch" -o BRANCHES
54
71
BRANCH=$selectedChoice
55
72
fi
56
- cd $SCRIPT_LOCATION
57
- message " Selecting $BRANCH branch for Columnstore"
58
- git checkout $BRANCH
59
- cd -
73
+ if [[ $BRANCH != $CURRENT_BRANCH ]] ; then
74
+ message " Selecting $BRANCH branch for Columnstore"
75
+ git checkout $BRANCH
76
+ fi
60
77
61
78
message " Turning off Columnstore submodule auto update via gitconfig"
62
79
cd $MDB_SOURCE_PATH
63
80
git config submodule.storage/columnstore/columnstore.update none
64
81
cd -
65
82
fi
66
83
67
- cd $SCRIPT_LOCATION
68
- CURRENT_BRANCH=$( git rev-parse --abbrev-ref HEAD)
69
84
cd -
70
85
message " Columnstore will be built from $color_yellow$CURRENT_BRANCH$color_normal branch"
71
86
}
@@ -136,7 +151,9 @@ clean_old_installation()
136
151
rm -rf /var/lib/columnstore/local/
137
152
rm -f /var/lib/columnstore/storagemanager/storagemanager-lock
138
153
rm -f /var/lib/columnstore/storagemanager/cs-initialized
154
+ rm -rf /var/log/mariadb/columnstore/*
139
155
rm -rf /tmp/*
156
+ rm -rf $REPORT_PATH
140
157
rm -rf /var/lib/mysql
141
158
rm -rf /var/run/mysqld
142
159
rm -rf $DATA_DIR
@@ -161,7 +178,8 @@ build()
161
178
-DWITH_WSREP=OFF
162
179
-DWITH_SSL=system
163
180
-DCMAKE_INSTALL_PREFIX:PATH=$INSTALL_PREFIX
164
- -DCMAKE_EXPORT_COMPILE_COMMANDS=1"
181
+ -DCMAKE_EXPORT_COMPILE_COMMANDS=1
182
+ "
165
183
166
184
167
185
if [[ $SKIP_UNIT_TESTS = true ]] ; then
@@ -172,11 +190,21 @@ build()
172
190
message " Buiding with unittests"
173
191
fi
174
192
193
+ if [[ $ASAN = true ]] ; then
194
+ warn " Building with ASAN"
195
+ MDB_CMAKE_FLAGS=" ${MDB_CMAKE_FLAGS} -DWITH_ASAN=ON -DWITH_COLUMNSTORE_ASAN=ON -DWITH_COLUMNSTORE_REPORT_PATH=${REPORT_PATH} "
196
+ fi
197
+
175
198
if [[ $WITHOUT_COREDUMPS = true ]] ; then
176
199
warn " Cores are not dumped"
177
-
178
200
else
179
201
MDB_CMAKE_FLAGS=" ${MDB_CMAKE_FLAGS} -DWITH_COREDUMPS=ON"
202
+ echo " ${REPORT_PATH} /core_%e.%p" | sudo tee /proc/sys/kernel/core_pattern
203
+ fi
204
+
205
+ if [[ $MAKEFILE_VERBOSE = true ]] ; then
206
+ warn " Verbosing Makefile Commands"
207
+ MDB_CMAKE_FLAGS=" ${MDB_CMAKE_FLAGS} -DCMAKE_VERBOSE_MAKEFILE:BOOL=ON"
180
208
fi
181
209
182
210
if [[ $RUN_BENCHMARKS = true ]] ; then
@@ -197,7 +225,6 @@ build()
197
225
message " Buiding without microbenchmarks"
198
226
fi
199
227
200
-
201
228
cd $MDB_SOURCE_PATH
202
229
203
230
if [[ $SKIP_SUBMODULES = true ]] ; then
@@ -228,11 +255,13 @@ build()
228
255
message " building with flags $MDB_CMAKE_FLAGS "
229
256
230
257
local CPUS=$( getconf _NPROCESSORS_ONLN)
231
- ${CMAKE_BIN_NAME} . -DCMAKE_BUILD_TYPE=$MCS_BUILD_TYPE $MDB_CMAKE_FLAGS && \
232
- make -j $CPUS install
258
+ ${CMAKE_BIN_NAME} -DCMAKE_BUILD_TYPE=$MCS_BUILD_TYPE $MDB_CMAKE_FLAGS && \ |
259
+ make -j $CPUS
260
+ message " Installing silently"
261
+ make -j $CPUS install > /dev/null
233
262
234
263
if [ $? -ne 0 ]; then
235
- error " !!!! BUILD FAILED"
264
+ error " !!!! BUILD FAILED !!!! "
236
265
exit 1
237
266
fi
238
267
cd -
@@ -259,7 +288,7 @@ run_unit_tests()
259
288
else
260
289
message " Running unittests"
261
290
cd $MDB_SOURCE_PATH
262
- ${CTEST_BIN_NAME} . -R columnstore: -j $( nproc)
291
+ ${CTEST_BIN_NAME} . -R columnstore: -j $( nproc) --progress
263
292
cd -
264
293
fi
265
294
}
@@ -271,14 +300,56 @@ run_microbenchmarks_tests()
271
300
else
272
301
message " Runnning microbenchmarks"
273
302
cd $MDB_SOURCE_PATH
274
- ${CTEST_BIN_NAME} . -V -R columnstore_microbenchmarks: -j $( nproc)
303
+ ${CTEST_BIN_NAME} . -V -R columnstore_microbenchmarks: -j $( nproc) --progress
275
304
cd -
276
305
fi
277
306
}
278
307
308
+ disable_plugins_for_bootstrap ()
309
+ {
310
+ find /etc -type f -exec sed -i ' s/plugin-load-add=auth_gssapi.so//g' {} +
311
+ find /etc -type f -exec sed -i ' s/plugin-load-add=ha_columnstore.so//g' {} +
312
+ }
313
+
314
+ enable_columnstore_back ()
315
+ {
316
+ echo plugin-load-add=ha_columnstore.so >> $CONFIG_DIR /columnstore.cnf
317
+ }
318
+
319
+ fix_config_files ()
320
+ {
321
+ message Fixing config files
322
+
323
+ THREAD_STACK_SIZE=" 20M"
324
+
325
+ SYSTEMD_SERVICE_DIR=" /usr/lib/systemd/system"
326
+ if [[ $ASAN = true ]] ; then
327
+ COLUMNSTORE_CONFIG=$CONFIG_DIR /columnstore.cnf
328
+ if grep -q thread_stack $COLUMNSTORE_CONFIG ; then
329
+ warn " MDB Server has thread_stack settings on $COLUMNSTORE_CONFIG check it's compatibility with ASAN"
330
+ else
331
+ echo " thread_stack = ${THREAD_STACK_SIZE} " >> $COLUMNSTORE_CONFIG
332
+ message " thread_stack was set to ${THREAD_STACK_SIZE} in $COLUMNSTORE_CONFIG "
333
+ fi
334
+
335
+ MDB_SERVICE_FILE=$SYSTEMD_SERVICE_DIR /mariadb.service
336
+ if grep -q ASAN $MDB_SERVICE_FILE ; then
337
+ warn " MDB Server has ASAN options in $MDB_SERVICE_FILE , check it's compatibility"
338
+ else
339
+ echo Environment=" 'ASAN_OPTIONS=abort_on_error=1:disable_coredump=0,print_stats=false,detect_odr_violation=0,check_initialization_order=1,detect_stack_use_after_return=1,atexit=false,log_path=${ASAN_PATH} '" >> $MDB_SERVICE_FILE
340
+ message " ASAN options were added to $MDB_SERVICE_FILE "
341
+ fi
342
+ fi
343
+ systemctl daemon-reload
344
+ }
345
+
279
346
install ()
280
347
{
281
348
message " Installing MariaDB"
349
+ disable_plugins_for_bootstrap
350
+
351
+ mkdir -p $REPORT_PATH
352
+ chmod 777 $REPORT_PATH
282
353
283
354
check_user_and_group
284
355
@@ -288,10 +359,15 @@ install()
288
359
socket=/run/mysqld/mysqld.sock" > /etc/my.cnf.d/socket.cnf'
289
360
290
361
mv $INSTALL_PREFIX /lib/mysql/plugin/ha_columnstore.so /tmp/ha_columnstore_1.so || mv $INSTALL_PREFIX /lib64/mysql/plugin/ha_columnstore.so /tmp/ha_columnstore_2.so
362
+ mkdir -p /var/lib/mysql
363
+ chown mysql:mysql /var/lib/mysql
364
+
291
365
message " Running mysql_install_db"
292
- mysql_install_db --rpm --user=mysql
366
+ sudo -u mysql mysql_install_db --rpm --user=mysql > /dev/null
293
367
mv /tmp/ha_columnstore_1.so $INSTALL_PREFIX /lib/mysql/plugin/ha_columnstore.so || mv /tmp/ha_columnstore_2.so $INSTALL_PREFIX /lib64/mysql/plugin/ha_columnstore.so
294
368
369
+ enable_columnstore_back
370
+
295
371
mkdir -p /etc/columnstore
296
372
297
373
cp $MDB_SOURCE_PATH /storage/columnstore/columnstore/oam/etc/Columnstore.xml /etc/columnstore/Columnstore.xml
@@ -308,7 +384,7 @@ socket=/run/mysqld/mysqld.sock" > /etc/my.cnf.d/socket.cnf'
308
384
> /etc/mysql/debian.cnf
309
385
fi
310
386
311
- systemctl daemon-reload
387
+ fix_config_files
312
388
313
389
if [ -d " /etc/mysql/mariadb.conf.d/" ]; then
314
390
message " Copying configs from /etc/mysql/mariadb.conf.d/ to /etc/my.cnf.d"
@@ -345,9 +421,23 @@ socket=/run/mysqld/mysqld.sock" > /etc/my.cnf.d/socket.cnf'
345
421
chmod 777 /var/log/mariadb/columnstore
346
422
}
347
423
424
+
425
+ smoke ()
426
+ {
427
+ message " Creating test database"
428
+ mariadb -e " create database if not exists test;"
429
+ message " Selecting magic numbers"
430
+ MAGIC=` mysql -N test < $MDB_SOURCE_PATH /storage/columnstore/columnstore/tests/scripts/smoke.sql`
431
+ if [[ $MAGIC == ' 42' ]] ; then
432
+ message " Great answer correct"
433
+ else
434
+ warn " Smoke failed, answer is '$MAGIC '"
435
+ fi
436
+ }
437
+
348
438
select_branch
349
439
350
- if [[ $SKIP_DEPS = false ]] ; then
440
+ if [[ $INSTALL_DEPS = true ]] ; then
351
441
install_deps
352
442
fi
353
443
@@ -358,4 +448,6 @@ run_unit_tests
358
448
run_microbenchmarks_tests
359
449
install
360
450
start_service
451
+ smoke
452
+
361
453
message " $color_green FINISHED $color_normal "
0 commit comments