Deb: Misc ColumnStore Debian packaging improvements

- Add 'libboost-all-dev' and 'libreadline-gplv2-dev' as they were was found
  to be a compulsory build dependency for columnstore plugin.
- Add 'expect' as run-time dependencey for columnstore plugin as scripts
  use it:
    usr/bin/mcs_module_installer.sh: #!/usr/bin/expect
    usr/bin/remote_command.sh: #!/usr/bin/expect
    usr/bin/remote_command_verify.sh: #!/usr/bin/expect
    usr/bin/remote_scp_get.sh: #!/usr/bin/expect
    usr/bin/remote_scp_put.sh: #!/usr/bin/expect
    usr/bin/rsync.sh: #!/usr/bin/expect
- Properly define depends on Python. No Python 2 support needs to be
  considered, Python 3 has been around long enough. Fixes Lintian errors
    E: mariadb-plugin-columnstore: python-script-but-no-python-dep
    usr/bin/mcs-loadbrm.py #!python
    E: mariadb-plugin-columnstore: python-script-but-no-python-dep
    usr/bin/mcs-start-storagemanager.py #!python
- Partially revert undocumented and thus unjustified changes in commits
  d69a79da63287089efdc5f90a11ecd66ce55b471 and
  c0565666cfe6528b76bc53ce50d3690d13c92cf6.
- Trigger ldconfig, otherwise Lintian complains:
    E: mariadb-plugin-columnstore: package-must-activate-ldconfig-trigger
    usr/lib/x86_64-linux-gnu/libwriteengineredistribute.so
- Update postinst to be compatible with new server binary mariadbd name.
- Properly detect systemd or fallback to sysv init in postrm script.
- Only attempt to build ColumnStore on amd64 and i386. Test builds on
  Launchpad.net showed the CMake plugin configure step will prevent even
  attempts to build on other platforms.
- Clean up and unify cmake build command in debian/rules.
- Explicitly list files not installed.
- Run 'wrap-and-sort -a -v'.
- Truncate build logs on Salsa-CI to keep under 4 MB. This is now needed
  as the ColumnStore build is so verbose.
  See https://jira.mariadb.org/browse/MCOL-4111.
- Update Travis-CI dependencies to match new debian/control.
This commit is contained in:
Otto Kekäläinen 2020-07-03 16:24:58 +03:00
parent 24ed08c3c4
commit 439377927b
13 changed files with 69 additions and 44 deletions

View file

@ -40,7 +40,14 @@ addons:
- g++-9 # ubuntu-toolchain-r/test (xenial and bionic) - g++-9 # ubuntu-toolchain-r/test (xenial and bionic)
- gdb - gdb
- libaio-dev - libaio-dev
- libboost-atomic-dev
- libboost-chrono-dev
- libboost-date-time-dev
- libboost-dev - libboost-dev
- libboost-filesystem-dev
- libboost-regex-dev
- libboost-system-dev
- libboost-thread-dev
- libcrack2-dev - libcrack2-dev
- libcurl3-dev - libcurl3-dev
- libdbd-mysql - libdbd-mysql
@ -52,6 +59,7 @@ addons:
- libnuma-dev - libnuma-dev
- libpam0g-dev - libpam0g-dev
- libpcre2-dev - libpcre2-dev
- libreadline-gplv2-dev
- libsnappy-dev - libsnappy-dev
- libssl-dev - libssl-dev
- libstemmer-dev - libstemmer-dev

View file

