Docker 容器数据卷用 V 命令添加 | 学习笔记

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 快速学习 Docker 容器数据卷用 V 命令添加

开发者学堂课程【Docker 快速入门:Docker 容器数据卷用 V 命令添加】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/616/detail/9402


Docker 容器数据卷用 V 命令添加

容器数据卷就是停止或者关闭以后,对于部分数据的持久化工作,想把保存下来,把保存在容器卷。

相当于外置的活动硬盘。功能主要是做容数据的持久化,容器间数据共享,甚至宿主机和容器之间的数据共享。如何添加相关的容器卷。有两种方法,第一种,直接命令添加,第二种 DockerFile,DockerFile 作为承上启下的知识点,在容器内添加数据卷,有两种方法,一个是命令,第二个是 DockerFile,通过 DockerFile 进行编写。在 docker 基础篇里面 DockerFile 是非常重要的概念。

1、直接命令添加。

(1)命令,docker run -it -v 自己本机通过某个镜像 run -it,有个交互性的终端开启,能够连上各自的容器,在这个命令的基础上,-v 是卷的英文缩写,/宿主机绝对路径目录:/容器内目录,镜像名。

宿机是虚拟器上的 centos_6.8。

image.png

打开根目录,在终端中打开。

image.png

宿主机Host。

image.png

当前在根目录下面,ll,可以看到宿主机的目录,假设在当前宿主机下面,创建myDataVolume 宿主机的目录,

docker run -it -v /myDataVolume:/ 容器内目录,镜像名

在根目录下没有 myDataVolume 目录,如果有了就是 Docker 命令创建的,容器内的目录一样,在 dataVolumeContainer 容器内,

docker run -it -v /myDataVolume:/dataVolumeContainer,镜像名

两个都在根目录下面,只不过 myDataVolume 是在 centos_6.8 宿主机,dataVolumeContainer 在容器里面,镜像生成实例。

container 容器内。

image.png

docker images,有 centos,

docker run -it centos /bin/bash

在容器里面的 centos 实例,

ll 下没有 dataVolumeContainer 文件夹,假设以最原始的方式去登陆,docker 登陆容器,centos 镜像生成的 f6a41a6b3758 容器,根目录下没有准备要写的dataVolumeContaine 文件夹。

exit 退出去,没有时两边都没有,不管是宿主机还是容器,都没有,在主机执行,执行 centos 镜像。

docker run -it -v /myDataVolume:/dataVolumeContainer centos

Docker ps 当前正在运行的容器实验,一个都没有,干干净净的。

在 centos 6.8 根目录下新建 myDataVolume,跟 docke 的 centos 容器根目录下的 dataVolumeContainer 达成连接,一个活动一趴插到笔记本上,开始容器和主机之间数据共享。

目前没有 myDataVolume。

image.png

执行,以 centos 为镜像,生成尾号是 8ede 的容器在 Docker 跑,刷新。

cd 根目录,ll,可以看到 myDataVolume。主机根目录下面没有 myDataVolume,现在新生成了,说明 -v 含有新建的功能,相当于 make dir,主机下面有 myDataVolume,但是里面没内容,登陆进 Docker 里面的容器 pwd,默认根目录,ll,可以看到 dataVolumeContainer,dataVolumeContainer 跟myDataVolume 进行了数据的共享和对接。Bind myDataVolume: V datavolumeContiner,从描述上可以清楚的看到。

(2)查看数据卷是否挂载成功。

再创建一个窗口,docker inspect 以 json 串的形式描述这个容器,以 centos 为例,得到 8ede 容器,docker inspec f89b5db98ede 回车,dataVolumeContainer 数据容器卷,跟 myDataVolume 宿主机绑定,从描述上可以清楚的看到。如果在 docker inspec 容器 id

中看到以下代码,说明绑定成功。Rw 读写,说明可以对 dataVolumeContainer 文件夹读写操作均可。

"Volumes": {

"/ dataVolumeContainer": " / myDataVolume"

},

"VolumesRw": {

" dataVolumeContainer: true

},

" AppArmorProfile":'

"ExecIDs": null,

