温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

docker中数据持久化是什么样的

发布时间:2021-10-19 17:55:45 来源:亿速云 阅读:109 作者:柒染 栏目:大数据

本篇文章为大家展示了docker中数据持久化是什么样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

  • 方式一 (bind moumting)

先看一个Nginx dockerfile

FROM nginx
WORKDIR /usr/nginx/html
COPY index.html index.html

我们想吧容器里的工作目录挂载到我们 服务器 的数据卷上,以免容器删除后数据丢失。

  •     首先我们build dockerfile成一个image 取名为 saniii/my-nginx-mount

docker build -t saniii/my-nginx-mount .

docker中数据持久化是什么样的

  • 运行容器

docker run -d -p 3331:80 -v $(pwd):/usr/nginx/html --name nginx1 saniii/my-nginx-mount

-d 后台运行

-p 绑定主机端口到容器端口 3331:表示服务器的端口 :80 表示容器里的端口


-v 数据绑定 $(pwd) 代表当前路径 :/usr/nginx/html 为要绑定的容器里的路径 

 --name  容器命名为 nginx 1 

 saniii/my-nginx-mount 运行的容器名

docker中数据持久化是什么样的

  • 看下数据有没有绑定成功

docker exec -it nginx1 /bin/bash

交互式运行容器

我们在容器里创建一个文件,退出

docker中数据持久化是什么样的

  • 方式二(Volume)

我们可以在dockerfile中定义我们数据的在容器中的持久化路径

https://github.com/docker-library/mysql/blob/9d1f62552b5dcf25d3102f14eb82b579ce9f4a26/5.7/Dockerfile

上面是 mysql 官方dockerfile中的最佳实践 mysql在容器中运行的时候数据持久化在以下的路径

命令
  
  sudo docker run -d -v mysql:/var/lib/mysql --name mysql1 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7


-v 数据绑定 将我们数据volume命名为mysql   /var/lib/mysql容器中数据卷的路径  -e MYSQL_ALLOW_EMPTY_PASSWORD=true 设置mysql无密码

docker中数据持久化是什么样的

正在运行的Volume
  
  docker volume ls
查看Volume在主机上的持久化地址

docker volume inspect mysql

docker中数据持久化是什么样的

验证数据有没有成功持久化

交互式运行容器
	docker exec -it mysql1 /bin/bash

登录mysql 查看数据库 mysql -uroot -hlocalhost -p

我们创建一个数据库

docker中数据持久化是什么样的

退出容器并删除。

docker rm -f mysql1
	 -f 强制删除正在运行的容器

我们再启动一个mysql容器,使用之前的Volume mysql

sudo docker run -d -v mysql:/var/lib/mysql --name mysql2 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7

docker中数据持久化是什么样的

我们发现数据还是存在的。

这样我们就可以做到数据的持久化了。

上述内容就是docker中数据持久化是什么样的,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI