docker存储

注意:数据卷挂载(卷映射):Docker会自动创建数据卷,并将容器运行所需的文件复制到数据卷中。 目录挂载:如果宿主机上没有对应的目录,容器会因为缺少运行所需的文件而出错。

1.目录挂载

指令:

复制代码
docker run -d --name app01 -p 80:80 -v /app/nginx/html:/usr/share/nginx/html nginx

-v /app/nginx/html:/usr/share/nginx/html

app/nginx/html代表外部目录,/usr/share/nginx/html容器内部目录,把容器内部目录映射到外部目录,操做一个另一个也会改变。

修改外部目录:vi /app/nginx/html/index.html

index.html

复制代码
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>docker</title>
</head>
<body>
    <h1>目录挂在</h1>
    <p>docker run -d --name app01 -p 80:80 -v /app/nginx/html:/usr/share/nginx/html nginx</p>
</body>
</html>

效果:

2.卷映射

先来看一下nginx容器的内部配置文件位置 /etc/nginx,通过下面指令进入一个nginx容器内部,查看配置文件。

命令:ngconf是创建的卷名

复制代码
docker run -d -p 89:80 --name app02 -v /app/nginx/html:/usr/share/nginx/html -v ngconf:/etc/nginx nginx

外部生成的卷存放位置 /var/lib/docker/volumes

快速查看卷和创建卷的方式

3.卷映射和文件映射的区别

在Docker中,目录挂载和数据卷挂载是两种常见的挂载方式,它们各有优缺点,适用于不同的场景。

3.1目录挂载

目录挂载是将宿主机上的一个目录直接挂载到容器内的一个目录。这样,容器内的应用程序可以直接访问和修改宿主机上的文件。使用目录挂载的命令如下:

docker run -d --name nginx_dir -p 8080:80 -v /app/nginx/html:/usr/share/nginx/share nginx

优点

  • 易于查找和维护:目录和文件在宿主机上可见,便于查找和管理。

  • 直接挂载:可以直接将宿主机上的目录或文件挂载到容器中。

缺点

  • 需要手动创建和维护:需要手动在宿主机上创建和维护目录和文件。

  • 可能导致权限问题:如果宿主机上的目录或文件权限设置不当,可能会导致容器无法访问。

3.2卷映射或者数据卷挂载

数据卷挂载是将Docker管理的数据卷挂载到容器内的一个目录。数据卷是由Docker管理的特殊目录,存储在宿主机的文件系统中,但不直接暴露给用户。使用数据卷挂载的命令如下:

docker run -d --name nginx_volume -p 8080:80 -v my_volume:/etc/nginx nginx

优点

  • 自动管理:Docker会自动创建和管理数据卷,简化了操作。

  • 数据持久化:即使容器删除,数据卷中的数据仍然保留。

  • 多容器共享:多个容器可以共享同一个数据卷,实现数据共享。

缺点

  • 不易查找:数据卷存储在宿主机的文件系统中,路径较深,不易查找。

  • 依赖Docker管理:需要依赖Docker来管理数据卷,增加了复杂性。

3.2实验对比

  1. 宿主机没有对应的目录或数据卷: 数据卷挂载:Docker会自动创建数据卷,并将容器运行所需的文件复制到数据卷中。 目录挂载:如果宿主机上没有对应的目录,容器会因为缺少运行所需的文件而出错。

  2. 宿主机有对应的目录或数据卷: 数据卷挂载:容器内的数据会覆盖数据卷中的数据。 目录挂载:容器会加载宿主机上的目录,保证容器的正常运行。

  3. 多容器共享: 数据卷挂载和目录挂载:都可以实现多个容器共享文件,通过修改共享的文件,可以在不同的端口访问相同的数据。

总结

选择目录挂载还是数据卷挂载,取决于具体的使用场景和需求。如果需要方便地查找和管理文件,可以选择目录挂载;如果需要数据持久化和多容器共享,可以选择数据卷挂载

相关推荐
ICT系统集成阿祥12 分钟前
负载均衡—会话保持技术详解
运维·负载均衡
付出不多16 分钟前
linux——mysql高可用
linux·运维·mysql
L汐5 小时前
07 负载均衡
运维·nginx·负载均衡
pjx9875 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
牛奔5 小时前
Docker配置远程连接
运维·docker·云原生·容器·eureka
VR最前沿5 小时前
构建集成差异化灵巧手和先进机器人控制技术的自动化系统
运维·机器人·自动化
蟑螂恶霸6 小时前
解决ubuntu20中tracker占用过多cpu,引起的风扇狂转
linux·运维·ubuntu
my_styles6 小时前
docker-compose部署项目(springboot服务)以及基础环境(mysql、redis等)ruoyi-ry
spring boot·redis·后端·mysql·spring cloud·docker·容器
1024小神6 小时前
tauri2项目使用sidcar嵌入可执行文件并使用命令行调用
linux·运维·服务器
AI风老师7 小时前
2、ubuntu系统配置OpenSSH | 使用vscode或pycharm远程连接
linux·运维·服务器·ssh