【Docker构建MySQL8.0镜像】

Docker构建MySQL8.0镜像

  • 部署流程
    • 1. 拉取docker镜像
    • 2. 创建数据卷,存放MySQL数据
    • 3. 启动MySQL镜像
    • 4. 初始化sql放入MySQL镜像
    • 5. 执行MySQL脚本
    • 6. MySQL镜像打包
    • 7. MySQL镜像迁移

部署流程

1. 拉取docker镜像

docker pull mysql:8.0.35

拉取成功后就可以看到镜像了:
在这里插入图片描述

这里我们选择MySQL 8.0.35版本,因为在8.0.33及其之前的版本被扫出多个漏洞,所以决定使用比较新版本的8.0.35

2. 创建数据卷,存放MySQL数据

docker volume create mysql_data8_35

最好在启动时自己准备好配置文件

3. 启动MySQL镜像

3.1 启动脚本

docker run -d -e MYSQL_ROOT_PASSWORD=密码 --name mysql8 -d -p 13307:3306 -v mysql_data8_35:/var/lib/mysql -v /日志目录/log:/var/log/ -v /配置文件目录/my.cnf:/etc/mysql/my.cnf mysql:8.0.35

注意:上述启动命令需要修改密码日志目录配置文件目录等内容后才能执行

常见的mysql8配置文件 my.cnf

[mysqld]
datadir = /var/lib/mysql
secure-file-priv= NULL
sql-mode = “ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION”
!includedir /etc/mysql/conf.d/
character-set-server = utf8mb4
collation-server = utf8mb4_general_ci
init_connect=‘SET NAMES utf8mb4’
lower_case_table_names = 1
[mysql]
default-character-set=utf8mb4
[client]
default-character-set=utf8mb4

3.2 查看是否启动成功
在这里插入图片描述

4. 初始化sql放入MySQL镜像

4.1 查看镜像id

docker ps
在这里插入图片描述

4.2 往镜像中放入脚本

docker cp init.sql 84dc03543c0f:/root/init.sql

4.3 进入镜像

docker exec -it mysql8 bash

在这里插入图片描述

5. 执行MySQL脚本

  1. 执行前登录mysql,开启日志:set global general_log=1;
  2. 查询日志存放目录:show variables like ‘general%’;
  3. 后续可以在目录实时查看脚本执行情况
    在这里插入图片描述
  4. 创建数据库:CREATE DATABASE IF NOT EXISTS 数据库名 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
  5. 执行MySQL脚本:mysql -uroot -p 数据库名 < /root/init.sql
    回车后输入密码
  6. 脚本执行完登录mysql去关闭日志:set global general_log=0;
    不关闭日志会导致数据堆积,mysql镜像越来越大

6. MySQL镜像打包

将MySQL镜像打成压缩包,后续就能直接把压缩包复制到别的服务器,实现镜像迁移

6.1 查看数据卷所在位置

docker volume inspect mysql_data8_35

在这里插入图片描述
6.2 数据压缩

  • 进入目录: cd /var/lib/docker/volumes/mysql_data8_35
  • 压缩数据:tar -czvf mysql8-35.tar.gz _data/

6.3 镜像压缩

docker save -o mysql8-35.tar mysql:8.0.35

6.4 最终结果
在这里插入图片描述

7. MySQL镜像迁移

1. 加载镜像
docker load -i mysql8-35.tar

加载后即可看到镜像

2. 解压数据卷文件
tar -zxvf mysql8-35.tar.gz
在这里插入图片描述
3. 启动镜像
启动指令:
docker run -d -e MYSQL_ROOT_PASSWORD=密码 --name mysql8 -d -p 13307:3306 -v 数据卷解压目录/_data:/var/lib/mysql -v 日志目录/logs:/var/log/mysql8 -v 配置文件目录/my.cnf:/etc/mysql/my.cnf mysql:8.0.35

上述指令的配置文件目录日志目录都是非必须的,如果不需要将对应 -v指令去掉即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/410219.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android 仿快手视频列表,RecyclerView与Banner联动效果

