docker下mysql镜像初始化

20 篇文章 0 订阅
14 篇文章 0 订阅

目录

1、介绍

2、部署及验证

2.1  场景复现

2.2  创建dockerfile

2.3  初始化脚本

2.4  构建镜像并查看

2.5  创建容器并验证

2.6  完成 


1、介绍

原理:当Mysql容器首次启动时,会在 /docker-entrypoint-initdb.d目录下扫描 .sh,.sql,.sql.gz类型的文件。如果这些类型的文件存在,将执行它们来初始化一个数据库。这些文件会按照字母的顺序执行。默认情况下它们会初始化在启动容器时声明的MYSQL_DATABASE变量中的数据库。MYSQL_DATABASE这个变量默认是不存在的,必须在启动容器时候声明或定义,否则就扫描/docker-entrypoint-initdb.d目录下进行初始化,如下所示:

docker run --name mysql01 -e MYSQL_DATABASE=test_db -d mysql:latest

【这里是初始化定义的test_db数据库,如果没有MYSQL_DATABASE就进行扫描/docker-entrypoint-initdb.d目录,看是否有.sh,.sql,.sql.gz类型的文件,若有就进行初始化,没有就不进行初始化】

2、部署及验证

2.1  场景复现

       在标准的官方MySQL镜像基础上制作一个新镜像,新镜像启动过程中检查/root/init.sql文件是否存在,如果存在就执行此初始化SQL,完成数据库的初始化,随后删除此文件,正常启动MySQL。init.sql里可以是创建hellodb数据库,里面有app_user表,并包括app_user的3条初始化数据。给出dockerfile以及整个制作镜像以及启动验证的截图和说明。

系统

CentOS Linux release 7.6.1810

mysql镜像

MYSQL_VERSION=8.0.20

2.2  创建dockerfile

[root@bogon ~]# cat dockerfile

FROM mysql:latest

COPY --chown=mysql:mysql init.sql /root/

RUN cp /root/init.sql /docker-entrypoint-initdb.d

RUN rm -fr /root/init.sql

[root@bogon ~]#

【COPY意思是:先使用chown修改init.sql的用户属性,执行初始化数据库最好使用mysql用户来进行,当然root用户也是可以的,用户属性修改完毕再将init.sql复制到容器的/root/下面】

2.3  初始化脚本

[root@bogon ~]# cat init.sql

create database hellodb;

use hellodb;

create table app_user(name varchar(128) not null,age int not null,primary key(name));

insert into app_user values("jack","11"),("bob","4"),("tom","3");

[root@bogon ~]#

2.4  构建镜像并查看

docker build -t mysql:new .

docker images

2.5  创建容器并验证

docker run -d --name 001 -e MYSQL_ROOT_PASSWORD=123456 mysql:new

docker exec -it 001 bash

root@a929607c2da8:/# ls -l /root

total 0 【为空正常】

root@a929607c2da8:/# ls -l /docker-entrypoint-initdb.d/

total 4 【有init.sql文件正常,这是初始化文件,必须存在】

-rw-r--r--. 1 root root 190 Jun 20 13:48 init.sql

root@a929607c2da8:/#

mysql -uroot -p123456

show databases;

use hellodb;

show tables;

desc app_user;

2.6  完成 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Docker 打包 MySQL 镜像是通过 Dockerfile 来完成的一个自动化过程,它使得创建、部署和管理基于特定配置的容器变得简单高效。以下是基本步骤: ### 正确使用 Dockerfile 创建 MySQL 镜像 #### 1. **创建 Dockerfile** 首先,你需要在一个目录下创建一个 `Dockerfile` 文件。这个文件包含了构建镜像的所有命令。 ```dockerfile # 使用官方的 MySQL 容器为基础 FROM mysql:5.7 # 设置环境变量 ENV MYSQL_ROOT_PASSWORD=mysecretpassword # 将自定义的配置文件放入镜像中并覆盖默认配置 COPY ./my.cnf /etc/mysql/conf.d/my.cnf # 指定默认端口 EXPOSE 3306 # 运行安装脚本更新数据库密码 CMD ["service", "mysqld", "start", "&&", "sed", "-i", "'s/^bind-address/# bind-address/g'", "/etc/mysql/my.cnf", "&&", "sed", "-i", "'/bind-address/s/#//g'", "/etc/mysql/my.cnf", "&&", "/usr/bin/mysqld_safe"] # 指定运行命令 ENTRYPOINT ["/bin/bash"] ``` ### **解释 Dockerfile 内容** - **FROM**:指定基础镜像,这里选择的是 MySQL 的版本(例如 `mysql:5.7`)。 - **ENV**:设置环境变量,用于MySQL的根密码(需要替换为你实际使用的密码)。 - **COPY**:复制本地文件到镜像内的指定位置,这里是将自定义的 `my.cnf` 配置文件放置在 `/etc/mysql/conf.d/` 目录下,以覆盖默认配置。 - **EXPOSE**:声明容器对外暴露的服务端口,这里MySQL默认的3306端口。 - **CMD** 和 **ENTRYPOINT**:用于指定容器启动时的命令和默认入口点,这里的例子中使用了 Bash shell,并在容器启动后执行 MySQL 自带的安全初始化脚本。 #### 2. **准备自定义配置文件 (`my.cnf`)** 在构建镜像之前,需要有自定义的配置文件 `my.cnf` 存放适当的参数,如监听地址等。 ```ini [mysqld] # 禁止绑定到 localhost,允许从其他主机访问MySQL服务 bind-address = 0.0.0.0 # 其他配置... ``` #### 3. **构建 Docker 镜像** 在包含 `Dockerfile` 和所有必要的自定义文件的目录中,打开终端并执行以下命令构建镜像: ```bash docker build -t my-mysql-image . ``` 这将会创建一个新的 Docker 镜像,并将其命名为 `my-mysql-image`。 #### 4. **运行容器** 一旦镜像构建成功,你可以使用该镜像运行一个容器实例: ```bash docker run -d -p 3306:3306 my-mysql-image ``` 这会启动一个新容器,并映射宿主机的3306端口到容器的3306端口。 ### 相关问题: 1. **如何优化 MySQL Docker 镜像的性能?** - 可以调整内存限制、增加缓存大小、优化日志配置等。 2. **如何安全地管理和维护 MySQL Docker 镜像?** - 应定期更新基础镜像版本、监控日志及系统状态、备份数据以及应用最新的安全补丁。 3. **如果在生产环境中部署 MySQL,需要考虑哪些因素?** - 考虑负载均衡、高可用性、数据备份、性能优化、安全性增强等关键因素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

weixin_44250083

微信号:c_x_y_000

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

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

打赏作者

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

抵扣说明:

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

余额充值