写最好的Docker安装最新版MySQL8(mysql-8.0.31)教程(参考Docker Hub和MySQL官方文档)
# 使用官方的Debian为基础镜像
FROM debian:bullseye-slim
# 设置MySQL的版本环境变量
ENV MYSQL_VERSION 8.0.31
# 安装MySQL依赖和必要的系统库
RUN apt-get update && apt-get install -y \
gnupg \
ca-certificates \
netbase \
wget \
&& rm -rf /var/lib/apt/lists/*
# 下载MySQL的官方公钥,并验证其有效性
RUN wget https://repo.mysql.com/mysql-apt-config_0.8.20-1_all.deb \
&& apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 58712A2291FA5D13 \
&& dpkg -i mysql-apt-config_0.8.20-1_all.deb \
&& apt-get update \
&& rm mysql-apt-config_0.8.20-1_all.deb
# 安装MySQL服务器
RUN apt-get install -y mysql-server="${MYSQL_VERSION}" mysql-client="${MYSQL_VERSION}" && rm -rf /var/lib/apt/lists/*
# 设置MySQL的root密码,并清理安装后的文件
RUN mysql_secure_installation \
&& rm -rf /mysql-server/*.cnf
# 设置MySQL服务在容器启动时自动运行
CMD ["mysqld"]
这个Dockerfile修正了原始文件中的一些问题,并采用了更为安全的下载MySQL公钥的方式。同时,它使用了mysql-apt-config
包来配置MySQL的APT仓库,这样可以更灵活地选择要安装的MySQL版本。最后,它使用了mysql_secure_installation
脚本来设置MySQL的root密码,并在安装完成后清理了一些不必要的文件。
评论已关闭