# Rx3-Docker/MariaDB Docker Image #------------------------------------------------------------------------------- ARG IMG_FROM_URL="rx3-docker/server:latest" FROM ${IMG_FROM_URL} ARG IMG_NAME ARG IMG_NAME_FULL ARG IMG_VERSION ARG IMG_MAINTAINER LABEL org.rx3.${IMG_NAME}.name=${IMG_NAME_FULL} LABEL org.rx3.${IMG_NAME}.version=${IMG_VERSION} LABEL org.rx3.${IMG_NAME}.maintainer=${IMG_MAINTAINER} LABEL maintainer=${IMG_MAINTAINER} ARG MARIADDB_LIB ARG MARIADDB_LOG ARG MARIADDB_PORT ARG POSTSQL_LOG ARG MARIADB_LOG_FILE="${MARIADDB_LOG}/mariadb.err" ARG POSTSQL_LOG_FILE="${POSTSQL_LOG}/postsql.log" #--------------------------------------------------------------------------------------------------- ARG MYSQLD='#!/bin/bash \n\ \n\ usermod -u ${MARIADB_UID} mysql \n\ groupmod -g ${MARIADB_GID} mysql \n\ \n\ chown -R mysql:mysql '${MARIADDB_LIB}' '${MARIADDB_LOG}' /var/run/mysqld \n\ \n\ sed -i -e "s/^skip-networking/#skip-networking/" /etc/my.cnf.d/server.cnf \n\ sed -i -e "s%hostname$%hostname\\n\\nlog_error='${MARIADB_LOG_FILE}'%" /etc/my.cnf.d/server.cnf \n\ sed -i -e "s/^plugin-load-add=/#plugin-load-add=/" /etc/my.cnf.d/cracklib_password_check.cnf \n\ \n\ rm -Rf /var/log/mysqld* \n\ \n\ echo "CREATE USER `root`@`${MARIADB_ROOT_HOST}` IDENTIFIED BY `${MARIADB_ROOT_PASSWORD}`; \n\ GRANT ALL ON *.* TO `root`@`${MARIADB_ROOT_HOST}` WITH GRANT OPTION; \n\ GRANT PROXY ON ``@`%` TO `root`@`${MARIADB_ROOT_HOST}` WITH GRANT OPTION;" >>/tmp/post.sql \n\ \n\ if [[ -n "${MARIADB_DATABASE}" ]] \n\ then \n\ echo "CREATE DATABASE IF NOT EXISTS ${MARIADB_DATABASE};" >>/tmp/post.sql \n\ fi \n\ \n\ if [[ -n "${MARIADB_USER}" ]] && [[ -n "${MARIADB_PASSWORD}" ]] \n\ then \n\ echo "CREATE USER `${MARIADB_USER}`@`%` IDENTIFIED BY `${MARIADB_PASSWORD}`;">>/tmp/post.sql \n\ \n\ if [[ -n "${MARIADB_DATABASE}" ]] \n\ then \n\ echo "GRANT ALL ON ${MARIADB_DATABASE}.* TO `${MARIADB_USER}`@`%`;" >>/tmp/post.sql \n\ fi \n\ fi \n\ \n\ \n\ /usr/sbin/mysqld-prepare-db-dir' #--------------------------------------------------------------------------------------------------- #--------------------------------------------------------------------------------------------------- ARG MYSQLD_INI='[program:mysqld] \n\ command=/usr/sbin/mysqld' #--------------------------------------------------------------------------------------------------- #--------------------------------------------------------------------------------------------------- ARG POSTSQL='#!/bin/bash \n\ \n\ function log() { echo "$(date --rfc-3339=ns) PostSQL: $*" | tee -a '${POSTSQL_LOG_FILE}'; } \n\ \n\ log "Starting" \n\ \n\ for i in {30..0} \n\ do \n\ if mariadb <<< "SELECT 1" &> /dev/null \n\ then \n\ break \n\ fi \n\ \n\ sleep 1 \n\ done \n\ \n\ if [ "$i" = 0 ] \n\ then \n\ log "Unable to connect server" \n\ else \n\ while read line \n\ do \n\ log "Executing: [${line}]" \n\ echo ${line} | mariadb mysql \n\ done < /tmp/post.sql \n\ fi \n\ \n\ log "Completed"' #--------------------------------------------------------------------------------------------------- #--------------------------------------------------------------------------------------------------- ARG POSTSQL_INI='[program:postsql] \n\ command=/usr/local/sbin/postsql' #--------------------------------------------------------------------------------------------------- RUN urpmi --force mariadb \ && echo -e "${MYSQLD}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/mysqld \ && chmod a+x /etc/init.d/mysqld \ && ln -s /etc/init.d/mysqld /etc/rcD.d/S30mysqld \ && echo -e "${MYSQLD_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/supervisord.d/mysqld.ini \ && echo -e "${POSTSQL}" | sed -e "s/\`/'/g" -e 's/ *$//' > /usr/local/sbin/postsql \ && chmod a+x /usr/local/sbin/postsql \ && echo -e "${POSTSQL_INI}" | sed -e 's/ *$//' > /etc/supervisord.d/postsql.ini VOLUME ${MARIADDB_LIB} VOLUME ${MARIADDB_LOG} EXPOSE ${MARIADDB_PORT}