@ -31,7 +31,7 @@ then
sed 's|DINSTALL_MYSQLTESTDIR=share/mysql/mysql-test|DINSTALL_MYSQLTESTDIR=false|' -i debian/rules sed 's|DINSTALL_MYSQLTESTDIR=share/mysql/mysql-test|DINSTALL_MYSQLTESTDIR=false|' -i debian/rules
# Also skip building RocksDB, Mroonga etc to save even more time and disk space # Also skip building RocksDB, Mroonga etc to save even more time and disk space
sed 's|-DDEB|-DPLUGIN_MROONGA=NO -DPLUGIN_SPIDER=NO -DPLUGIN_OQGRAPH=NO -DPLUGIN_PERFSCHEMA=NO -DPLUGIN_SPHINX=NO -DDEB|' -i debian/rules sed 's|-DDEB|-DPLUGIN_MROONGA=NO -DPLUGIN_ROCKSDB=NO -DPLUGIN_SPIDER=NO -DPLUGIN_OQGRAPH=NO -DPLUGIN_PERFSCHEMA=NO -DPLUGIN_SPHINX=NO -DDEB|' -i debian/rules
fi fi
# Convert gcc version to numberical value. Format is Mmmpp where M is Major # Convert gcc version to numberical value. Format is Mmmpp where M is Major
@ -75,7 +75,6 @@ fi
if [[ $GCCVERSION -lt 40800 ]] || [[ $(arch) =~ i[346]86 ]] || [[ $TRAVIS ]] if [[ $GCCVERSION -lt 40800 ]] || [[ $(arch) =~ i[346]86 ]] || [[ $TRAVIS ]]
then then
sed '/Package: mariadb-plugin-rocksdb/,/^$/d' -i debian/control sed '/Package: mariadb-plugin-rocksdb/,/^$/d' -i debian/control
sed -i 's|-DPLUGIN_ROCKSDB=YES|-DPLUGIN_ROCKSDB=NO|' debian/rules
fi fi
# If libpcre2-dev is not available (before Debian Stretch and Ubuntu Xenial) # If libpcre2-dev is not available (before Debian Stretch and Ubuntu Xenial)
@ -95,11 +94,13 @@ then
sed -i -e "/Package: libmariadbd-dev/,/^$/d" debian/control sed -i -e "/Package: libmariadbd-dev/,/^$/d" debian/control
fi fi
if [[ $TRAVIS ]] || ! [[ $(arch) =~ 86 ]] # Don't build nor package ColumnStore on Travis-CI
if [[ $TRAVIS ]]
then then
sed -i -e "/Package: mariadb-plugin-columnstore/,/^$/d" debian/control sed "/Package: mariadb-plugin-columnstore/,/^$/d" -i debian/control
sed -i '/flex/d' debian/control sed '/flex/d' -i debian/control
sed -i 's|-DPLUGIN_COLUMNSTORE=YES|-DPLUGIN_COLUMNSTORE=NO|' debian/rules sed -r '/libboost-[a-z-]+-dev/d' -i debian/control
sed 's|-DPLUGIN_COLUMNSTORE=YES|-DPLUGIN_COLUMNSTORE=NO|' -i debian/rules
fi fi
# Adjust changelog, add new version # Adjust changelog, add new version

19
debian/control vendored
View file

@ -9,10 +9,17 @@ Build-Depends: bison,
dh-apparmor, dh-apparmor,
dh-exec, dh-exec,
dh-systemd, dh-systemd,
flex, flex [i386 amd64],
gdb, gdb,
libaio-dev [linux-any], libaio-dev [linux-any],
libboost-atomic-dev [i386 amd64],
libboost-chrono-dev [i386 amd64],
libboost-date-time-dev [i386 amd64],
libboost-dev, libboost-dev,
libboost-filesystem-dev [i386 amd64],
libboost-regex-dev [i386 amd64],
libboost-system-dev [i386 amd64],
libboost-thread-dev [i386 amd64],
libcrack2-dev (>= 2.9.0), libcrack2-dev (>= 2.9.0),
libcurl4-openssl-dev | libcurl4-dev, libcurl4-openssl-dev | libcurl4-dev,
libedit-dev, libedit-dev,
@ -24,6 +31,7 @@ Build-Depends: bison,
libnuma-dev [!armhf], libnuma-dev [!armhf],
libpam0g-dev, libpam0g-dev,
libpcre2-dev, libpcre2-dev,
libreadline-gplv2-dev [i386 amd64],
libsnappy-dev, libsnappy-dev,
libssl-dev | libssl1.0-dev, libssl-dev | libssl1.0-dev,
libsystemd-dev [linux-any], libsystemd-dev [linux-any],
@ -653,11 +661,12 @@ Description: RocksDB storage engine for MariaDB
Package: mariadb-plugin-columnstore Package: mariadb-plugin-columnstore
Architecture: amd64 i386 Architecture: amd64 i386
Depends: mariadb-server-10.5 (= ${binary:Version}), Depends: binutils,
net-tools, expect,
binutils,
libsnappy1 | libsnappy1v5,
libjemalloc1 | libjemalloc2, libjemalloc1 | libjemalloc2,
libsnappy1 | libsnappy1v5,
mariadb-server-10.5 (= ${binary:Version}),
net-tools,
python3, python3,
${misc:Depends}, ${misc:Depends},
${shlibs:Depends} ${shlibs:Depends}

View file

@ -18,7 +18,6 @@ usr/bin/ProcMon
usr/bin/ServerMonitor usr/bin/ServerMonitor
usr/bin/StorageManager usr/bin/StorageManager
usr/bin/WriteEngineServer usr/bin/WriteEngineServer
usr/bin/dbmsReport.sh
usr/bin/autoConfigure usr/bin/autoConfigure
usr/bin/bulklogReport.sh usr/bin/bulklogReport.sh
usr/bin/clearShm usr/bin/clearShm
@ -42,6 +41,7 @@ usr/bin/cpimport
usr/bin/cpimport.bin usr/bin/cpimport.bin
usr/bin/cplogger usr/bin/cplogger
usr/bin/dbbuilder usr/bin/dbbuilder
usr/bin/dbmsReport.sh
usr/bin/dbrmctl usr/bin/dbrmctl
usr/bin/ddlcleanup usr/bin/ddlcleanup
usr/bin/disable-rep-columnstore.sh usr/bin/disable-rep-columnstore.sh
@ -51,8 +51,12 @@ usr/bin/hardwareReport.sh
usr/bin/idbmeminfo usr/bin/idbmeminfo
usr/bin/load_brm usr/bin/load_brm
usr/bin/logReport.sh usr/bin/logReport.sh
usr/bin/mariadb-columnstore-start.sh
usr/bin/mariadb-columnstore-stop.sh
usr/bin/mariadb-command-line.sh usr/bin/mariadb-command-line.sh
usr/bin/master-rep-columnstore.sh usr/bin/master-rep-columnstore.sh
usr/bin/mcs-loadbrm.py
usr/bin/mcs-start-storagemanager.py
usr/bin/mcs-stop-controllernode.sh usr/bin/mcs-stop-controllernode.sh
usr/bin/mcsGetConfig usr/bin/mcsGetConfig
usr/bin/mcsSetConfig usr/bin/mcsSetConfig
@ -82,10 +86,6 @@ usr/bin/smrm
usr/bin/startupTests.sh usr/bin/startupTests.sh
usr/bin/viewtablelock usr/bin/viewtablelock
usr/bin/workernode usr/bin/workernode
usr/bin/mcs-start-storagemanager.py
usr/bin/mcs-loadbrm.py
usr/bin/mariadb-columnstore-start.sh
usr/bin/mariadb-columnstore-stop.sh
usr/lib/*/libalarmmanager.so usr/lib/*/libalarmmanager.so
usr/lib/*/libbatchloader.so usr/lib/*/libbatchloader.so
usr/lib/*/libbrm.so usr/lib/*/libbrm.so
@ -146,9 +146,9 @@ usr/share/columnstore/mcs-dmlproc.service
usr/share/columnstore/mcs-exemgr.service usr/share/columnstore/mcs-exemgr.service
usr/share/columnstore/mcs-loadbrm.service usr/share/columnstore/mcs-loadbrm.service
usr/share/columnstore/mcs-primproc.service usr/share/columnstore/mcs-primproc.service
usr/share/columnstore/mcs-storagemanager.service
usr/share/columnstore/mcs-workernode.service usr/share/columnstore/mcs-workernode.service
usr/share/columnstore/mcs-writeengineserver.service usr/share/columnstore/mcs-writeengineserver.service
usr/share/columnstore/mcs-storagemanager.service
usr/share/columnstore/mcstest-001.sh usr/share/columnstore/mcstest-001.sh
usr/share/columnstore/mcstest-002.sh usr/share/columnstore/mcstest-002.sh
usr/share/columnstore/mcstest-003.sh usr/share/columnstore/mcstest-003.sh

