一、背景及分析

MysqL容器启动时,会自动创建一些必要的数据库,比如MysqL,这是官方认的做法。但是,在实际中,还需要让MysqL自动创建我们自定义数据库。本文就此应用场合进行探究。

一般的做法是,启动容器并挂载数据目录后,使用MysqL客户端连接服务器,再手动输入sql语句创建(或导入.sql文件),当然也可以直接在容器内创建(方法同上)。由于挂载了数据目录,因此可持久化保存。但是,这些方法在部署数据库比较繁琐,不方便,特别是在初测阶段,会频繁地从头开始搭建环境。

如果能在MysqL容器启动时,自动执行我们自己的.sql文件,就不需要那么麻烦了,其实MysqL容器的启动脚本已经考虑了这种场合。通过MysqL镜像构建脚本docker-entrypoint.sh(参考这里
),发现如下语句:

  1. for f in /docker-entrypoint-initdb.d/*; do
  2. process_init_file "$f" "${MysqL[@]}"
  3. done

process_init_file函数定义如下:

  1. process_init_file() {
  2. local f="$1"; shift
  3. local MysqL=( "$@" )
  4. case "$f" in
  5. *.sh) echo "$0: running $f"; . "$f" ;;
  6. *.sql) echo "$0: running $f"; "${MysqL[@]}" < "$f"; echo ;;
  7. *.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${MysqL[@]}"; echo ;;
  8. *) echo "$0: ignoring $f" ;;
  9. esac
  10. echo
  11. }

从上面语句看到,脚本将需要执行的文件(如.sh或.sql)放到/docker-entrypoint-initdb.d目录下,那么docker-entrypoint.sh就会自动执行。明白了原理,解决方案就十分简单了。

二、解决方

2.1 Dockerfile

内容如下:

  1. FROM MysqL:5.7
  2. copY sql/*.sql /docker-entrypoint-initdb.d/

为了方便起见,所有.sql文件都放到Dockerfile同级的sql目录。

2.2 准备好sql文件

下面是测试用的.sql文件文件名为test.sql内容如下:

  1. -- 创建db_test数据库
  2. create database `db_test` default character set utf8 collate utf8_general_ci;
  3. use db_test;
  4. -- 创建用户
  5. DROP TABLE IF EXISTS `user`;
  6. CREATE TABLE `user` (
  7. `id` bigint(20) NOT NULL,
  8. `email` varchar(255) DEFAULT NULL,
  9. `first_name` varchar(255) DEFAULT NULL,
  10. `last_name` varchar(255) DEFAULT NULL,
  11. `username` varchar(255) DEFAULT NULL,
  12. PRIMARY KEY (`id`)
  13. ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
  14. -- 插入数据
  15. INSERT INTO `user` (`id`, `email`, `first_name`, `last_name`, `username`)
  16. VALUES(0,'li@latelee.org','Late','Lee','latelee');

主要内容是创建user表,并插入测试的数据。

2.3 创建镜像

  1. docker build -t MysqLtest .

创建镜像名称MysqLtest,注意最后的点号.,表示使用当前目录的Dockerfile

2.4 容器启动

docker-compose.yml文件内容如下:

  1. version: '2'
  2. services:
  3. database:
  4. image: MysqLtest
  5. #image: singula/MysqL
  6. container_name: MysqL
  7. ports:
  8. - "3406:3306"
  9. volumes:
  10. - ./MysqL_data:/var/lib/MysqL
  11. - /home:/home
  12. environment:
  13. MysqL_ROOT_PASSWORD: 123456

使用下列命令启动:

  1. docker-compose up -d

验证数据库表:

  1. $ docker exec -it MysqL bash
  2. bash-4.2# MysqL -uroot -p123456
  3. MysqL> use db_test;
  4. MysqL> select * from user;
  5. +----+----------------+------------+-----------+----------+
  6. | id | email | first_name | last_name | username |
  7. +----+----------------+------------+-----------+----------+
  8. | 0 | li@latelee.org | Late | Lee | latelee |
  9. +----+----------------+------------+-----------+----------+
  10. 1 row in set (0.00 sec)

使用如下语句修改邮箱地址:

  1. update user set email='cst@cststudio.com.cn' where username='latelee';

退出容器后,停止容器:

  1. docker-compose down

再次重复上述命令启动、查看数据,可以看到邮件地址是最新的,从而验证了数据能永久存储。

三、实践指导

.sql脚本只有第一次启动时创建(或说没有数据库时则会创建),已创建的,不会覆盖掉,否则这个机制就无法正式应用项目中。

.sql脚本中,也可以创建账号、密码,这样就不用在docker-compose文件指定环境变量了。起到了一定的保护作用。

如果要完全迁移数据,需要将数据目录(文中为MysqL_data目录)与docker-compose.yml文件一起迁移。

MySQL启动时自动创建数据库的更多相关文章

  1. 让docker中的mysql启动时自动执行sql文件

    本文提要 本文目的不仅仅是创建一个MySQL的镜像,而是在其基础上再实现启动过程中自动导入数据及数据库用户的权限设置,并且在新创建出来的容器里自动启动MySQL服务接受外部连接,主要是通过Docker ...

  2. 让docker中的mysql启动时自动执行sql

    在用docker创建mysql容器的时,有时候我们期望容器启动后数据库和表已经自动建好,初始化数据也已自动录入,也就是说容器启动后我们就能直接连上容器中的数据库,使用其中的数据了. 其实mysql的官 ...

  3. ssh整合思想 Spring与Hibernate的整合 项目在服务器启动则自动创建数据库表

    Spring整合Hibernate Spring的Web项目中,web.xml文件会自动加载,以出现欢迎首页.也可以在这个文件中对Spring的配置文件进行监听,自启动配置文件, 以及之前Struts ...

  4. 查询事件状态,mysql查看事件是否开启,设置启动时自动开启方法

    1.查看事件是否开启 SHOW VARIABLES LIKE 'event_scheduler' 2.设置当前事件开启 SET GLOBAL event_scheduler = 1; 或 SET GL ...

  5. Code First 迁移----官方 应用程序启动时自动升级(MigrateDatabaseToLatestVersion 初始值设定项)

    Code First 迁移 如果使用的是 Code First 工作流,推荐使用 Code First 迁移改进应用程序的数据库架构. 迁移提供一组允许以下操作的工具: 创建可用于 EF 模型的初始数 ...

  6. SpringBoot使用Hibernate,实现自动创建数据库表【博客数据库设计】

    我们准备设计博客,那就要设计数据库. 我们可以使用Hibernate来自动生成数据库. 博客数据库的结构: 实体类: 博客 Blog 博客分类 Type 博客标签 Tag 博客评论 Comment 用 ...

  7. EF自动创建数据库步骤之三(自定义数据库初始器)

    EF自动创建数据库需要我们告诉数据库如何进行初始化:如创建表后是否需要插入一些基础数据,是否 需要创建存储过程.触发器等.还有就是EF有三种初始化方式(参见下面三个类): DropCreateData ...

  8. SpringBoot程序启动时在Oracle数据库中建表充值

    例子工程下载链接:https://files.cnblogs.com/files/xiandedanteng/gatling20200428-1.zip 需求:在工程启动时在Oracle数据库中建表. ...

  9. EntityFramework SQLiteCodeFirst 自动创建数据库 关闭级联删除

    外键的级联删除: 如A表中有主键idA, B表中设置外键(ForeignKey)为A表中的主键idA, 当A表中的记录被删除时, B表中所有引用此条记录的记录(即所有外键为idA的记录)将自动被删除 ...

  10. sql2008 计划自动创建数据库分区【转】

    本文转自:http://jingyan.baidu.com/article/6b97984d9a26ec1ca3b0bf77.html sql2008 计划自动创建数据库分区 固定增量的数据,自动创建 ...

随机推荐

  1. Android 内存分析(java native heap内存、虚拟内存、处理器内存.

    1.jvm 堆内存(dalvik 堆内存) 每个Java应用程序在运行时都会拥有自己的JVM实例,这个实例会为其分配独立的堆内存空间.这意味着不同的应用程序之间不会共享堆内存. 不同手机中app进程的 ...

  2. 墨天轮专访星环科技刘熙:“向量热”背后的冷思考,Hippo如何打造“先发”优势?

    导读: 深耕技术研发数十载,坚持自主可控发展路.星环科技一路砥砺前行.坚持创新为先,建设了全面的产品矩阵,并于2022年作为首个独立基础软件产品公司成功上市.星环科技在今年的向星力•未来技术大会上发布 ...

  3. 2022年 GOPS 全球运维大会(上海站)资料分享

    2022年 GOPS 全球运维大会(上海站)主题为"XOps 风向标",共分为16个专场,主要侧重方向是运维.DevOps.AIOps.DevSecOps.云原生.研发效能.可观测 ...

  4. Fluent Operator v2.0 发布:Fluent Bit 新的部署方式——Fluent Bit Collector

    2019 年 1 月 21 日,KubeSphere 社区为了满足以云原生的方式管理 Fluent Bit 的需求开发了 FluentBit Operator.此后产品不断迭代,在 2021 年 8 ...

  5. appium-解决uiautomatorviewer不能定位android7以上版本元素的方法

    上图是android10模拟器,发现我们是无法连接模拟器识别的 解决方法: 在模拟器内打开指定页面然后截图,最后保存为uix文件,然后用adb拉到本地,一共四个命令,可以保存为.bat文件快捷执行(这 ...

  6. OpenCV开发笔记(八十一):通过棋盘格使用鱼眼方式标定相机内参矩阵矫正摄像头图像

    前言   对于广角摄像头通过相机图片可以识别出棋盘角点计算相机内参矩阵,通过畸变校准可以得到较好的效果,但是鱼眼摄像头通过这种方式获得周围四周的图像效果并不是很好.所以,鱼眼摄像头在校准上与普通摄像头 ...

  7. SparkSQL练习:对学生选课成绩进行分析计算

    题目内容: 对学生选课成绩进行分析计算 题目要求: (1)该系总共有多少学生: (2)该系共开设来多少门课程: (3)每个学生的总成绩多少: (4)每门课程选修的同学人数: (5)每位同学选修的课程门 ...

  8. 3.5 Linux命令行下如何识别文件类型?

    对于第一次使用 Linux 命令行的用户,可能真的搞不清楚哪个是文件,哪个是目录,究其原因是很难直接通过名字看出来目录和文件的区别. 虽然从名称上不容易分辨,但是可以从颜色上进行区分.一般情况下,Li ...

  9. games101_Homework0

    给定一个点 P=(2,1), 将该点绕原点先逆时针旋转 45 ◦,再平移 (1,2), 计算出 变换后点的坐标(要求用齐次坐标进行计算). 作业解答: #include<cmath> #i ...

  10. 2023NOIP A层联测28 T3 大眼鸹猫

    2023NOIP A层联测28 T3 大眼鸹猫 比赛做出来了,但是文抄-- 思路 分析每一个 \(i\),发现其一定需要上升或下降 \(|a_i-b_i|\). 如果求出最小操作次数,然后在此基础上, ...