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`
相关推荐
玄斎4 小时前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
我的offer在哪里5 小时前
mysql修改密码
adb
编程小Y5 小时前
MySQL 与 MCP 集成全解析(核心原理 + 实战步骤 + 应用场景)
数据库·mysql·adb
lvbinemail6 小时前
Grafana模板自动复制图表
数据库·mysql·zabbix·grafana·监控
学Linux的语莫6 小时前
docker,docker-compose二进制包安装
docker
weixin_448119946 小时前
Datawhale Hello-Agents入门篇202512第1次作业
数据库·sql·mysql
皮皮林5516 小时前
有了开源的 MySQL,为什么还要选择 PostgreSQL?
mysql
廋到被风吹走7 小时前
【数据库】【MySQL】分库分表策略 分类、优势与短板
数据库·mysql·分类
_oP_i7 小时前
Docker 整体架构
docker·容器·架构
杨浦老苏7 小时前
可视化服务构建器Dock-Dploy
docker·工具·群晖