docker 编译安装mysql脚本

本文详细介绍了如何在Docker中使用Dockerfile从MySQL源代码编译安装,并创建一个包含自定义配置和初始化的MySQL镜像。过程包括安装依赖、编译、配置和启动MySQL服务。
摘要由CSDN通过智能技术生成

在Docker中,你通常不会直接编译安装MySQL,因为Docker提供了预先构建好的MySQL镜像。这些镜像已经包含了编译好的MySQL二进制文件和所需的库文件。不过,如果你有特殊需求,例如想要自己从源代码编译MySQL并打包成Docker镜像,你可以编写一个Dockerfile来实现。

下面是一个简单的Dockerfile示例,用于从MySQL的源代码编译并安装MySQL,然后创建一个Docker镜像:

 
# 使用一个包含编译工具的基础镜像
FROM ubuntu:latest AS builder

# 安装编译MySQL所需的依赖包
RUN apt-get update && \
apt-get install -y \
cmake \
gcc \
g++ \
make \
libncurses5-dev \
libssl-dev \
libreadline-dev \
zlib1g-dev \
&& rm -rf /var/lib/apt/lists/*

# 设置工作目录
WORKDIR /usr/src/mysql

# 从MySQL官方网站下载源代码
ARG MYSQL_VERSION=8.0.26
RUN curl -sSL https://dev.mysql.com/get/Downloads/MySQL-${MYSQL_VERSION}/mysql-${MYSQL_VERSION}.tar.gz | tar -xzvf -

# 编译和安装MySQL
RUN mkdir build && \
cd build && \
cmake .. -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DSYSCONFDIR=/etc -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0 -DMYSQL_DATADIR=/var/lib/mysql -DMYSQL_UNIX_ADDR=/tmp/mysql.sock && \
make -j$(nproc) && \
make install

# 复制配置文件模板到镜像中
COPY my.cnf /etc/mysql/my.cnf

# 创建一个MySQL用户
RUN useradd -r -s /bin/false -M mysql

# 设置MySQL数据目录权限
RUN chown -R mysql:mysql /var/lib/mysql /usr/local/mysql

# 设置环境变量
ENV PATH=/usr/local/mysql/bin:$PATH
ENV MYSQL_HOME=/usr/local/mysql
ENV MYSQL_DATA_DIR=/var/lib/mysql

# 复制启动脚本
COPY entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh

# 暴露MySQL默认端口
EXPOSE 3306

# 定义容器启动时执行的命令
ENTRYPOINT ["/entrypoint.sh"]

这个Dockerfile执行了以下步骤:

  1. 使用ubuntu:latest作为基础镜像,并切换到builder阶段。
  2. 安装编译MySQL所需的依赖包。
  3. 下载MySQL的源代码。
  4. 使用cmakemake工具编译MySQL。
  5. 安装MySQL到/usr/local/mysql目录。
  6. 复制一个自定义的my.cnf配置文件到镜像中。
  7. 创建一个名为mysql的系统用户。
  8. 设置MySQL数据目录的权限。
  9. 设置环境变量。
  10. 复制一个启动脚本entrypoint.sh到镜像中,并使其可执行。
  11. 暴露MySQL的默认端口3306。
  12. 设置容器启动时的默认命令为entrypoint.sh

你需要创建一个entrypoint.sh脚本来初始化数据库、启动MySQL服务等。这个脚本可能会像这样:

 
#!/bin/bash

# 初始化数据库
/usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/var/lib/mysql

# 启动MySQL服务
/usr/local/mysql/bin/mysqld_safe --user=mysql &

# 等待MySQL服务启动
while ! nc -z localhost 3306; do
sleep 1
done

# 现在MySQL服务已经启动,可以执行其他命令,比如等待用户的命令
exec "$@"

要构建这个Docker镜像,你可以在Dockerfile所在的目录中运行以下命令:

 
docker build -t my-custom-mysql .

然后,你可以运行一个新的容器实例:

 
docker run -p 3306:3306 --name my-mysql-container -e MYSQL_ROOT_PASSWORD=my-secret-pw -d my-custom-mysql

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三希

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值