【Docker】MySQL 源码构建 Docker 镜像(基于 ARM 64 架构)
# 使用Debian Buster作为基础镜像
FROM balenalib/generic-aarch64-debian:buster-build
# 设置MySQL版本和下载URL
ENV MYSQL_VERSION 8.0.23
ENV MYSQL_DOWNLOAD_URL https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-${MYSQL_VERSION}/mysql-${MYSQL_VERSION}-linux-glibc2.12-aarch64.tar.xz
# 安装构建依赖
RUN apt-get update && apt-get install -y \
build-essential \
cmake \
libssl-dev \
libncurses5 \
libncurses5-dev \
libncursesw5 \
libncursesw5-dev \
libreadline-dev \
libsqlite3-dev \
libmysqlclient-dev \
zlib1g-dev \
libbz2-dev \
libboost-all-dev \
libnuma-dev \
&& rm -rf /var/lib/apt/lists/*
# 下载MySQL源码并解压
RUN mkdir /opt/mysql \
&& curl -fsSL ${MYSQL_DOWNLOAD_URL} -o /tmp/mysql.tar.xz \
&& tar -xf /tmp/mysql.tar.xz -C /opt/mysql --strip-components=1 \
&& rm /tmp/mysql.tar.xz
# 配置MySQL编译选项
ENV MYSQL_DATADIR /var/lib/mysql
ENV PATH /opt/mysql/bin:$PATH
# 设置MySQL用户和用户组
RUN groupadd --system mysql && useradd --system --create-home --home-dir /var/lib/mysql --shell /bin/bash --no-user-group --group mysql \
# 创建目录并设置权限
&& mkdir -p $MYSQL_DATADIR \
&& chown -R mysql:mysql $MYSQL_DATADIR
# 设置环境变量
ENV GPG_KEY 0x516EAF855B20A6AB6B393677E72755344E2B7092
ENV MYSQL_USER mysql
ENV MYSQL_GROUP mysql
# 编译和安装MySQL
RUN cd /opt/mysql \
&& cmake . -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local \
&& make -j$(nproc) && make install
# 配置MySQL
COPY mysql_default.cnf /etc/mysql/conf.d/
COPY docker-entrypoint.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/docker-entrypoint.sh
# 设置容器启动时执行的命令
ENTRYPOINT ["usr/local/bin/docker-entrypoint.sh"]
# 设置容器对外暴露的端口
EXPOSE 3306
# 提供MySQL用户的默认配置
# 这里是一个示例,具体配置根据实际需要进行修改
# 注意:这个文件需要你自己提供,并且放置在你的Dockerfile能访问到的地方
这个Dockerfile提供了一个基本的框架来构建一个MySQL的Docker镜像。它使用了Debian Buster作为基础镜像,并且安装了构建MySQL所需的依赖。然后,它下载了MySQL的源码,解压缩,并编译安装。最后,它配置了MySQL的默认配置,设置了启动时运行的脚本,并暴露了MySQL的默认端口。这个示例假设你有一个叫做mysql_default.cnf
的MySQL配置文件和一个叫做docker-entrypoint.sh
的启动脚本,并且这些文件
评论已关闭