登录
首页 >  数据库 >  MySQL

Docker | 数据持久化与数据共享

来源:SegmentFault

时间:2023-02-24 12:57:11 202浏览 收藏

对于一个数据库开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《Docker | 数据持久化与数据共享》,主要介绍了MySQL、docker、前端,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

数据持久化(安装MySQL)

参考另一篇Docker安装mysql: https://segmentfault.com/a/1190000042597787

MySQL的数据持久化问题

# 下载容器
docker pull mysql:5.7

-d 后台运行
-p 端口映射
-v 挂载数据卷
-e 环境配置
--name 容器名字
# 运行容器
docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7

https://hub.docker.com/_/mysql

官网启动MySQL,设置密码

--volumes-from 
实现容器间的数据共享

多个centos容器数据共享

  1. 父容器docker01(数据卷容器)

# 父容器docker01(数据卷容器)
docker run -it --name docker01 xiao-centos /bin/bash
  1. 创建docker02容器,继承关联docker01容器

docker run -it --name docker02 --volumes-from docker01 xiao-centos /bin/bash
  1. 创建docker03容器,继承关联docker01容器

docker run -it --name docker03 --volumes-from docker01 xiao-centos /bin/bash

以上三个容器之间数据同步共享,测试停止并删除docker01容器之后,docker02,docker03的数据存在且依然可以同步数据

多个MySQL实现数据共享

# 创建mysql01容器
docker run -d -p 3310:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e MYSQL_ROOT_PQSSWORD=123456 --name mysql01 mysql:5.7

# 创建mysql02容器,同步mysql01容器
docker run -d -p 3310:3306 -e MYSQL_ROOT_PQSSWORD=123456 --name mysql02 --volumes-from mysql02 mysql:5.7

通过 --volumes-from 实现数据共享(继承)

结论:

  1. 容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器为止。
  2. 同步到宿主机本机的数据,本地持久化

我是 甜点cc

热爱前端,也喜欢专研各种跟本职工作关系不大的技术,技术、产品兴趣广泛且浓厚,等待着一个创业机会。本号主要致力于分享个人经验总结,希望可以给一小部分人一些微小帮助。

希望能和大家一起努力营造一个良好的学习氛围,为了个人和家庭、为了我国的互联网物联网技术、数字化转型、数字经济发展做一点点贡献。数风流人物还看中国、看今朝、看你我。

今天关于《Docker | 数据持久化与数据共享》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>