当前位置: 首页 > news >正文

在docker中对MySQL快速部署与初始数据

1.准备工作

将已经准备好的Dockerfile文件与数据库初始化脚本init.sql放到 /usr/local目录中。

Dockerfile文件内容:

FROM mysql:5.7
WORKDIR /docker-entrypoint-initdb.d
ADD init.sql .

 FROM 代表来自mysql5.7的镜像,作为基准镜像。

WORKDIR设置工作目录,“docker-entrypoint-initdb.d”目录是MySQL5.7官方定义的执行SQL的目录,只有把脚本放到这个目录下,在启动镜像时,脚本才会被执行。

ADD是拷贝文件,把自己写的初始化脚本init.sql拷贝到WORKDIR工作目录中,让docker来执行该脚本。

init.sql文件内容:

create database `docker_mysql`;use docker_mysql;-- 建表
DROP TABLE IF EXISTS `user`;CREATE TABLE `user` (`id` bigint(20) NOT NULL,`created_at` bigint(40) DEFAULT NULL,`last_modified` bigint(40) DEFAULT NULL,`email` varchar(255) DEFAULT NULL,`first_name` varchar(255) DEFAULT NULL,`last_name` varchar(255) DEFAULT NULL,`username` varchar(255) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;-- 插入数据
INSERT INTO `user` (`id`, `created_at`, `last_modified`, `email`, `first_name`, `last_name`, `username`)
VALUES(0,1490257904,1490257904,'john.doe@example.com','John','Doe','user');

docker官方网址:

https://hub.docker.com/

搜索MySQL,可以看到官方支持的版本,根据说明可以安装不同版本的MySQL。

2.拉取docker镜像

docker pull mysql:5.7

使用docker images命令,查看镜像是否拉取完成。 

已经获取成功。

3.使用Dockerfile文件创建自定义镜像

将路径切换到Dockerflie所在的目录中,执行创建镜像的命令。

docker build -t sampledb .

sampledb是数据库镜像的名称,后面的点代表当前目录中的Dockerfile文件。

4.运行镜像,生成容器。

docker run -d -p 3310:3306 -e MYSQL_ROOT_PASSWORD=root sampledb

3310:3306表示用3310端口映射到docker内部的3306端口。

-e 表示设置环境常量,环境常量MYSQL_ROOT_PASSWORD,是MySQL5.7定义的,用来设置MySQL中root的初始密码,这里把初始密码设置为root。

sampledb是前面创建的镜像的名称。

5.使用navicat连接到MySQL数据库

可以看到定义的表和数据都在里面。

到此为止,在docker中基于MySQL5.7的官方镜像,自行创建了MySQL镜像,并初始化了数据库docker_mysql。

http://www.lryc.cn/news/512779.html

相关文章:

  • Mysql(MGR)和ProxySQL搭建部署-Kubernetes版本
  • 将现有Web 网页封装为macOS应用
  • 药片(药丸)和胶囊识别数据集,使用yolo,pasical voc xml, coco json格式标注,可识别药片和胶囊两种标签,2445张原始图片
  • 在Linux的世界中怎么玩转定时器任务
  • HTML——20 自定义属性
  • 2025:OpenAI的“七十二变”?
  • mac docker部署jar包流程
  • 【postgresql 物化视图】自动刷新物化视图2种方法
  • HMSC联合物种分布模型
  • stm32f103zet6 ds18b20
  • 【前端,TypeScript】TypeScript速成(六):函数
  • React引入Echart水球图
  • 谷歌浏览器的智能推荐功能使用指南
  • GitHub 上排名前 11 的开源管理后台(Admin Dashboard)项目
  • 【运维】部署MKDocs
  • C# 读取多种CAN报文文件转换成统一格式数据,工具类:CanMsgRead
  • 计算机网络 (8)物理层的传输方式
  • 【C#】WPF设置Separator为垂直方向
  • 太速科技-519-基于ZU19EG的4路100G光纤的PCIe 加速计算卡
  • 安卓入门二 Kotlin基础
  • C++ ——— 单/多参数构造函数的隐式类型转换和 explicit 关键字
  • Java编程规约:集合处理
  • IOS safari 播放 mp4 遇到的坎儿
  • plsql :用户system通过sysdba连接数据库--报错ora-01031
  • LabVIEW条件配置对话框
  • PyAudio库基本知识详解——为自制PCM音频播放器做准备
  • Git如何添加子仓库
  • 001__VMware软件和ubuntu系统安装(镜像)
  • 在国产电脑上运行PDFSAM软件使用pdf分割合并交替混合处理pdf文档
  • STM32完全学习——FATFS0.15移植SD卡