" HostConfig": {

"Binds": [

' / myDataVolume: /dataVolumeContainer"

],

(3)容器和宿主机之间数据共享。

先看主机 cd myDataVolum,

在宿主机下的 myDataVolum 根目录下,

Touch host.txt 主机键,主机看到,

进入 container,尾号 8ede,

cd dataVolumeContainer 当前在容器下面,

Ll,有 host.txt,vim host.txt,因为 centos 不支持 vim,没有下载,因为是精简版的没有这个功能,vi host.txt,

container update 01 回车,可读可写,

touch container. txt

ll

在容器内,修改了主机的文件,还创建了一个,实现了宿主机和容器内的数据共享,

Cat host.txt

container update 01

(4)容器停止退出后,主机修改后数据是否同步。

exit 是退出停止容器,出门关灯,container 加 p 加 q,出门没关灯。

Docker ps

当前正在运行的容器,容器停止,但是主机还有,

touch host02. txt

主机又修改一次,主机有 vim,主机是 centos6.8 最全的 4g 大小的,不是容器上docker 跑的精简版 200 兆的,要分清,

Host update 01 改同一个文件,主机 host02.txt,如果把容器重新启动,再重新进去,里面会不会有新的数据,上一轮容器已经退出,主机又新建了 host 02,容器重新启动,主机改了能否同步,docker ps 当前没有运行任何实验,上一次运行的是 f89b5qb98ede,

Docker start f89b5qb98ede

Up 3 seconds 上一轮关闭的又重新启动,

Docker attch 重新进入容器,进入 f89b5qb98ede 容器,ll dataVolumeContainer,在 docker 容器里面的 centos 200 兆精简版,

dataVolumeContainer]# pwd

/dataVolumeContainer

dataVolumeContainer]# ll

host02. txt

关了之后只要留着 rdp 和 iof,重启之后又可以做一次全链数据的同步拉起,

Cat host.txt

container update 01

Host update 01

主机改过的都可以,容器停止退出后,主机修改后数据完全同步。

(5)命令(带权限)。

Docker inspect 查看了容器是否挂载成功,rw 是 true,如果 rw 不是 true 是false。有些硬盘写保护,相当于只可以查看,不可以删除硬盘上的东西,而有些硬盘是插上之后,随便干,就把 docker 容器当作活动硬盘,写保护。

docker run -it -v/ 宿主机绝对路径目录:/容器内目录: ro 镱像名

docker run -itI 镜像名

以镜像启动实例,容器数据卷

docker run -it -V /myDataVolume: /dataVqlumeContainer 镜像名

加了数据卷,但是 ro read only 只读,容器内的目录只读不可写。

执行docker run -it -V /myDataVolume: /dataVqlumeContainer :ro

rm-rf myDataVolume/当前目录下

Ll

Total0

文件夹没删除,后面新建会覆盖掉,如果为了怕出问题,可以把dataVqlumeContainer 删除重做,dataVqlumeContainer 里面可读可写,读写是ture,

exit容器停止并退出,回到 cocker ps,当前什么都没有,

再运行命令 docker run -it -V /myDataVolume: /dataVqlumeContainer :ro centos回车,进入容器,

ll 可以看到 dataVqlumeContainer,

Cd dataVqlumeContainer 容器测的 dataVqlumeContainer,在主机中可以看到myDataVolume,ll 总用量 0,也没有。

Touch host.txt 由于加了只读,主机上写了一个 host.txt 是否会同步过去,

Host update 主机修改过,cat host.txt 主机上有这个文件,且文件里面有内容,cat.host.txt 主机上有文件,且文件里面有内容 host update,

cat.host.txt 有,

touch container. txt 在文件夹里面不能新建,不能有写操作,

Vi host.txt 修改

Host update

Container update

强制保存退出,在写的过程中不能打开文件,写操作不支持,容器的数据只允许主机单向的操作传给它,容器只可以查看,但并不能做增删改。

Docker ps

新的容器 id 是 1c95e7d533f0。

docker inspect 1c95e7d533f0

进行了绑定。

Binds":

" / myDataVolume: /dataVolumeContainer: ro"

读写是 false,read-only file system 只可以读,不可以写,这就是用 docker-v 命令添加容器数据卷,达到容器和宿主机中间数据共享的目的。

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