No zuo no die ,用Docker安装Mysql

话说,小哥接触Mysql也有几年了,但总是感觉Mysql有很多神秘的特性,一直也不太敢折腾这家伙。昨天准备动动手,可安装过程就花了2天时间。 期间,错误的以为必须要给mysql server挂载本地目录,对数据进行持久化。最终,还是看了docker文档才搞清楚Docker Volume的使用方法。

先讲案例

一、docker 安装 Mysql

1.在docker shell 下载mysql-server

docker pull mysql/mysql-server:8.0
## 8.0 可以设为7.0 5.6 5.5

2. 启动镜像

docker run --name=mysql1 -d mysql/mysql-server:8.0

3. 等待镜像完成初始化,用docker ps 命令查看状态。由于dokcer -d是后台执行,无法观察系统执行情况。当docker ps输出status 为healthy的时候,系统启动完成。

docker ps

4.获取root密码

docker logs mysql1 2>&1 | grep GENERATED

回显,GENERATED ROOT PASSWORD: Axegh3kAJyDLaRuBemecis&EShOs

5.获得mysql shell,用docker获取镜像里的进程

docker exec -it mysql1 mysql -uroot -p

输入 4步获得的密码。

6.修改root密码

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpassword';

完成以上6步,就可以得到一个mysql虚拟机,你可以通过docker exec -it mysql1 mysql -uroot -p 连接到虚拟机内部。

以上步骤,来源于docker hub上mysql server的文档。 https://hub.docker.com/r/mysql/mysql-server/

二、docker 数据持久化

如果docker 不能持久化数据,重新启动docker,那么写入mysql的数据就都丢失了?

1. 测试,关闭虚拟机

我们采用命令, 重启虚拟机,发现写入的数据没有丢失。

docker stop mysql1
docker start mysql1

2. Docker 为什么不是持久化

在docker 官方文档上,介绍了docker存储原理。docker的一种重要特性,就是分层存储,这个在编译、传输docker时都带来很大优势。

运行的docker容器也是分层的,“writeable container layer”可写层位于docker容器的最顶端,这个层的特点就是不能持久化。

docker运行过程中的写操作都保存在“writeable layer”上,但当容器停止时,这些数据是没有保存,下一次启动docker,就好像启动一块有还原卡的主机,之前操作都没有保存下来。

By default all files created inside a container are stored on a writable container layer. This means that:

  • The data doesn’t persist when that container is no longer running, and it can be difficult to get the data out of the container if another process needs it.
  • A container’s writable layer is tightly coupled to the host machine where the container is running. You can’t easily move the data somewhere else.
  • Writing into a container’s writable layer requires a storage driver to manage the filesystem. The storage driver provides a union filesystem, using the Linux kernel. This extra abstraction reduces performance as compared to using data volumes, which write directly to the host filesystem. https://docs.docker.com/storage/

3.docker Volume 概念

volume

docker 提供了三种数据持久化的方案

  1. volume
  2. bind mount
  3. tmpfs mount

官网文章 https://docs.docker.com/storage/#good-use-cases-for-volumes 给出了Good use cases for (volume;bind mount;tmpfs)。

官网的图片就可以说明三中类型区别:

  1. volume 卷,由Docker维护,保存在Filesystem中,即宿主机的文件系统中,但宿主机通常无法管理volume。
  2. bind mount,磁盘挂载,将宿主机的目录挂载到docker中。我们将源码保存在工程目录里,docker挂载工程目录,实现发布测试,就是用的这种方式。
  3. tmpfs是基于内存的。

三、卷的使用方法

1. bind mount挂载一个卷,将当前目录下的html文件夹挂载到docker nginx的发布目录

docker run -v $PWD/html:/usr/share/nginx/html -d nginx 

2. Volume 分为两种类型,匿名Volume和非匿名Volume

使用非匿名Volume,首先要创建一个,

docker volume create mydataVolume

挂载Volume,也是-v volume名字:docker路径

docker run --name=nginx -v mydataVolume:/usr/share/nginx/html -d nginx

匿名Volumn,在docker run的时候,创建一个volume并和镜像路径和绑定。

docker run --name=nginx -v /usr/share/nginx/html -d nginx

查看所有的Volume,每次创建新的容器,都会创建新的Volume。注,docker run创建新容器,docker stop可以运行已经停止的容器。

docker volume ls

下图,019 734等都是匿名卷,而wangsen是非匿名卷。

docker volume list

3. 卷的操作

如果镜像被删除了,匿名卷是不会被删除的,调用docker volume rm 卷名

如果挂载卷的docker被删除,其他镜像可以挂载这个卷。

一个卷没有任何的镜像挂载,那么它就成了无用的卷,命令docker volume prune可以批量删除无用卷。

4.挂载卷

不能直接 -v一个已经被其他docker挂载的volume,但是可以挂载docker,-volumes-from命令。

四,终于要揭开谜底 Mysql如何实现的持久化

在Mysql的Dockerfile,定义了匿名卷 VOLUME /var/lib/mysql

dockfile

此外docker mysql/mysql-server官方文档关于持久化主题https://dev.mysql.com/doc/refman/5.7/en/docker-mysql-more-topics.html#docker-persisting-data-configuration

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏LuckQI

微服务重要的容器技术Docker的核心实现技术

Docker 作为一种容器虚拟化技术,应用了操作系统的多项底层支持技术。其中的技术层包含Linux操作系统的命名空间Namespace,控制组,联合文件系统,...

15330
来自专栏编程坑太多

『高级篇』docker之DockerSwarm的集群环境搭建(28)

PS:以上就完成高可用的docker swarm的集群环境,其实真心比其他的简单。

13120
来自专栏云计算教程系列

如何使用Helm软件包管理器在Kubernetes集群上安装软件

Helm是Kubernetes的软件包管理器,允许开发人员和操作员更轻松地在Kubernetes集群上配置和部署应用程序。

20620
来自专栏云计算教程系列

Kubernetes DNS服务简介

域名系统(DNS)是一种用于将各种类型的信息(例如IP地址)与易于记忆的名称相关联的系统。默认情况下,大多数Kubernetes群集会自动配置内部DNS服务,以...

34440
来自专栏北京马哥教育

Docker Swarm学习笔记(二)

搭建基础环境 官方文档中演示时用到了五台主机/虚拟机; ? 这里因为资源有限,只用三台; ? 创建虚拟机(可以用主机,也可以用虚拟机); 安装Ubuntu 16...

29370
来自专栏Samego开发资源

JDK的安装与配置 | Linux&Windows

27530
来自专栏写写代码吃吃瓜

Ubuntu环境下Tornado环境部署

18870
来自专栏运维

RHEL4.4老版本YUM安装

Red Hat Enterprise Linux AS release 4 (Nahant Update 4)

27220
来自专栏bdcn

Anaconda配置和使用 原

原来一直使用原生python和pip的方式,换了新电脑,准备折腾下Anaconda。

1.9K20
来自专栏架构说

Mesos+Zookeeper+Marathon管理Docker(1)

.服务器信息:物理机10.1.44.35上的KVM虚拟机 名称IP服务单点10.1.44.69Mesos\Marathon\Deimos\Zookeeper\D...

36170

扫码关注云+社区

领取腾讯云代金券