FROM registry.fedoraproject.org/fedora:26 # MySQL image for OpenShift. # # Volumes: # * /var/lib/mysql/data - Datastore for MySQL # Environment: # * $MYSQL_USER - Database user name # * $MYSQL_PASSWORD - User's password # * $MYSQL_DATABASE - Name of the database to create # * $MYSQL_ROOT_PASSWORD (Optional) - Password for the 'root' MySQL account ENV MYSQL_VERSION=5.7 \ HOME=/var/lib/mysql ENV SUMMARY="MySQL 5.7 SQL database server" \ DESCRIPTION="MySQL is a multi-user, multi-threaded SQL database server. The container \ image provides a containerized packaging of the MySQL mysqld daemon and client application. \ The mysqld server daemon accepts connections from clients and provides access to content from \ MySQL databases on behalf of the clients." ENV NAME=mysql \ VERSION=0 \ RELEASE=1 \ ARCH=x86_64 LABEL summary="$SUMMARY" \ description="$DESCRIPTION" \ io.k8s.description="$DESCRIPTION" \ io.k8s.display-name="MySQL 5.7" \ io.openshift.expose-services="3306:mysql" \ io.openshift.tags="database,mysql,mysql57,rh-mysql57" \ com.redhat.component="$NAME" \ name="$FGC/$NAME" \ version="$VERSION" \ release="$RELEASE.$DISTTAG" \ architecture="$ARCH" \ usage="docker run -d -e MYSQL_USER=user -e MYSQL_PASSWORD=pass -e MYSQL_DATABASE=db -p 3306:3306 rhscl/mysql-57-rhel7" \ maintainer="SoftwareCollections.org " EXPOSE 3306 # On Fedora, we fake missing python binary. In case user installs the python2 # in the container, this hack will be removed by installing /usr/bin/python from RPM. RUN ln -s /usr/bin/python3 /usr/bin/python # This image must forever use UID 27 for mysql user so our volumes are # safe in the future. This should *never* change, the last test is there # to make sure of that. RUN INSTALL_PKGS="rsync tar gettext hostname bind-utils community-mysql-server policycoreutils" && \ yum install -y --setopt=tsflags=nodocs $INSTALL_PKGS && \ rpm -V $INSTALL_PKGS && \ yum clean all && \ mkdir -p /var/lib/mysql/data && chown -R mysql.0 /var/lib/mysql && \ test "$(id mysql)" = "uid=27(mysql) gid=27(mysql) groups=27(mysql)" # Get prefix path and path to scripts rather than hard-code them in scripts ENV CONTAINER_SCRIPTS_PATH=/usr/share/container-scripts/mysql \ MYSQL_PREFIX=/usr COPY root / COPY README.md /README.md # this is needed due to issues with squash # when this directory gets rm'd by the container-setup # script. RUN rm -rf /etc/my.cnf.d/* RUN /usr/libexec/container-setup VOLUME ["/var/lib/mysql/data"] USER 27 ENTRYPOINT ["container-entrypoint"] CMD ["run-mysqld"]