Docker基础之九: 管理容器的数据

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 管理容器的数据 到目前为止,我们已经介绍了Docker的一些基本概念,如:容器的操作,镜像的操作和网络的操作等。在本节,我们将介绍如何管理容器内部的数据,以及容器间的数据交互。我们将介绍如何创建: 数据卷 数据型容器 1 数据卷 数据卷是一个经过特殊设计的文件夹,提供给容器使用。数据卷并不

管理容器的数据

对Docker感兴趣的朋友可以加我的微信ghostcloud2016,然后我把你加到我们的一个Docker爱好者群组里面。

到目前为止,我们已经介绍了Docker的一些基本概念,如:容器的操作,镜像的操作和网络的操作等。在本节,我们将介绍如何管理容器内部的数据,以及容器间的数据交互。我们将介绍如何创建:

  • 数据卷
  • 数据型容器

1 数据卷

数据卷是一个经过特殊设计的文件夹,提供给容器使用。数据卷并不由UnionFS管理,因此数据卷可以用作持久化和数据分享,它具有以下特性:

  • 数据卷在容器创建的时候进行初始化。如果容器的镜像在特定的Mount点下有数据,那么已有的数据将被拷贝到指定目录。
  • 数据卷可以在容器间共享和复用
  • 对数据卷的改变是直接操作,不会回滚。
  • 当你更新镜像时,数据卷的改变不会被保存。
  • 即使容器被删除了,数据卷也不会丢失。

因此,数据卷是用来持久化数据的,跟容器本身的生命周期是无关的。Docker删除容器的时候,不会自动删除数据卷,因此当你使用数据卷的时候也要注意不要产生过多的垃圾数据。

2 添加数据卷

数据卷是通过-v来指定的,在docker create和docker run的时候可以使用多个-v参数,指定多个数据卷。

$ docker run -d -P --name web -v /webapp training/webapp python app.py
AI 代码解读

这条命令在创建容器时,会创建一个/webapp目录。 注意:我们也可以通过VOLUME指令在Dockerfile中指定需要Mount的数据卷。 默认情况下,数据卷是可读可写的,但是你也可以设置为只读:

$ docker run -d -P --name web -v /opt/webapp:ro training/webapp python app.py
AI 代码解读

3 定位卷的位置

$ docker inspect web
...
Mounts": [
    {
        "Name": "fac362...80535",
        "Source": "/var/lib/docker/volumes/fac362...80535/_data",
        "Destination": "/webapp",
        "Driver": "local",
        "Mode": "",
        "RW": true
    }
]
...
AI 代码解读

其中source是文件系统在主机上的地址(注意这个地址是随机分配的,因此一定要注意垃圾回收),Destination是容器中的地址。

4 Mount本地文件夹作为数据卷

通过-v我们可以给容器添加一个随机的数据卷,但是这种卷是不好控制的,因此我们可以Mount一个本地文件夹作为数据卷。

$ docker run -d -P --name web -v /src/webapp:/opt/webapp training/webapp python app.py
AI 代码解读

上面这条命令,我们将本地的/src/webapp映射到了容器的/opt/webapp目录。由于将主机的文件系统映射到了容器中,因此容器有了主机的完全访问权限,因此一定要注意安全。

5 Mount本地文件到容器中

-v参数除了可以Mount文件夹,还可以做文件的映射。比如:

$ docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu /bin/bash
AI 代码解读

这条命令,将把主机的~/.bash_histroy映射到容器中,因此主机和容器可以共享Bash命令的历史数据。如果将~/.bash_profile映射进去,那就可以共享Bash的配置。

6 数据型容器

如果你希望在容器间共享卷,那么就可以使用数据型容器。我们可以先创建一个命名容器:

$ docker create -v /dbdata --name dbdata ubuntu
AI 代码解读

接下来,我们通过--volumes-from选项来进行数据卷的复用:

$ docker run -it --volumes-from dbdata --name db1 ubuntu
AI 代码解读

然后再建一个容器:

$ docker run -it --volumes-from dbdata --name db2 ubuntu
AI 代码解读

之后我们就可以在db1和db2中同时对/dbdata进行操作了。

7 数据备份、还原和迁移

我们可以通过下面的命令进行数据备份:

$ docker run --volumes-from dbdata -v $(pwd):/backup ubuntu tar cvf /backup/backup.tar /dbdata
AI 代码解读
  • --volumes-from将把dbdata容器的数据卷Mount到当前容器;
  • -v 将当前目录映射到/backup目录
  • tar命令将/dbdata打包

接下来,我们可以对容器进行数据恢复:

$ docker run -v /dbdata --name dbdata2 ubuntu /bin/bash
AI 代码解读
$ docker run --volumes-from dbstore2 -v $(pwd):/backup ubuntu bash -c "cd /dbdata && tar xvf /backup/backup.tar"
AI 代码解读

通过上面的操作,我们就可以自动备份、还原和迁移数据了。

8 注意事项

由于数据卷的共享,会出现多个容器同时写一个卷的情况,因此可能会导致数据丢失,这里面一定要特别注意。可以采取一定的同步机制来保证数据的一致性。

目录
打赏
0
2
2
0
105
分享
相关文章
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
279 93
Docker+consul容器服务的更新与发现
通过本文的介绍,我们详细探讨了如何结合Docker和Consul来实现容器服务的更新与发现。通过Consul的服务注册和发现功能,可以高效地管理和监控容器化服务,确保系统的高可用性和可扩展性。希望本文能帮助您在实际项目中更好地应用Docker和Consul,提高系统的可靠性和管理效率。
63 23
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
313 15
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
203 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
73 17
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
134 12
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
285 11
课时5:阿里云容器服务:最原生的集成Docker和云服务
阿里云容器服务以服务化形式构建容器基础设施,大幅提升开发效率,简化应用部署流程。通过Docker容器和DevOps工具(如Jenkins),实现自动化部署与迭代,优化企业内部复杂部署问题。该服务支持GPU调度、混合云架构无缝迁移,并与阿里云产品体系无缝集成,提供安全防护、网络负载均衡等多重功能支持。凭借微服务架构,帮助企业突破业务瓶颈,提高资源利用率,轻松应对海量流量。
课时5:阿里云容器服务:最原生的集成Docker和云服务
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
330 78
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序

热门文章

最新文章