| # Copyright 1999-2015 Gentoo Foundation |
| # Distributed under the terms of the GNU General Public License v2 |
| # $Id$ |
| |
| # @ECLASS: mysql-multilib.eclass |
| # @MAINTAINER: |
| # Maintainers: |
| # - MySQL Team <mysql-bugs@gentoo.org> |
| # - Robin H. Johnson <robbat2@gentoo.org> |
| # - Jorge Manuel B. S. Vicetto <jmbsvicetto@gentoo.org> |
| # - Brian Evans <grknight@gentoo.org> |
| # @BLURB: This eclass provides most of the functions for mysql ebuilds |
| # @DESCRIPTION: |
| # The mysql-multilib.eclass is the base eclass to build the mysql and |
| # alternative projects (mariadb and percona) ebuilds. |
| # This eclass uses the mysql-cmake eclass for the |
| # specific bits related to the build system. |
| # It provides the src_unpack, src_prepare, src_configure, src_compile, |
| # src_install, pkg_preinst, pkg_postinst, pkg_config and pkg_postrm |
| # phase hooks. |
| |
| MYSQL_EXTRAS="" |
| |
| # @ECLASS-VARIABLE: MYSQL_EXTRAS_VER |
| # @DESCRIPTION: |
| # The version of the MYSQL_EXTRAS repo to use to build mysql |
| # Use "none" to disable it's use |
| [[ ${MY_EXTRAS_VER} == "live" ]] && MYSQL_EXTRAS="git-r3" |
| |
| inherit eutils systemd flag-o-matic ${MYSQL_EXTRAS} mysql-cmake mysql_fx versionator \ |
| toolchain-funcs user cmake-utils multilib-minimal |
| |
| # |
| # Supported EAPI versions and export functions |
| # |
| |
| case "${EAPI:-0}" in |
| 5) ;; |
| *) die "Unsupported EAPI: ${EAPI}" ;; |
| esac |
| |
| EXPORT_FUNCTIONS pkg_pretend pkg_setup src_unpack src_prepare src_configure src_compile src_install pkg_preinst pkg_postinst pkg_config |
| |
| # |
| # VARIABLES: |
| # |
| |
| # @ECLASS-VARIABLE: MYSQL_CMAKE_NATIVE_DEFINES |
| # @DESCRIPTION: |
| # Add extra CMake arguments for native multilib builds |
| |
| # @ECLASS-VARIABLE: MYSQL_CMAKE_NONNATIVE_DEFINES |
| # @DESCRIPTION: |
| # Add extra CMake arguments for non-native multilib builds |
| |
| # @ECLASS-VARIABLE: MYSQL_CMAKE_EXTRA_DEFINES |
| # @DESCRIPTION: |
| # Add extra CMake arguments |
| |
| # Shorten the path because the socket path length must be shorter than 107 chars |
| # and we will run a mysql server during test phase |
| S="${WORKDIR}/mysql" |
| |
| [[ ${MY_EXTRAS_VER} == "latest" ]] && MY_EXTRAS_VER="20090228-0714Z" |
| if [[ ${MY_EXTRAS_VER} == "live" ]]; then |
| EGIT_REPO_URI="git://anongit.gentoo.org/proj/mysql-extras.git" |
| EGIT_CHECKOUT_DIR=${WORKDIR}/mysql-extras |
| EGIT_CLONE_TYPE=shallow |
| fi |
| |
| # @ECLASS-VARIABLE: MYSQL_PV_MAJOR |
| # @DESCRIPTION: |
| # Upstream MySQL considers the first two parts of the version number to be the |
| # major version. Upgrades that change major version should always run |
| # mysql_upgrade. |
| MYSQL_PV_MAJOR="$(get_version_component_range 1-2 ${PV})" |
| |
| # Cluster is a special case... |
| if [[ "${PN}" == "mysql-cluster" ]]; then |
| case $PV in |
| 7.2*) MYSQL_PV_MAJOR=5.5 ;; |
| 7.3*) MYSQL_PV_MAJOR=5.6 ;; |
| esac |
| fi |
| |
| # MariaDB has left the numbering schema but keeping compatibility |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]]; then |
| case ${PV} in |
| 10.0*) MYSQL_PV_MAJOR="5.6" ;; |
| 10.1*) MYSQL_PV_MAJOR="5.6" ;; |
| esac |
| fi |
| |
| # @ECLASS-VARIABLE: MYSQL_VERSION_ID |
| # @DESCRIPTION: |
| # MYSQL_VERSION_ID will be: |
| # major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99] |
| # This is an important part, because many of the choices the MySQL ebuild will do |
| # depend on this variable. |
| # In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803" |
| # We also strip off upstream's trailing letter that they use to respin tarballs |
| MYSQL_VERSION_ID="" |
| tpv="${PV%[a-z]}" |
| tpv=( ${tpv//[-._]/ } ) ; tpv[3]="${PVR:${#PV}}" ; tpv[3]="${tpv[3]##*-r}" |
| for vatom in 0 1 2 3 ; do |
| # pad to length 2 |
| tpv[${vatom}]="00${tpv[${vatom}]}" |
| MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}" |
| done |
| # strip leading "0" (otherwise it's considered an octal number by BASH) |
| MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"} |
| |
| # This eclass should only be used with at least mysql-5.5.35 |
| mysql_version_is_at_least "5.5.35" || die "This eclass should only be used with >=mysql-5.5.35" |
| |
| # Work out the default SERVER_URI correctly |
| if [[ -z ${SERVER_URI} ]]; then |
| [[ -z ${MY_PV} ]] && MY_PV="${PV//_/-}" |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]]; then |
| # Beginning with 5.5, MariaDB stopped putting beta, alpha or rc on their tarball names |
| mysql_version_is_at_least "5.5" && MARIA_FULL_PV=$(get_version_component_range 1-3) || \ |
| MARIA_FULL_PV=$(replace_version_separator 3 '-' ${MY_PV}) |
| MARIA_FULL_P="${PN}-${MARIA_FULL_PV}" |
| SERVER_URI=" |
| http://ftp.osuosl.org/pub/mariadb/${MARIA_FULL_P}/source/${MARIA_FULL_P}.tar.gz |
| http://mirror.jmu.edu/pub/mariadb/${MARIA_FULL_P}/source/${MARIA_FULL_P}.tar.gz |
| http://mirrors.coreix.net/mariadb/${MARIA_FULL_P}/source/${MARIA_FULL_P}.tar.gz |
| http://mirrors.syringanetworks.net/mariadb/${MARIA_FULL_P}/source/${MARIA_FULL_P}.tar.gz |
| http://mirrors.fe.up.pt/pub/mariadb/${MARIA_FULL_P}/source/${MARIA_FULL_P}.tar.gz |
| http://mirror2.hs-esslingen.de/mariadb/${MARIA_FULL_P}/source/${MARIA_FULL_P}.tar.gz |
| http://ftp.osuosl.org/pub/mariadb/${MARIA_FULL_P}/kvm-tarbake-jaunty-x86/${MARIA_FULL_P}.tar.gz |
| http://mirror.jmu.edu/pub/mariadb/${MARIA_FULL_P}/kvm-tarbake-jaunty-x86/${MARIA_FULL_P}.tar.gz |
| http://mirrors.coreix.net/mariadb/${MARIA_FULL_P}/kvm-tarbake-jaunty-x86/${MARIA_FULL_P}.tar.gz |
| http://mirrors.syringanetworks.net/mariadb/${MARIA_FULL_P}/kvm-tarbake-jaunty-x86/${MARIA_FULL_P}.tar.gz |
| http://mirrors.fe.up.pt/pub/mariadb/${MARIA_FULL_P}/kvm-tarbake-jaunty-x86/${MARIA_FULL_P}.tar.gz |
| http://mirror2.hs-esslingen.de/mariadb/${MARIA_FULL_P}/kvm-tarbake-jaunty-x86/${MARIA_FULL_P}.tar.gz |
| " |
| if [[ ${PN} == "mariadb-galera" ]]; then |
| MY_SOURCEDIR="${PN%%-galera}-${MARIA_FULL_PV}" |
| fi |
| elif [[ ${PN} == "percona-server" ]]; then |
| PERCONA_PN="Percona-Server" |
| MIRROR_PV=$(get_version_component_range 1-2 ${PV}) |
| MY_PV=$(get_version_component_range 1-3 ${PV}) |
| PERCONA_RELEASE=$(get_version_component_range 4-5 ${PV}) |
| PERCONA_RC=$(get_version_component_range 6 ${PV}) |
| SERVER_URI="http://www.percona.com/redir/downloads/${PERCONA_PN}-${MIRROR_PV}/${PERCONA_PN}-${MY_PV}-${PERCONA_RC}${PERCONA_RELEASE}/source/tarball/${PN}-${MY_PV}-${PERCONA_RC}${PERCONA_RELEASE}.tar.gz" |
| # http://www.percona.com/redir/downloads/Percona-Server-5.5/LATEST/source/tarball/Percona-Server-5.5.30-rel30.2.tar.gz |
| # http://www.percona.com/redir/downloads/Percona-Server-5.6/Percona-Server-5.6.13-rc60.5/source/tarball/Percona-Server-5.6.13-rc60.5.tar.gz |
| else |
| if [[ "${PN}" == "mysql-cluster" ]] ; then |
| URI_DIR="MySQL-Cluster" |
| URI_FILE="mysql-cluster-gpl" |
| else |
| URI_DIR="MySQL" |
| URI_FILE="mysql" |
| fi |
| URI_A="${URI_FILE}-${MY_PV}.tar.gz" |
| MIRROR_PV=$(get_version_component_range 1-2 ${PV}) |
| # Recently upstream switched to an archive site, and not on mirrors |
| SERVER_URI="http://downloads.mysql.com/archives/${URI_FILE}-${MIRROR_PV}/${URI_A} |
| mirror://mysql/Downloads/${URI_DIR}-${PV%.*}/${URI_A}" |
| fi |
| fi |
| |
| # Define correct SRC_URIs |
| SRC_URI="${SERVER_URI}" |
| |
| # Gentoo patches to MySQL |
| if [[ ${MY_EXTRAS_VER} != "live" && ${MY_EXTRAS_VER} != "none" ]]; then |
| SRC_URI="${SRC_URI} |
| mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 |
| https://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 |
| https://dev.gentoo.org/~jmbsvicetto/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 |
| https://dev.gentoo.org/~grknight/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2" |
| fi |
| |
| DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" |
| HOMEPAGE="http://www.mysql.com/" |
| if [[ ${PN} == "mariadb" ]]; then |
| HOMEPAGE="http://mariadb.org/" |
| DESCRIPTION="An enhanced, drop-in replacement for MySQL" |
| fi |
| if [[ ${PN} == "mariadb-galera" ]]; then |
| HOMEPAGE="http://mariadb.org/" |
| DESCRIPTION="An enhanced, drop-in replacement for MySQL with Galera Replication" |
| fi |
| if [[ ${PN} == "percona-server" ]]; then |
| HOMEPAGE="http://www.percona.com/software/percona-server" |
| DESCRIPTION="An enhanced, drop-in replacement for MySQL from the Percona team" |
| fi |
| LICENSE="GPL-2" |
| SLOT="0/${SUBSLOT:-0}" |
| |
| IUSE="debug embedded extraengine jemalloc latin1 libressl +openssl |
| +perl profiling selinux systemtap static static-libs tcmalloc test yassl" |
| |
| REQUIRED_USE="^^ ( yassl openssl libressl )" |
| |
| ### Begin readline/libedit |
| ### If the world was perfect, we would use external libedit on both to have a similar experience |
| ### However libedit does not seem to support UTF-8 keyboard input |
| |
| # This probably could be simplified, but the syntax would have to be just right |
| #if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] && \ |
| # mysql_check_version_range "5.5.37 to 10.0.13.99" ; then |
| # IUSE="bindist ${IUSE}" |
| #elif [[ ${PN} == "mysql" || ${PN} == "percona-server" ]] && \ |
| # mysql_check_version_range "5.5.37 to 5.6.11.99" ; then |
| # IUSE="bindist ${IUSE}" |
| #elif [[ ${PN} == "mysql-cluster" ]] && \ |
| # mysql_check_version_range "7.2 to 7.2.99.99" ; then |
| # IUSE="bindist ${IUSE}" |
| #fi |
| |
| # Tests always fail when libressl is enabled due to hard-coded ciphers in the tests |
| RESTRICT="libressl? ( test )" |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] ; then |
| IUSE="bindist ${IUSE}" |
| RESTRICT="${RESTRICT} !bindist? ( bindist )" |
| fi |
| |
| ### End readline/libedit |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]]; then |
| IUSE="${IUSE} oqgraph pam sphinx tokudb" |
| # 5.5.33 and 10.0.5 add TokuDB. Authors strongly recommend jemalloc or perfomance suffers |
| mysql_version_is_at_least "10.0.5" && IUSE="${IUSE} odbc xml" |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| REQUIRED_USE="${REQUIRED_USE} !server? ( !oqgraph !sphinx ) tokudb? ( jemalloc )" |
| else |
| REQUIRED_USE="${REQUIRED_USE} minimal? ( !oqgraph !sphinx ) tokudb? ( jemalloc )" |
| fi |
| # MariaDB 10.1 introduces InnoDB/XtraDB compression with external libraries |
| # Choices are bzip2, lz4, lzma, lzo. bzip2 and lzma enabled by default as they are system libraries |
| mysql_version_is_at_least "10.1.1" && IUSE="${IUSE} innodb-lz4 innodb-lzo" |
| |
| # It can also compress with app-arch/snappy |
| mysql_version_is_at_least "10.1.7" && IUSE="${IUSE} innodb-snappy" |
| |
| # 10.1.2 introduces a cracklib password checker |
| mysql_version_is_at_least "10.1.1" && IUSE="${IUSE} cracklib" |
| fi |
| |
| if [[ -n "${WSREP_REVISION}" ]]; then |
| if [[ ${PN} == "mariadb" ]]; then |
| IUSE="${IUSE} galera sst-rsync sst-xtrabackup" |
| REQUIRED_USE="${REQUIRED_USE} sst-rsync? ( galera ) sst-xtrabackup? ( galera )" |
| else |
| IUSE="${IUSE} +sst-rsync sst-xtrabackup" |
| fi |
| fi |
| |
| if [[ ${PN} == "percona-server" ]]; then |
| IUSE="${IUSE} pam" |
| fi |
| |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| IUSE="${IUSE} client-libs +server +tools" |
| REQUIRED_USE="${REQUIRED_USE} !server? ( !extraengine !embedded ) server? ( tools ) || ( client-libs server tools )" |
| else |
| IUSE="${IUSE} minimal" |
| REQUIRED_USE="${REQUIRED_USE} minimal? ( !extraengine !embedded )" |
| fi |
| |
| REQUIRED_USE=" |
| ${REQUIRED_USE} tcmalloc? ( !jemalloc ) jemalloc? ( !tcmalloc ) |
| static? ( yassl )" |
| |
| # |
| # DEPENDENCIES: |
| # |
| |
| # Be warned, *DEPEND are version-dependant |
| # These are used for both runtime and compiletime |
| # MULTILIB_USEDEP only set for libraries used by the client library |
| DEPEND=" |
| kernel_linux? ( |
| sys-process/procps:0= |
| dev-libs/libaio:0= |
| ) |
| >=sys-apps/sed-4 |
| >=sys-apps/texinfo-4.7-r1 |
| !dev-db/mariadb-native-client[mysqlcompat] |
| jemalloc? ( dev-libs/jemalloc:0= ) |
| tcmalloc? ( dev-util/google-perftools:0= ) |
| systemtap? ( >=dev-util/systemtap-1.3:0= ) |
| " |
| |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| DEPEND+=" |
| client-libs? ( |
| openssl? ( >=dev-libs/openssl-1.0.0:0=[${MULTILIB_USEDEP},static-libs?] ) |
| libressl? ( dev-libs/libressl:0=[${MULTILIB_USEDEP},static-libs?] ) |
| >=sys-libs/zlib-1.2.3:0=[${MULTILIB_USEDEP},static-libs?] |
| ) |
| !client-libs? ( |
| openssl? ( >=dev-libs/openssl-1.0.0:0=[static-libs?] ) |
| libressl? ( dev-libs/libressl:0=[static-libs?] ) |
| >=sys-libs/zlib-1.2.3:0=[static-libs?] |
| ) |
| tools? ( sys-libs/ncurses:0= ) embedded? ( sys-libs/ncurses:0= ) |
| " |
| else |
| DEPEND+=" |
| openssl? ( >=dev-libs/openssl-1.0.0:0=[${MULTILIB_USEDEP},static-libs?] ) |
| libressl? ( dev-libs/libressl:0=[${MULTILIB_USEDEP},static-libs?] ) |
| >=sys-libs/zlib-1.2.3:0=[${MULTILIB_USEDEP},static-libs?] |
| sys-libs/ncurses:0=[${MULTILIB_USEDEP}] |
| " |
| fi |
| |
| ### Begin readline/libedit |
| ### If the world was perfect, we would use external libedit on both to have a similar experience |
| ### However libedit does not seem to support UTF-8 keyboard input |
| |
| # dev-db/mysql-5.6.12+ only works with dev-libs/libedit |
| # mariadb 10.0.14 fixes libedit detection. changed to follow mysql |
| # This probably could be simplified |
| #if [[ ${PN} == "mysql" || ${PN} == "percona-server" ]] && \ |
| # mysql_version_is_at_least "5.6.12" ; then |
| # DEPEND="${DEPEND} dev-libs/libedit:0=[${MULTILIB_USEDEP}]" |
| #elif [[ ${PN} == "mysql-cluster" ]] && mysql_version_is_at_least "7.3"; then |
| # DEPEND="${DEPEND} dev-libs/libedit:0=[${MULTILIB_USEDEP}]" |
| #elif [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] && \ |
| # mysql_version_is_at_least "10.0.14" ; then |
| # DEPEND="${DEPEND} dev-libs/libedit:0=[${MULTILIB_USEDEP}]" |
| #else |
| # DEPEND="${DEPEND} !bindist? ( >=sys-libs/readline-4.1:0=[${MULTILIB_USEDEP}] )" |
| #fi |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] ; then |
| # Readline is only used for the command-line and embedded example |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| DEPEND="${DEPEND} !bindist? ( tools? ( >=sys-libs/readline-4.1:0= ) embedded? ( >=sys-libs/readline-4.1:0= ) )" |
| else |
| DEPEND="${DEPEND} !bindist? ( >=sys-libs/readline-4.1:0=[${MULTILIB_USEDEP}] )" |
| fi |
| fi |
| |
| ### End readline/libedit |
| |
| if [[ ${PN} == "mysql" || ${PN} == "percona-server" ]] ; then |
| if mysql_version_is_at_least "5.7.6" ; then DEPEND="${DEPEND} >=dev-libs/boost-1.57.0:0=" ; else |
| mysql_version_is_at_least "5.7.5" && DEPEND="${DEPEND} >=dev-libs/boost-1.56.0:0=" |
| fi |
| fi |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] ; then |
| # Bug 441700 MariaDB >=5.3 include custom mytop |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| DEPEND="${DEPEND} server? ( pam? ( virtual/pam:0= ) )" |
| else |
| DEPEND="${DEPEND} !minimal? ( pam? ( virtual/pam:0= ) )" |
| fi |
| DEPEND="${DEPEND} |
| oqgraph? ( >=dev-libs/boost-1.40.0:0= ) |
| perl? ( !dev-db/mytop )" |
| if mysql_version_is_at_least "10.0.5" ; then |
| DEPEND="${DEPEND} |
| extraengine? ( |
| odbc? ( dev-db/unixODBC:0= ) |
| xml? ( dev-libs/libxml2:2= ) |
| ) |
| " |
| fi |
| mysql_version_is_at_least "10.0.7" && DEPEND="${DEPEND} oqgraph? ( dev-libs/judy:0= )" |
| mysql_version_is_at_least "10.0.9" && DEPEND="${DEPEND} >=dev-libs/libpcre-8.35:3=" |
| |
| mysql_version_is_at_least "10.1.1" && DEPEND="${DEPEND} |
| innodb-lz4? ( app-arch/lz4 ) |
| innodb-lzo? ( dev-libs/lzo ) |
| " |
| |
| mysql_version_is_at_least "10.1.2" && DEPEND="${DEPEND} cracklib? ( sys-libs/cracklib:0= )" |
| mysql_version_is_at_least "10.1.7" && DEPEND="${DEPEND} innodb-snappy? ( app-arch/snappy )" |
| fi |
| |
| if [[ ${PN} == "percona-server" ]] ; then |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| DEPEND="${DEPEND} server? ( pam? ( virtual/pam:0= ) )" |
| else |
| DEPEND="${DEPEND} !minimal? ( pam? ( virtual/pam:0= ) )" |
| fi |
| fi |
| |
| # Having different flavours at the same time is not a good idea |
| for i in "mysql" "mariadb" "mariadb-galera" "percona-server" "mysql-cluster" ; do |
| [[ ${i} == ${PN} ]] || |
| DEPEND="${DEPEND} !dev-db/${i}" |
| done |
| |
| if [[ ${PN} == "mysql-cluster" ]] ; then |
| # TODO: This really should include net-misc/memcached |
| # but the package does not install the files it seeks. |
| mysql_version_is_at_least "7.2.3" && \ |
| DEPEND="${DEPEND} dev-libs/libevent:0=" |
| fi |
| |
| # prefix: first need to implement something for #196294 |
| # TODO: check emul-linux-x86-db dep when it is multilib enabled |
| RDEPEND="${DEPEND} |
| selinux? ( sec-policy/selinux-mysql ) |
| abi_x86_32? ( !app-emulation/emul-linux-x86-db[-abi_x86_32(-)] ) |
| " |
| |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| RDEPEND="${RDEPEND} |
| server? ( !prefix? ( dev-db/mysql-init-scripts ) ) |
| !client-libs? ( virtual/libmysqlclient ) |
| !<virtual/mysql-5.6-r4" |
| else |
| RDEPEND="${RDEPEND} !minimal? ( !prefix? ( dev-db/mysql-init-scripts ) )" |
| fi |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] ; then |
| # Bug 455016 Add dependencies of mytop |
| RDEPEND="${RDEPEND} perl? ( |
| virtual/perl-Getopt-Long |
| dev-perl/TermReadKey |
| virtual/perl-Term-ANSIColor |
| virtual/perl-Time-HiRes ) " |
| fi |
| |
| # @ECLASS-VARIABLE: WSREP_REVISION |
| # @DEFAULT_UNSET |
| # @DESCRIPTION: |
| # Version of the sys-cluster/galera API (major version in portage) to use for galera clustering |
| |
| if [[ -n "${WSREP_REVISION}" ]] ; then |
| # The wsrep API version must match between the ebuild and sys-cluster/galera. |
| # This will be indicated by WSREP_REVISION in the ebuild and the first number |
| # in the version of sys-cluster/galera |
| # |
| # lsof is required as of 5.5.38 and 10.0.11 for the rsync sst |
| |
| GALERA_RDEPEND="sys-apps/iproute2 |
| =sys-cluster/galera-${WSREP_REVISION}* |
| " |
| if [[ ${PN} == "mariadb" ]]; then |
| GALERA_RDEPEND="galera? ( ${GALERA_RDEPEND} )" |
| fi |
| RDEPEND="${RDEPEND} ${GALERA_RDEPEND} |
| sst-rsync? ( sys-process/lsof ) |
| sst-xtrabackup? ( |
| net-misc/socat[ssl] |
| ) |
| " |
| # Causes a circular dependency if DBD-mysql is not already installed |
| PDEPEND="${PDEPEND} sst-xtrabackup? ( >=dev-db/xtrabackup-bin-2.2.4 )" |
| fi |
| |
| if [[ ${PN} == "mysql-cluster" ]] ; then |
| mysql_version_is_at_least "7.2.9" && RDEPEND="${RDEPEND} java? ( >=virtual/jre-1.6 )" && \ |
| DEPEND="${DEPEND} java? ( >=virtual/jdk-1.6 )" |
| fi |
| |
| # compile-time-only |
| # ncurses only needs multilib for compile time due to a binary that will be not installed |
| DEPEND="${DEPEND} |
| virtual/yacc |
| static? ( sys-libs/ncurses[static-libs] ) |
| >=dev-util/cmake-2.8.9 |
| " |
| |
| # Transition dep until all ebuilds have client-libs patch and USE |
| if ! [[ ${HAS_TOOLS_PATCH} ]] ; then |
| DEPEND="${DEPEND} sys-libs/ncurses[${MULTILIB_USEDEP}]" |
| fi |
| |
| # For other stuff to bring us in |
| # dev-perl/DBD-mysql is needed by some scripts installed by MySQL |
| PDEPEND="${PDEPEND} perl? ( >=dev-perl/DBD-mysql-2.9004 ) |
| ~virtual/mysql-${MYSQL_PV_MAJOR}" |
| |
| # my_config.h includes ABI specific data |
| MULTILIB_WRAPPED_HEADERS=( /usr/include/mysql/my_config.h /usr/include/mysql/private/embedded_priv.h ) |
| |
| [[ ${PN} == "mysql-cluster" ]] && \ |
| MULTILIB_WRAPPED_HEADERS+=( /usr/include/mysql/storage/ndb/ndb_types.h ) |
| |
| [[ ${PN} == "mariadb" ]] && mysql_version_is_at_least "10.1.1" && \ |
| MULTILIB_WRAPPED_HEADERS+=( /usr/include/mysql/mysql_version.h ) |
| |
| # |
| # HELPER FUNCTIONS: |
| # |
| |
| # @FUNCTION: mysql-multilib_disable_test |
| # @DESCRIPTION: |
| # Helper function to disable specific tests. |
| mysql-multilib_disable_test() { |
| mysql-cmake_disable_test "$@" |
| } |
| |
| # |
| # EBUILD FUNCTIONS |
| # |
| |
| # @FUNCTION: mysql-multilib_pkg_pretend |
| # @DESCRIPTION: |
| # Perform some basic tests and tasks during pkg_pretend phase: |
| mysql-multilib_pkg_pretend() { |
| if [[ ${MERGE_TYPE} != binary ]] ; then |
| local GCC_MAJOR_SET=$(gcc-major-version) |
| local GCC_MINOR_SET=$(gcc-minor-version) |
| if use_if_iuse tokudb && [[ ${GCC_MAJOR_SET} -lt 4 || \ |
| ${GCC_MAJOR_SET} -eq 4 && ${GCC_MINOR_SET} -lt 7 ]] ; then |
| eerror "${PN} with tokudb needs to be built with gcc-4.7 or later." |
| eerror "Please use gcc-config to switch to gcc-4.7 or later version." |
| die |
| fi |
| # Bug 565584. InnoDB now requires atomic functions introduced with gcc-4.7 on |
| # non x86{,_64} arches |
| if ! use amd64 && ! use x86 && [[ ${GCC_MAJOR_SET} -lt 4 || \ |
| ${GCC_MAJOR_SET} -eq 4 && ${GCC_MINOR_SET} -lt 7 ]] ; then |
| eerror "${PN} needs to be built with gcc-4.7 or later." |
| eerror "Please use gcc-config to switch to gcc-4.7 or later version." |
| die |
| fi |
| fi |
| } |
| |
| # @FUNCTION: mysql-multilib_pkg_setup |
| # @DESCRIPTION: |
| # Perform some basic tests and tasks during pkg_setup phase: |
| # die if FEATURES="test", USE="-minimal" and not using FEATURES="userpriv" |
| # create new user and group for mysql |
| # warn about deprecated features |
| mysql-multilib_pkg_setup() { |
| |
| if has test ${FEATURES} ; then |
| if use_if_iuse minimal ; then |
| : |
| elif ! in_iuse server || use_if_iuse server ; then |
| if ! has userpriv ${FEATURES} ; then |
| eerror "Testing with FEATURES=-userpriv is no longer supported by upstream. Tests MUST be run as non-root." |
| fi |
| fi |
| fi |
| |
| # This should come after all of the die statements |
| enewgroup mysql 60 || die "problem adding 'mysql' group" |
| enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user" |
| |
| if [[ ${PN} == "mysql-cluster" ]] ; then |
| mysql_version_is_at_least "7.2.9" && java-pkg-opt-2_pkg_setup |
| fi |
| } |
| |
| # @FUNCTION: mysql-multilib_src_unpack |
| # @DESCRIPTION: |
| # Unpack the source code |
| mysql-multilib_src_unpack() { |
| |
| # Initialize the proper variables first |
| mysql_init_vars |
| |
| unpack ${A} |
| # Grab the patches |
| [[ "${MY_EXTRAS_VER}" == "live" ]] && S="${WORKDIR}/mysql-extras" git-r3_src_unpack |
| |
| mv -f "${WORKDIR}/${MY_SOURCEDIR}" "${S}" |
| } |
| |
| # @FUNCTION: mysql-multilib_src_prepare |
| # @DESCRIPTION: |
| # Apply patches to the source code and remove unneeded bundled libs. |
| mysql-multilib_src_prepare() { |
| mysql-cmake_src_prepare "$@" |
| if [[ ${PN} == "mysql-cluster" ]] ; then |
| mysql_version_is_at_least "7.2.9" && java-pkg-opt-2_src_prepare |
| fi |
| } |
| |
| |
| # @FUNCTION: mysql-multilib_src_configure |
| # @DESCRIPTION: |
| # Configure mysql to build the code for Gentoo respecting the use flags. |
| mysql-multilib_src_configure() { |
| # Bug #114895, bug #110149 |
| filter-flags "-O" "-O[01]" |
| |
| CXXFLAGS="${CXXFLAGS} -fno-strict-aliasing" |
| CXXFLAGS="${CXXFLAGS} -felide-constructors" |
| # Causes linkage failures. Upstream bug #59607 removes it |
| if ! mysql_version_is_at_least "5.6" ; then |
| CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" |
| fi |
| # As of 5.7, exceptions are used! |
| if [[ ${PN} == "percona-server" ]] && mysql_version_is_at_least "5.6.26" ; then |
| CXXFLAGS="${CXXFLAGS} -fno-rtti" |
| elif ! mysql_version_is_at_least "5.7" ; then |
| CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-rtti" |
| fi |
| export CXXFLAGS |
| |
| # bug #283926, with GCC4.4, this is required to get correct behavior. |
| append-flags -fno-strict-aliasing |
| |
| # bug 508724 mariadb cannot use ld.gold |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] ; then |
| tc-ld-disable-gold |
| fi |
| |
| multilib-minimal_src_configure |
| } |
| |
| multilib_src_configure() { |
| |
| debug-print-function ${FUNCNAME} "$@" |
| |
| CMAKE_BUILD_TYPE="RelWithDebInfo" |
| |
| if ! multilib_is_native_abi && in_iuse client-libs ; then |
| if ! use client-libs ; then |
| einfo "Skipping multilib build due to client-libs USE disabled" |
| return 0 |
| fi |
| fi |
| |
| # debug hack wrt #497532 |
| mycmakeargs=( |
| -DCMAKE_C_FLAGS_RELWITHDEBINFO="$(usex debug "" "-DNDEBUG")" |
| -DCMAKE_CXX_FLAGS_RELWITHDEBINFO="$(usex debug "" "-DNDEBUG")" |
| -DCMAKE_INSTALL_PREFIX=${EPREFIX}/usr |
| -DMYSQL_DATADIR=${EPREFIX}/var/lib/mysql |
| -DSYSCONFDIR=${EPREFIX}/etc/mysql |
| -DINSTALL_BINDIR=bin |
| -DINSTALL_DOCDIR=share/doc/${PF} |
| -DINSTALL_DOCREADMEDIR=share/doc/${PF} |
| -DINSTALL_INCLUDEDIR=include/mysql |
| -DINSTALL_INFODIR=share/info |
| -DINSTALL_LIBDIR=$(get_libdir) |
| -DINSTALL_ELIBDIR=$(get_libdir)/mysql |
| -DINSTALL_MANDIR=share/man |
| -DINSTALL_MYSQLDATADIR=${EPREFIX}/var/lib/mysql |
| -DINSTALL_MYSQLSHAREDIR=share/mysql |
| -DINSTALL_MYSQLTESTDIR=share/mysql/mysql-test |
| -DINSTALL_PLUGINDIR=$(get_libdir)/mysql/plugin |
| -DINSTALL_SBINDIR=sbin |
| -DINSTALL_SCRIPTDIR=share/mysql/scripts |
| -DINSTALL_SQLBENCHDIR=share/mysql |
| -DINSTALL_SUPPORTFILESDIR=${EPREFIX}/usr/share/mysql |
| -DWITH_COMMENT="Gentoo Linux ${PF}" |
| $(cmake-utils_use_with test UNIT_TESTS) |
| -DWITH_LIBEDIT=0 |
| -DWITH_ZLIB=system |
| -DWITHOUT_LIBWRAP=1 |
| -DENABLED_LOCAL_INFILE=1 |
| -DMYSQL_UNIX_ADDR=${EPREFIX}/var/run/mysqld/mysqld.sock |
| -DINSTALL_UNIX_ADDRDIR=${EPREFIX}/var/run/mysqld/mysqld.sock |
| -DWITH_DEFAULT_COMPILER_OPTIONS=0 |
| -DWITH_DEFAULT_FEATURE_SET=0 |
| -DINSTALL_SYSTEMD_UNITDIR="$(systemd_get_unitdir)" |
| ) |
| |
| if in_iuse systemd ; then |
| mycmakeargs+=( -DWITH_SYSTEMD=$(usex systemd) ) |
| fi |
| |
| if use openssl || use libressl ; then |
| mycmakeargs+=( -DWITH_SSL=system ) |
| else |
| mycmakeargs+=( -DWITH_SSL=bundled ) |
| fi |
| |
| if in_iuse client-libs ; then |
| mycmakeargs+=( -DWITHOUT_CLIENTLIBS=$(usex client-libs 0 1) ) |
| fi |
| |
| if in_iuse tools ; then |
| if multilib_is_native_abi ; then |
| mycmakeargs+=( -DWITHOUT_TOOLS=$(usex tools 0 1) ) |
| else |
| mycmakeargs+=( -DWITHOUT_TOOLS=1 ) |
| fi |
| fi |
| |
| if in_iuse bindist ; then |
| # bfd.h is only used starting with 10.1 and can be controlled by NOT_FOR_DISTRIBUTION |
| if multilib_is_native_abi; then |
| mycmakeargs+=( |
| -DWITH_READLINE=$(usex bindist 1 0) |
| -DNOT_FOR_DISTRIBUTION=$(usex bindist 0 1) |
| ) |
| elif ! in_iuse client-libs ; then |
| mycmakeargs+=( |
| -DWITH_READLINE=1 |
| -DNOT_FOR_DISTRIBUTION=0 |
| ) |
| fi |
| fi |
| |
| ### TODO: make this system but issues with UTF-8 prevent it |
| mycmakeargs+=( -DWITH_EDITLINE=bundled ) |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] && multilib_is_native_abi ; then |
| mycmakeargs+=( |
| -DWITH_JEMALLOC=$(usex jemalloc system) |
| ) |
| |
| mysql_version_is_at_least "10.0.9" && mycmakeargs+=( -DWITH_PCRE=system ) |
| fi |
| |
| configure_cmake_locale |
| |
| if use_if_iuse minimal ; then |
| configure_cmake_minimal |
| elif in_iuse server ; then |
| if multilib_is_native_abi && use server ; then |
| configure_cmake_standard |
| else |
| configure_cmake_minimal |
| fi |
| else |
| if multilib_is_native_abi ; then |
| configure_cmake_standard |
| else |
| configure_cmake_minimal |
| fi |
| fi |
| |
| # systemtap only works on native ABI bug 530132 |
| if multilib_is_native_abi; then |
| mycmakeargs+=( $(cmake-utils_use_enable systemtap DTRACE) ) |
| [[ ${MYSQL_CMAKE_NATIVE_DEFINES} ]] && mycmakeargs+=( ${MYSQL_CMAKE_NATIVE_DEFINES} ) |
| else |
| mycmakeargs+=( -DENABLE_DTRACE=0 ) |
| [[ ${MYSQL_CMAKE_NONNATIVE_DEFINES} ]] && mycmakeargs+=( ${MYSQL_CMAKE_NONNATIVE_DEFINES} ) |
| fi |
| |
| [[ ${MYSQL_CMAKE_EXTRA_DEFINES} ]] && mycmakeargs+=( ${MYSQL_CMAKE_EXTRA_DEFINES} ) |
| |
| # Always build NDB with mysql-cluster for libndbclient |
| [[ ${PN} == "mysql-cluster" ]] && mycmakeargs+=( |
| -DWITH_NDBCLUSTER=1 -DWITH_PARTITION_STORAGE_ENGINE=1 |
| -DWITHOUT_PARTITION_STORAGE_ENGINE=0 ) |
| |
| cmake-utils_src_configure |
| } |
| |
| mysql-multilib_src_compile() { |
| local _cmake_args=( "${@}" ) |
| |
| multilib-minimal_src_compile |
| } |
| |
| multilib_src_compile() { |
| if ! multilib_is_native_abi && in_iuse client-libs ; then |
| if ! use client-libs ; then |
| return 0 |
| fi |
| fi |
| |
| cmake-utils_src_compile "${_cmake_args[@]}" |
| } |
| |
| |
| # @FUNCTION: mysql-multilib_src_install |
| # @DESCRIPTION: |
| # Install mysql. |
| mysql-multilib_src_install() { |
| if ! in_iuse client-libs || use_if_iuse client-libs ; then |
| # wrap the config script |
| MULTILIB_CHOST_TOOLS=( /usr/bin/mysql_config ) |
| fi |
| |
| if in_iuse client-libs && ! use client-libs ; then |
| multilib_foreach_abi multilib_src_install |
| else |
| multilib-minimal_src_install |
| fi |
| } |
| |
| multilib_src_install() { |
| debug-print-function ${FUNCNAME} "$@" |
| |
| if ! multilib_is_native_abi && in_iuse client-libs ; then |
| if ! use client-libs ; then |
| return 0 |
| fi |
| fi |
| |
| if multilib_is_native_abi; then |
| mysql-cmake_src_install |
| else |
| cmake-utils_src_install |
| if [[ "${PN}" == "mariadb" || "${PN}" == "mariadb-galera" ]] ; then |
| if use_if_iuse minimal ; then |
| : |
| elif use_if_iuse server || ! in_iuse server ; then |
| insinto /usr/include/mysql/private |
| doins "${S}"/sql/*.h |
| fi |
| fi |
| fi |
| } |
| |
| # @FUNCTION: mysql-multilib_pkg_preinst |
| # @DESCRIPTION: |
| # Call java-pkg-opt-2 eclass when mysql-cluster is installed |
| mysql-multilib_pkg_preinst() { |
| debug-print-function ${FUNCNAME} "$@" |
| |
| if [[ ${PN} == "mysql-cluster" ]] ; then |
| mysql_version_is_at_least "7.2.9" && java-pkg-opt-2_pkg_preinst |
| fi |
| # Here we need to see if the implementation switched client libraries |
| # First, we check if this is a new instance of the package and a client library already exists |
| # Then, we check if this package is rebuilt but the previous instance did not |
| # have the client-libs USE set. |
| # Instances which do not have a client-libs USE can only be replaced by a different provider |
| local SHOW_ABI_MESSAGE |
| if ! in_iuse client-libs || use_if_iuse client-libs ; then |
| if [[ -z ${REPLACING_VERSIONS} && -e "${EROOT}usr/$(get_libdir)/libmysqlclient.so" ]] ; then |
| SHOW_ABI_MESSAGE=1 |
| elif [[ ${REPLACING_VERSIONS} && -e "${EROOT}usr/$(get_libdir)/libmysqlclient.so" ]] && \ |
| in_iuse client-libs && has_version "${CATEGORY}/${PN}[-client-libs(+)]" ; then |
| SHOW_ABI_MESSAGE=1 |
| fi |
| |
| fi |
| if [[ ${SHOW_ABI_MESSAGE} ]] ; then |
| elog "Due to ABI changes when switching between different client libraries," |
| elog "revdep-rebuild must find and rebuild all packages linking to libmysqlclient." |
| elog "Please run: revdep-rebuild --library libmysqlclient.so.${SUBSLOT:-18}" |
| ewarn "Failure to run revdep-rebuild may cause issues with other programs or libraries" |
| fi |
| } |
| |
| # @FUNCTION: mysql-multilib_pkg_postinst |
| # @DESCRIPTION: |
| # Run post-installation tasks: |
| # create the dir for logfiles if non-existant |
| # touch the logfiles and secure them |
| # install scripts |
| # issue required steps for optional features |
| # issue deprecation warnings |
| mysql-multilib_pkg_postinst() { |
| debug-print-function ${FUNCNAME} "$@" |
| |
| # Make sure the vars are correctly initialized |
| mysql_init_vars |
| |
| # Check FEATURES="collision-protect" before removing this |
| [[ -d "${ROOT}${MY_LOGDIR}" ]] || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}" |
| |
| # Secure the logfiles |
| touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} |
| chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* |
| chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* |
| |
| # Minimal builds don't have the MySQL server |
| if use_if_iuse minimal ; then |
| : |
| elif ! in_iuse server || use_if_iuse server ; then |
| docinto "support-files" |
| for script in \ |
| support-files/my-*.cnf \ |
| support-files/magic \ |
| support-files/ndb-config-2-node.ini |
| do |
| [[ -f "${script}" ]] \ |
| && dodoc "${script}" |
| done |
| |
| docinto "scripts" |
| for script in scripts/mysql* ; do |
| if [[ -f "${script}" && "${script%.sh}" == "${script}" ]]; then |
| dodoc "${script}" |
| fi |
| done |
| |
| if [[ ${PN} == "mariadb" || ${PN} == "mariadb-galera" ]] ; then |
| if use_if_iuse pam ; then |
| einfo |
| elog "This install includes the PAM authentication plugin." |
| elog "To activate and configure the PAM plugin, please read:" |
| elog "https://mariadb.com/kb/en/mariadb/pam-authentication-plugin/" |
| einfo |
| fi |
| fi |
| |
| einfo |
| elog "You might want to run:" |
| elog "\"emerge --config =${CATEGORY}/${PF}\"" |
| elog "if this is a new install." |
| einfo |
| |
| einfo |
| elog "If you are upgrading major versions, you should run the" |
| elog "mysql_upgrade tool." |
| einfo |
| |
| if [[ ${PN} == "mariadb-galera" ]] || use_if_iuse galera ; then |
| einfo |
| elog "Be sure to edit the my.cnf file to activate your cluster settings." |
| elog "This should be done after running \"emerge --config =${CATEGORY}/${PF}\"" |
| elog "The first time the cluster is activated, you should add" |
| elog "--wsrep-new-cluster to the options in /etc/conf.d/mysql for one node." |
| elog "This option should then be removed for subsequent starts." |
| einfo |
| fi |
| fi |
| } |
| |
| # @FUNCTION: mysql-multilib_getopt |
| # @DESCRIPTION: |
| # Use my_print_defaults to extract specific config options |
| mysql-multilib_getopt() { |
| local mypd="${EROOT}"/usr/bin/my_print_defaults |
| section="$1" |
| flag="--${2}=" |
| "${mypd}" $section | sed -n "/^${flag}/p" |
| } |
| |
| # @FUNCTION: mysql-multilib_getoptval |
| # @DESCRIPTION: |
| # Use my_print_defaults to extract specific config options |
| mysql-multilib_getoptval() { |
| local mypd="${EROOT}"/usr/bin/my_print_defaults |
| local section="$1" |
| local flag="--${2}=" |
| local extra_options="${3}" |
| "${mypd}" $extra_options $section | sed -n "/^${flag}/s,${flag},,gp" |
| } |
| |
| # @FUNCTION: mysql-multilib_pkg_config |
| # @DESCRIPTION: |
| # Configure mysql environment. |
| mysql-multilib_pkg_config() { |
| |
| debug-print-function ${FUNCNAME} "$@" |
| |
| local old_MY_DATADIR="${MY_DATADIR}" |
| local old_HOME="${HOME}" |
| # my_print_defaults needs to read stuff in $HOME/.my.cnf |
| export HOME=${EPREFIX}/root |
| |
| # Make sure the vars are correctly initialized |
| mysql_init_vars |
| |
| [[ -z "${MY_DATADIR}" ]] && die "Sorry, unable to find MY_DATADIR" |
| if [[ ${HAS_TOOLS_PATCH} ]] ; then |
| if ! built_with_use ${CATEGORY}/${PN} server ; then |
| die "Minimal builds do NOT include the MySQL server" |
| fi |
| else |
| if built_with_use ${CATEGORY}/${PN} minimal ; then |
| die "Minimal builds do NOT include the MySQL server" |
| fi |
| fi |
| |
| if [[ ( -n "${MY_DATADIR}" ) && ( "${MY_DATADIR}" != "${old_MY_DATADIR}" ) ]]; then |
| local MY_DATADIR_s="${ROOT}/${MY_DATADIR}" |
| MY_DATADIR_s="${MY_DATADIR_s%%/}" |
| local old_MY_DATADIR_s="${ROOT}/${old_MY_DATADIR}" |
| old_MY_DATADIR_s="${old_MY_DATADIR_s%%/}" |
| |
| if [[ ( -d "${old_MY_DATADIR_s}" ) && ( "${old_MY_DATADIR_s}" != / ) ]]; then |
| if [[ -d "${MY_DATADIR_s}" ]]; then |
| ewarn "Both ${old_MY_DATADIR_s} and ${MY_DATADIR_s} exist" |
| ewarn "Attempting to use ${MY_DATADIR_s} and preserving ${old_MY_DATADIR_s}" |
| else |
| elog "Moving MY_DATADIR from ${old_MY_DATADIR_s} to ${MY_DATADIR_s}" |
| mv --strip-trailing-slashes -T "${old_MY_DATADIR_s}" "${MY_DATADIR_s}" \ |
| || die "Moving MY_DATADIR failed" |
| fi |
| else |
| ewarn "Previous MY_DATADIR (${old_MY_DATADIR_s}) does not exist" |
| if [[ -d "${MY_DATADIR_s}" ]]; then |
| ewarn "Attempting to use ${MY_DATADIR_s}" |
| else |
| eerror "New MY_DATADIR (${MY_DATADIR_s}) does not exist" |
| die "Configuration Failed! Please reinstall ${CATEGORY}/${PN}" |
| fi |
| fi |
| fi |
| |
| local pwd1="a" |
| local pwd2="b" |
| local maxtry=15 |
| |
| if [ -z "${MYSQL_ROOT_PASSWORD}" ]; then |
| MYSQL_ROOT_PASSWORD="$(mysql-multilib_getoptval 'client mysql' password)" |
| # Sometimes --show is required to display passwords in some implementations of my_print_defaults |
| if [[ "${MYSQL_ROOT_PASSWORD}" == '*****' ]]; then |
| MYSQL_ROOT_PASSWORD="$(mysql-multilib_getoptval 'client mysql' password --show)" |
| fi |
| fi |
| MYSQL_TMPDIR="$(mysql-multilib_getoptval mysqld tmpdir)" |
| # These are dir+prefix |
| MYSQL_RELAY_LOG="$(mysql-multilib_getoptval mysqld relay-log)" |
| MYSQL_RELAY_LOG=${MYSQL_RELAY_LOG%/*} |
| MYSQL_LOG_BIN="$(mysql-multilib_getoptval mysqld log-bin)" |
| MYSQL_LOG_BIN=${MYSQL_LOG_BIN%/*} |
| |
| if [[ ! -d "${ROOT}"/$MYSQL_TMPDIR ]]; then |
| einfo "Creating MySQL tmpdir $MYSQL_TMPDIR" |
| install -d -m 770 -o mysql -g mysql "${EROOT}"/$MYSQL_TMPDIR |
| fi |
| if [[ ! -d "${ROOT}"/$MYSQL_LOG_BIN ]]; then |
| einfo "Creating MySQL log-bin directory $MYSQL_LOG_BIN" |
| install -d -m 770 -o mysql -g mysql "${EROOT}"/$MYSQL_LOG_BIN |
| fi |
| if [[ ! -d "${EROOT}"/$MYSQL_RELAY_LOG ]]; then |
| einfo "Creating MySQL relay-log directory $MYSQL_RELAY_LOG" |
| install -d -m 770 -o mysql -g mysql "${EROOT}"/$MYSQL_RELAY_LOG |
| fi |
| |
| if [[ -d "${ROOT}/${MY_DATADIR}/mysql" ]] ; then |
| ewarn "You have already a MySQL database in place." |
| ewarn "(${ROOT}/${MY_DATADIR}/*)" |
| ewarn "Please rename or delete it if you wish to replace it." |
| die "MySQL database already exists!" |
| fi |
| |
| # Bug #213475 - MySQL _will_ object strenously if your machine is named |
| # localhost. Also causes weird failures. |
| [[ "${HOSTNAME}" == "localhost" ]] && die "Your machine must NOT be named localhost" |
| |
| if [ -z "${MYSQL_ROOT_PASSWORD}" ]; then |
| |
| einfo "Please provide a password for the mysql 'root' user now" |
| einfo "or through the ${HOME}/.my.cnf file." |
| ewarn "Avoid [\"'\\_%] characters in the password" |
| read -rsp " >" pwd1 ; echo |
| |
| einfo "Retype the password" |
| read -rsp " >" pwd2 ; echo |
| |
| if [[ "x$pwd1" != "x$pwd2" ]] ; then |
| die "Passwords are not the same" |
| fi |
| MYSQL_ROOT_PASSWORD="${pwd1}" |
| unset pwd1 pwd2 |
| fi |
| |
| local options |
| local sqltmp="$(emktemp)" |
| |
| # Fix bug 446200. Don't reference host my.cnf, needs to come first, |
| # see http://bugs.mysql.com/bug.php?id=31312 |
| use prefix && options="${options} '--defaults-file=${MY_SYSCONFDIR}/my.cnf'" |
| |
| local help_tables="${ROOT}${MY_SHAREDSTATEDIR}/fill_help_tables.sql" |
| [[ -r "${help_tables}" ]] \ |
| && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \ |
| || touch "${TMPDIR}/fill_help_tables.sql" |
| help_tables="${TMPDIR}/fill_help_tables.sql" |
| |
| # Figure out which options we need to disable to do the setup |
| local helpfile="${TMPDIR}/mysqld-help" |
| ${EROOT}/usr/sbin/mysqld --verbose --help >"${helpfile}" 2>/dev/null |
| for opt in grant-tables host-cache name-resolve networking slave-start \ |
| federated ssl log-bin relay-log slow-query-log external-locking \ |
| ndbcluster log-slave-updates \ |
| ; do |
| optexp="--(skip-)?${opt}" optfull="--loose-skip-${opt}" |
| egrep -sq -- "${optexp}" "${helpfile}" && options="${options} ${optfull}" |
| done |
| # But some options changed names |
| egrep -sq external-locking "${helpfile}" && \ |
| options="${options/skip-locking/skip-external-locking}" |
| |
| use prefix || options="${options} --user=mysql" |
| |
| # MySQL 5.6+ needs InnoDB |
| if [[ ${PN} == "mysql" || ${PN} == "percona-server" ]] ; then |
| mysql_version_is_at_least "5.6" || options="${options} --loose-skip-innodb" |
| fi |
| |
| einfo "Creating the mysql database and setting proper permissions on it ..." |
| |
| # Now that /var/run is a tmpfs mount point, we need to ensure it exists before using it |
| PID_DIR="${EROOT}/var/run/mysqld" |
| if [[ ! -d "${PID_DIR}" ]]; then |
| mkdir -p "${PID_DIR}" || die "Could not create pid directory" |
| chown mysql:mysql "${PID_DIR}" || die "Could not set ownership on pid directory" |
| chmod 755 "${PID_DIR}" || die "Could not set permissions on pid directory" |
| fi |
| |
| pushd "${TMPDIR}" &>/dev/null |
| #cmd="'${EROOT}/usr/share/mysql/scripts/mysql_install_db' '--basedir=${EPREFIX}/usr' ${options}" |
| cmd=${EROOT}usr/share/mysql/scripts/mysql_install_db |
| [[ -f ${cmd} ]] || cmd=${EROOT}usr/bin/mysql_install_db |
| cmd="'$cmd' '--basedir=${EPREFIX}/usr' ${options} '--datadir=${ROOT}/${MY_DATADIR}' '--tmpdir=${ROOT}/${MYSQL_TMPDIR}'" |
| einfo "Command: $cmd" |
| eval $cmd \ |
| >"${TMPDIR}"/mysql_install_db.log 2>&1 |
| if [ $? -ne 0 ]; then |
| grep -B5 -A999 -i "ERROR" "${TMPDIR}"/mysql_install_db.log 1>&2 |
| die "Failed to run mysql_install_db. Please review ${EPREFIX}/var/log/mysql/mysqld.err AND ${TMPDIR}/mysql_install_db.log" |
| fi |
| popd &>/dev/null |
| [[ -f "${ROOT}/${MY_DATADIR}/mysql/user.frm" ]] \ |
| || die "MySQL databases not installed" |
| chown -R mysql:mysql "${ROOT}/${MY_DATADIR}" 2>/dev/null |
| chmod 0750 "${ROOT}/${MY_DATADIR}" 2>/dev/null |
| |
| # Filling timezones, see |
| # http://dev.mysql.com/doc/mysql/en/time-zone-support.html |
| "${EROOT}/usr/bin/mysql_tzinfo_to_sql" "${EROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null |
| |
| if [[ -r "${help_tables}" ]] ; then |
| cat "${help_tables}" >> "${sqltmp}" |
| fi |
| |
| local socket="${EROOT}/var/run/mysqld/mysqld${RANDOM}.sock" |
| local pidfile="${EROOT}/var/run/mysqld/mysqld${RANDOM}.pid" |
| local mysqld="${EROOT}/usr/sbin/mysqld \ |
| ${options} \ |
| $(use prefix || echo --user=mysql) \ |
| --log-warnings=0 \ |
| --basedir=${EROOT}/usr \ |
| --datadir=${ROOT}/${MY_DATADIR} \ |
| --max_allowed_packet=8M \ |
| --net_buffer_length=16K \ |
| --default-storage-engine=MyISAM \ |
| --socket=${socket} \ |
| --pid-file=${pidfile} |
| --tmpdir=${ROOT}/${MYSQL_TMPDIR}" |
| #einfo "About to start mysqld: ${mysqld}" |
| ebegin "Starting mysqld" |
| einfo "Command ${mysqld}" |
| ${mysqld} & |
| rc=$? |
| while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do |
| maxtry=$((${maxtry}-1)) |
| echo -n "." |
| sleep 1 |
| done |
| eend $rc |
| |
| if ! [[ -S "${socket}" ]]; then |
| die "Completely failed to start up mysqld with: ${mysqld}" |
| fi |
| |
| ebegin "Setting root password" |
| # Do this from memory, as we don't want clear text passwords in temp files |
| local sql="UPDATE mysql.user SET Password = PASSWORD('${MYSQL_ROOT_PASSWORD}') WHERE USER='root'" |
| "${EROOT}/usr/bin/mysql" \ |
| --socket=${socket} \ |
| -hlocalhost \ |
| -e "${sql}" |
| eend $? |
| |
| ebegin "Loading \"zoneinfo\", this step may require a few seconds" |
| "${EROOT}/usr/bin/mysql" \ |
| --socket=${socket} \ |
| -hlocalhost \ |
| -uroot \ |
| --password="${MYSQL_ROOT_PASSWORD}" \ |
| mysql < "${sqltmp}" |
| rc=$? |
| eend $? |
| [[ $rc -ne 0 ]] && ewarn "Failed to load zoneinfo!" |
| |
| # Stop the server and cleanup |
| einfo "Stopping the server ..." |
| kill $(< "${pidfile}" ) |
| rm -f "${sqltmp}" |
| wait %1 |
| einfo "Done" |
| } |