Docker exemple Dockerfile
Rédigé par Serge NOEL Aucun commentaireExemple de création d'un fichier Dockerfile.
Le conteneur officiel de MariaDB va re ré-écrit afin de maitriser totalement l'image.
Docker file pour MariaDB
L'image de départ est Alpine, on précise toujours la version
FROM alpine:3.7
Ajouter des informations (optionnellles) afin de préciser l'auteur, le but, ...
LABEL Author="Serge NOEL <serge.noel@net6a.com>" \
Description = "Image MariaDB"
Il est possible de définir des variables d'envirronnement (qui seront donc utilisables en tant que valeur par défaut)
ENV TIMEZONE Europe/Paris
ENV MYSQL_ROOT_PASSWORD Secr3t
Copier des fichiers dans l'image (script de démarrage)
ADD launch-db /usr/local/bin/launch-db
// Mise à jour de la liste des paquets, ajout des paquets nécessaires
RUN apk update \
&& apk add mariadb mariadb-client pwgen \
&& apk add --update tzdata \
&& cp /usr/share/zoneinfo/${TIMEZONE} /etc/localtime \
&& echo "${TIMEZONE}" > /etc/timezone \
&& chmod a+x /usr/local/bin/launch-db
Déclaration du ou des ports utilisé dans le conteneur
# Expose ports
EXPOSE 3306
Déclaration du point de montage
VOLUME ["/var/lib/mysql"]
Porgramme à lancer
# Entry point
ENTRYPOINT ["/usr/local/bin/launch-db"]
Détail de construction du fichier launch-db (script de démarrage)
Shebang, le fichier qui suit est le programme à lancer (/bin/sh)
#!/bin/sh
MariaDb à besoin du fichier /run/mysqld
if [ -d "/run/mysqld" ]; then
echo "[i] mysqld already present, skipping creation"
chown -R mysql:mysql /run/mysqld
else
echo "[i] mysqld not found, creating...."
mkdir -p /run/mysqld
chown -R mysql:mysql /run/mysqld
fi
Si le répertoire /var/lib/mysql/mysql existe cela signifie que le volume /var/lib/mysql contient une base. Sinon, il faut créer la base de donnée.
if [ -d /var/lib/mysql/mysql ]; then
echo "[i] MySQL directory already present, skipping creation"
chown -R mysql:mysql /var/lib/mysql
else
echo "[i] MySQL data directory not found, creating initial DBs"
chown -R mysql:mysql /var/lib/mysql
mysql_install_db --user=mysql > /dev/null
if [ "$MYSQL_ROOT_PASSWORD" = "" ]; then
MYSQL_ROOT_PASSWORD=`pwgen 16 1`
echo "[i] MySQL root Password: $MYSQL_ROOT_PASSWORD"
fi
MYSQL_DATABASE=${MYSQL_DATABASE:-""}
MYSQL_USER=${MYSQL_USER:-""}
MYSQL_PASSWORD=${MYSQL_PASSWORD:-""}
tfile=`mktemp`
if [ ! -f "$tfile" ]; then
return 1
fi
Création de la base de donnée
cat << EOF > $tfile
USE mysql;
FLUSH PRIVILEGES;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' identified by '$MYSQL_ROOT_PASSWORD' WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' identified by '$MYSQL_ROOT_PASSWORD' WITH GRANT OPTION;
UPDATE user SET password=PASSWORD("$MYSQL_ROOT_PASSWORD") WHERE user='root' AND host='localhost';
EOF
if [ "$MYSQL_DATABASE" != "" ]; then
echo "[i] Creating database: $MYSQL_DATABASE"
echo "CREATE DATABASE IF NOT EXISTS \`$MYSQL_DATABASE\` CHARACTER SET utf8 COLLATE utf8_general_ci;" >> $tfile
if [ "$MYSQL_USER" != "" ]; then
echo "[i] Creating user: $MYSQL_USER with password $MYSQL_PASSWORD"
echo "GRANT ALL ON \`$MYSQL_DATABASE\`.* to '$MYSQL_USER'@'%' IDENTIFIED BY '$MYSQL_PASSWORD';" >> $tfile
fi
fi
/usr/bin/mysqld --user=mysql --bootstrap --verbose=0 < $tfile
rm -f $tfile
fi
Tout est en ordre, on peut lancer le serveur, on utilise exec afin de transmettre les signaux SIGTERM (fermeture propre de l'appli)
exec /usr/bin/mysqld --user=mysql --console