docker映射mysql文件_使用Docker部署MySQL(数据持久化),将mysql的数据映射到本机磁盘...

使用Docker部署MySQL(数据持久化),将mysql的数据映射到本机磁盘

发布时间:2018-04-19 15:56,

浏览次数:349

, 标签:

Docker

MySQL

本文简述如何使用Docker部署mysql,同时持久化数据.我们会用到tutum-docker-mysql

这个项目来搭建一个mysql,省去重头写Dockerfile的时间.

首先我们将tutum-docker-mysql跑起来.

注意不能在同一个文件夹下建立两个 会报错为[ERROR] InnoDB: Unable to lock ./ibdata1, error: 11

docker run -d -p 3306:3306 --name mysql tutum/mysql

如果你本地没有tutum/mysql的image,docker会先下载它的image,这一步可能会用些时间.待执行完毕我们检查一下应该会有如下样子

tutum-docker-mysql会自动帮我们建一个随机的密码供我们访问,通过日志可以查看到.

我们通过日志上的密码登陆mysql

mysql -uadmin -pi6k5USp9Km9G -h127.0.0.1

理论上我们这个时候就登陆mysql成功了,你可以创建一个库,一个张表,然后退出.但是当这个container停止再重启后,你的数据就丢了.

如何使你的数据真的被保存下来呢?

解决方案就是:挂载一个本地文件到Container (Mount a local folder from the host on the container

to store the database files).

首先我们停掉之前的Container

docker stop mysql

我们指定一个本地可以挂载的路径,重新启动tutum-docker-mysql.我们指定/home/walter/softwares/tutum-docker-mysql/data

挂到Container里的/var/lib/mysql目录(-v Bind mount a volume).

这样子我们就可以将数据持久化在主机(Host)的目录中了.

sudo docker run -d -p 3306:3306 -v

/home/walter/softwares/tutum-docker-mysql/data:/var/lib/mysql -eMYSQL_PASS=

"mypass" tutum/mysql

sudo docker run -dit -v /home/zcl/docker-mysql/data:/var/lib/mysql -p

3307:3306 --name master -e MYSQL_ROOT_PASSWORD=root mysql:5.6

--lower_case_table_names=1

我们在上面启动的时候顺便指定了创建密码为mypass,我们现在登陆一下mysql创建一些数据,看看会不会被保存下来

shell>mysql -uadmin -pmypass -h127.0.0.1 mysql>create databases test;

退出mysql,重启Container,我们发下我们做的操作将会被保留下来.我们之后每一次启动这个mysql都可以使用下面的命令

docker run -d -p 127.0.0.1:3306:3306 -v

/home/walter/softwares/tutum-docker-mysql/data:/var/lib/mysql tutum/mysql

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker是一个开放源代码的虚拟平台,能够以容器的形式打包和分发应用程序。MySQL是一种流行的开源关系型数据库管理系统。使用Docker部署MySQL可以极大简安装和配置的过程,并且能够实现数据持久。 首先,我们需要在Docker上搜索并选择适合的MySQL镜像。可以通过运行`docker search mysql`命令来查找可用的MySQL镜像。选择合适的镜像后,可以通过`docker pull <镜像名称>`来下载镜像,例如`docker pull mysql:latest`。 下载完成后,我们可以运行以下命令来创建一个MySQL容器: ``` docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=your_password -d mysql:latest ``` 这个命令将会创建一个名为mysql的容器,并将MySQL服务的默认端口3306映射到宿主的3306端口。同样,我们可以设置一个root密码,让MySQL服务有一个基本的访问控制。 这样,MySQL容器就成功运行起来了。我们可以通过`docker ps`命令来查看正在运行的容器。接下来,我们可以使用MySQL客户端连接到该容器。可以通过以下命令登录到MySQL容器内部的MySQL服务: ``` docker exec -it mysql mysql -uroot -p ``` 然后,我们可以在MySQL容器内部使用标准的MySQL命令来管理和操作数据库。 要实现数据持久,我们可以将MySQL容器内部的数据目录和宿主的目录进行挂载。可以使用`-v`参数来指定目录的挂载点。例如: ``` docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=your_password -v /path/to/mysql/data:/var/lib/mysql -d mysql:latest ``` 这将会将MySQL容器内部的`/var/lib/mysql`目录与宿主上的`/path/to/mysql/data`目录进行挂载,从而实现数据持久。 通过以上步骤,我们可以使用Docker部署MySQL,并且实现数据持久。这样,我们可以方便地在不同的环境之间快速部署和迁移MySQL数据库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值