使用Docker部署MySQL(数据持久化)
原文链接:http://walterinsh.github.io/2015/01/17/use-mysql-with-docker.html
本文简述如何使用Docker部署mysql,同时持久化数据.我们会用到tutum-docker-mysql 这个项目来搭建一个mysql,省去重头写Dockerfile的时间.
首先我们将tutum-docker-mysql跑起来.
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 -e MYSQL_PASS="mypass" tutum/mysql
我们在上面启动的时候顺便指定了创建密码为mypass,我们现在登陆一下mysql创建一些数据,看看会不会被保存下来
-
shell>mysql -uadmin -pmypass -h127.0.0.1
-
mysql>create database 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
**********************************
**********************************
-
获取docker image
docker pull mysql:5.6
-
运行mysql镜像,并指定mysql配置
docker run -p 3306:3306 -v /Users/huangxiang/softData/docerData/mysql:/etc/mysql --name localmysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.6
-
进入myql
docker exec -it localmysql bash
-
登陆mysql
mysql -uroot -p
-
重新启动创建的容器
docker start localmysql
下次需要的时候重启容器,原有数据都能被加载
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!