View file

@ -5,6 +5,4 @@ set -e
# Install ColumnStore # Install ColumnStore
columnstore-post-install --rpmmode=install columnstore-post-install --rpmmode=install
echo "MariaDB ColumnStore install completed"
#DEBHELPER# #DEBHELPER#

View file

@ -8,22 +8,17 @@ if [ "$1" = "purge" ]; then
rm -f /etc/mysql/mariadb.conf.d/columnstore.cnf.rpmsave rm -f /etc/mysql/mariadb.conf.d/columnstore.cnf.rpmsave
fi fi
running_systemd() { # Automatically restart MariaDB after ColumnStore plugin has been removed
if [ "$(ps --no-headers -o comm 1)" = "systemd" ]; then case "$1" in
echo 0 purge|remove|disappear)
else if [ -d /run/systemd/system ]; then
echo 1 # If systemd
deb-systemd-invoke restart mariadb.service >/dev/null
elif [ -x "/etc/init.d/mariadb" ]; then
# Fall-back to SysV init
invoke-rc.d mariadb restart || exit $?
fi fi
} ;;
esac
if [ ! -z "$(pgrep -x mysqld)" ];then
systemctl cat mariadb.service > /dev/null 2>&1
if [ $? -eq 0 ] && [ $(running_systemd) -eq 0 ]; then
systemctl restart mariadb.service > /dev/null 2>&1
else
pkill mysqld > /dev/null 2>&1
/usr/bin/mysqld_safe &
fi
fi
#DEBHELPER# #DEBHELPER#

View file

@ -4,6 +4,5 @@ set -e
columnstore-pre-uninstall columnstore-pre-uninstall
exit 0
#DEBHELPER# #DEBHELPER#

View file

@ -0,0 +1 @@
activate-noawait ldconfig

View file

@ -1,12 +1,17 @@
etc/columnstore/storagemanager.cnf.example # Copy of etc/columnstore/storagemanager.cnf that is installed
lib/systemd/system/mariadb.service # Installed by rules file lib/systemd/system/mariadb.service # Installed by rules file
lib/systemd/system/mariadb@.service # Installed by rules file lib/systemd/system/mariadb@.service # Installed by rules file
usr/bin/mysql_config # We already have the MariaDB variant usr/bin/mysql_config # We already have the MariaDB variant
usr/bin/mytop # Mytop is distributed from a separate source package usr/bin/mytop # Mytop is distributed from a separate source package
usr/bin/sst_dump # Use the one from rocksdb-tools package usr/bin/sst_dump # Use the one from rocksdb-tools package
usr/lib/sysusers.d/sysusers.conf
usr/lib/tmpfiles.d/tmpfiles.conf
usr/lib/mysql/plugin/JavaWrappers.jar # These are only built if JNI/libjawt.so is installed from e.g. openjdk-8-jre-headless usr/lib/mysql/plugin/JavaWrappers.jar # These are only built if JNI/libjawt.so is installed from e.g. openjdk-8-jre-headless
usr/lib/mysql/plugin/JdbcInterface.jar # These are only built if JNI/libjawt.so is installed from e.g. openjdk-8-jre-headless usr/lib/mysql/plugin/JdbcInterface.jar # These are only built if JNI/libjawt.so is installed from e.g. openjdk-8-jre-headless
usr/lib/sysusers.d/sysusers.conf
usr/lib/tmpfiles.d/tmpfiles.conf
usr/lib/*/libdbbc.a # ColumnStore header file
usr/lib/*/libidbboot.a # ColumnStore header file
usr/lib/*/libprocessor.a # ColumnStore header file
usr/lib/*/libwe_xml.a # ColumnStore header file
usr/share/doc/mariadb-server-10.5/COPYING usr/share/doc/mariadb-server-10.5/COPYING
usr/share/doc/mariadb-server-10.5/COPYING.AGPLv3 usr/share/doc/mariadb-server-10.5/COPYING.AGPLv3
usr/share/doc/mariadb-server-10.5/COPYING.GPLv2 usr/share/doc/mariadb-server-10.5/COPYING.GPLv2

