docker 编译安装mysql脚本

在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`
相关推荐
Y3ai1 天前
Windows 11 Docker Desktop 保姆级安装使用教程
windows·docker·容器
星辰徐哥1 天前
大模型工程化部署:Docker Compose批量部署
运维·docker·容器
J超会运1 天前
OpenEuler系统MySQL故障排查终极指南
mysql
biubiubiu07061 天前
Docker 快速通关
docker·容器·eureka
csdn_aspnet1 天前
MySQL主从延迟根因诊断法,从网络、IO、SQL到参数,系统化定位高并发下的同步瓶颈
数据库·mysql·主从
Deryck_德瑞克1 天前
【已解决】MySQL连接出错 1045 - Access denied for user ‘root‘@‘::1‘
android·mysql·adb
两点王爷1 天前
docker 创建和使用存储卷相关内容
java·docker·容器
回到原点的码农1 天前
Linux(CentOS)安装 MySQL
linux·mysql·centos
m0_491267001 天前
Docker部署MySQL 多库自动备份(结构+数据完整,适配CentOS)
mysql·安全
高梦轩1 天前
MySQL 故障排查与优化
数据库·mysql