这是看到群里讨论过快手APP的一个观看他人视频列表的一个联动效果&#xff0c;但是并不是完全按照这个软件的效果来做的&#xff0c;只是参考&#xff0c;并不是完全仿照这个软件来做的&#xff0c;没时间去优化排版问题了&#xff0c;请见谅&#xff0c;如图&#xff1a; 实现…

11.1 pcl_ros的点云学习

本文是看了两个博主的内容&#xff0c;整理在这里是为了以后用时方便查找&#xff0c;更容易理解。引用的博文路径如下&#xff08;本人也是刚开始看PCL的运用&#xff0c;本文是完全抄下面博主的内容&#xff0c;觉得这位博主写的很详细很清楚&#xff0c;并且自己运行了一遍有…

C++I/O流——(4)格式化输入/输出(第二节)

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 含泪播种的人一定能含笑收获&#xff…

【J-Flash基本使用总结】

【J-Flash基本使用总结】 VX&#xff1a;hao541022348 ■ 烧录文件■ 创建新的工程■ 烧录模式-SWD模式■ J-Flash下载程序到单片机 ■ J-Flash拼接多个hex或bin文件■ J-Flash读单片机的option byte■ J-Flash读单片机Flash数据■ 将读出来的文件用jflash烧录到其他的芯片■ 设…

Kafka集群与可靠性

Kafka集群与可靠性 1.Kafka集群搭建实战 使用两台Linux服务器&#xff1a;一台192.168.182.137 一台192.168.182.138 安装kafka首先&#xff0c;我们需要配置java环境变量&#xff08;这里就略过了&#xff09; mkdir /opt/kafka #上传压缩包kafka_2.13-3.3.1.tgz并解压 ta…

imgaug库指南(28):从入门到精通的【图像增强】之旅(万字长文)

引言 在深度学习和计算机视觉的世界里&#xff0c;数据是模型训练的基石&#xff0c;其质量与数量直接影响着模型的性能。然而&#xff0c;获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此&#xff0c;数据增强技术应运而生&#xff0c;成为了解决这一问题的…

java客户端连接redis并设置序列化处理

1、导入依赖 <!--继承父依赖--> <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.12.RELEASE</version><relativePath/> <!-- lookup paren…

数学建模常见算法的通俗理解(更新中)

目录 1.层次分析法&#xff08;结合某些属性及个人倾向&#xff0c;做出某种决定&#xff09; 1.1 粗浅理解 1.2 算法过程 1.2.1 构造判断矩阵 1.2.2 计算权重向量 1.2.3 计算最大特征根 1.2.4 计算C.I.值 1.2.5 求解C.R.值 1.2.6 判断一致性 1.2.7 计算总得分 2 神经…

CleanMyMac X .4.14.7如何清理 Mac 系统?

细心的用户发现苹果Mac电脑越用越慢&#xff0c;其实这种情况是正常的&#xff0c;mac电脑用久了会产生很多的缓存文件&#xff0c;如果不及时清理会影响运行速度。Mac系统在使用过程中都会产生大量系统垃圾&#xff0c;如不需要的系统语言安装包&#xff0c;视频网站缓存文件&…

Microsoft Word 设置底纹

Microsoft Word 设置底纹 References 打开文档页面&#xff0c;选中特定段落或全部文档 在“段落”中单击“边框”下三角按钮 在列表中选择“边框和底纹”选项 在“边框和底纹”对话框中单击“底纹”选项卡 在图案样式和图案颜色列表中设置合适颜色的底纹&#xff0c;单击“确…

Spark原理——逻辑执行图

逻辑执行图 明确逻辑计划的边界 在 Action 调用之前&#xff0c;会生成一系列的RDD,这些RDD之间的关系&#xff0c;其实就是整个逻辑计划 val conf new SparkConf().setMaster("local[6]").setAppName("wordCount_source") val sc new SparkContext(conf)v…

利用HTML和CSS实现的浮动布局

代码如下 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><style>*{m…