14
debian/rules vendored
View file

@ -39,6 +39,17 @@ else
TESTSUITE_FAIL_CMD:=exit 1 TESTSUITE_FAIL_CMD:=exit 1
endif endif
# RocksDB cannot build on 32-bit platforms
ifeq (32,$(DEB_HOST_ARCH_BITS))
CMAKEFLAGS += -DWITHOUT_ROCKSDB=true
endif
# ColumnStore only attempts to build on a few platforms as dictated by CMake checks
# Also note in debian/control the CS-only build deps marked '[i386 amd64]'
ifeq ($(DEB_HOST_ARCH),$(filter $(DEB_HOST_ARCH),amd64 i386))
CMAKEFLAGS += -DPLUGIN_COLUMNSTORE=YES
endif
# Add extra flag to avoid WolfSSL code crashing the entire mariadbd on s390x. This # Add extra flag to avoid WolfSSL code crashing the entire mariadbd on s390x. This
# can be removed once upstream has made the code s390x compatible, see # can be removed once upstream has made the code s390x compatible, see
# https://jira.mariadb.org/browse/MDEV-21705 and # https://jira.mariadb.org/browse/MDEV-21705 and
@ -83,10 +94,7 @@ endif
-DBUILD_CONFIG=mysql_release \ -DBUILD_CONFIG=mysql_release \
-DPLUGIN_TOKUDB=NO \ -DPLUGIN_TOKUDB=NO \
-DPLUGIN_CASSANDRA=NO \ -DPLUGIN_CASSANDRA=NO \
-DPLUGIN_COLUMNSTORE=YES \
-DPLUGIN_ROCKSDB=YES \
-DPLUGIN_AWS_KEY_MANAGEMENT=NO \ -DPLUGIN_AWS_KEY_MANAGEMENT=NO \
-WITH_EMBEDDED_SERVER=OFF \
-DDEB=$(DEB_VENDOR) ..' -DDEB=$(DEB_VENDOR) ..'
# This is needed, otherwise 'make test' will run before binaries have been built # This is needed, otherwise 'make test' will run before binaries have been built

3
debian/salsa-ci.yml vendored
View file

@ -33,7 +33,8 @@ build:
- export CCACHE_DIR="${CCACHE_TMP_DIR}" - export CCACHE_DIR="${CCACHE_TMP_DIR}"
- update-ccache-symlinks; ccache -z # Zero out ccache counters - update-ccache-symlinks; ccache -z # Zero out ccache counters
- mk-build-deps debian/control -t "apt-get -y -o Debug::pkgProblemResolver=yes --no-install-recommends" -r -i - mk-build-deps debian/control -t "apt-get -y -o Debug::pkgProblemResolver=yes --no-install-recommends" -r -i
- debian/autobake-deb.sh - while true; do sleep 600; echo "10 minutes passed" >&2; done & # Progress keeper since build is long and silent
- debian/autobake-deb.sh |& tail -n 10000 # Keep Gitlab-CI output under 4 MB
- cd ..; rm -rfv *.tmp # Clean away build files not to store as artifacts - cd ..; rm -rfv *.tmp # Clean away build files not to store as artifacts
- cp -v *.* ${WORKING_DIR}/ - cp -v *.* ${WORKING_DIR}/
- du -shc ${WORKING_DIR}/* # Show total file size of artifacts. Must stay are under 100 MB. - du -shc ${WORKING_DIR}/* # Show total file size of artifacts. Must stay are under 100 MB.