【Docker】在容器中管理数据&&数据卷挂载以及宿主机目录挂载

🎉🎉欢迎来到我的CSDN主页!🎉🎉

🏅我是平顶山大师,一个在CSDN分享笔记的博主。📚📚

🌟推荐给大家我的博客专栏《【Docker】在容器中管理数据》。🎯🎯

🎁如果感觉还不错的话请给我关注加三连吧!🎁🎁

docker在容器中管理数据主要有两种方式:

1- 数据卷(Volumes)

2- 挂载主机目录(Bind mounts)

一,数据卷

1.1数据卷作用:

**作用:为了很好的实现数据保存和数据共享,**以正常的文件或者目录的形式存在于宿主机上。又被称作数据卷。

**挂载数据卷的好处在于:**它使得Docker容器与主机之间可以共享数据,并且在容器删除后,数据仍然存在于主机上。这样,即使容器被删除或重新创建,数据也不会丢失。(安全性高)另外,通过挂载数据卷,我们还可以在多个容器之间共享数据,这对于搭建基于微服务架构的应用非常有用。同时,数据卷还支持读写分离、只读和权限设置等功能,使得数据在容器内外的访问更加灵活和安全。(方便不同数据中的操作,因为容器中的文件,数据是操作不了的,只能在容器建立之前进行增删改

1.2使用数据卷(命令)

都是增删改查的操作可以使用 容器+数据卷+create,ls,inspect,rm的记忆方法来记忆

创建数据卷

复制代码
docker volume create 数据卷名称

查看所有数据卷

复制代码
docker volume ls

查看数据卷信息

复制代码
docker volume inspect 数据卷名称

删除一个volume

复制代码
docker volume rm 数据卷名称

注意:数据卷 是被设计用来持久化数据的,它的生命周期独立于容器,Docker不会在容器被删除后自动 删除数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的数据卷,无主的数据卷 可能会占据很多空间,所以要及时删除.

挂载数据卷

在用 docker run 命令的时候,使用 --mount 标记来将 数据卷 挂载到容器里。在一次 docker run 中可以挂载多个数据卷 。如果容器,数据卷中没有对应的文件文件夹会自动创建。

复制代码
docker run -itd \
--name 容器名字 \
--mount source=数据卷名称,target=容器中的对应目录 \
镜像名称

查看是否挂载成功

首先查看我们数据卷的目录位置

docker inspect name

备注:

复制代码
docker run -it
 --name c1
--mount source=t1,target=/test1 \
centos

c1容器中又建立了test1文件夹

touch c1.txt --建立文件

cd --进入目录

二,挂载主机目录

2.1什么是目录挂载?

目录挂载是将主机上的一个目录直接挂载到容器中,容器中的文件会直接覆盖主机上的文件,这种方式不适合多个容器共享数据。目录挂载的好处是可以方便地将主机上的文件或目录与容器中的文件或目录进行同步,方便开发和调试。

2.目录挂载的基本使用

在宿主机上创建一个目录用于存放资源

复制代码
docker run -itd \
--name 容器名字 \
--mount type=bind,source=宿主机目录,target=容器中的对应目录 \
镜像名称

docker run -itd \ --运行一个新的容器且后台运行模式
--name t1 \ --起名字
-p 8080:8080 \ --将容器内的端口 8080 映射到宿主机的端口 8080等于访问外部8080就是访问到容器中8080

-v /soft:/user/local/tomcat/webapps \ --将本地宿主机上的目录 /soft 挂载到容器内

tomcat:8.5.20 --指定tomcat镜像版本启动容器,建议一样不然可能会报错

访问不到就尝试在防火墙上开端口

开放端口

firewall-cmd --zone=public --add-port=8080/tcp

sudo firewall-cmd --list-ports --查看已经开放的端口

firewall-cmd reload --刷新防火墙

但是这么它是将整个文件夹进行替换!!!!就相当于把其他内置的文件给覆盖了

三,针对目录挂载进行优化以及部署一个war包

认真写博客的人,见一个少一个🤩🤩🤩🤩🤩🤩🤩🤩🤩

👍 点赞支持,⭐️ 收藏学习,❤️ 关注不迷路~

💬 如有错漏请不吝指正~

平顶山大师-CSDN博客

相关推荐
wayuncn21 分钟前
月付物理服务器租用平台-青蛙云
运维·服务器·服务器租用·服务器托管·物理机租用
望获linux23 分钟前
【实时Linux实战系列】CPU 隔离与屏蔽技术
java·linux·运维·服务器·操作系统·开源软件·嵌入式软件
0wioiw038 分钟前
C#基础(项目结构和编译运行)
linux·运维·服务器
2401_873587822 小时前
Linux常见指令以及权限理解
linux·运维·服务器
RW~2 小时前
Minio安装配置,桶权限设置,nginx代理 https minio
运维·nginx·https·minio
李洋-蛟龙腾飞公司2 小时前
HarmonyOS NEXT应用元服务常见列表操作分组吸顶场景
linux·运维·windows
链上Sniper2 小时前
智能合约状态快照技术:实现 EVM 状态的快速同步与回滚
java·大数据·linux·运维·web3·区块链·智能合约
从零开始学习人工智能4 小时前
深入解析 OPC UA:工业自动化与物联网的关键技术
运维·物联网·自动化
从后端到QT4 小时前
SRS流媒体服务器(8)源码分析之rtc/rtmp互相转码详解
运维·服务器·实时音视频
CodeWithMe4 小时前
Nginx入门进阶:从零到高手的实战指南
运维·nginx