Docker容器共享磁盘
需求:.NET程序需要监控一个FTP上的文件变化并进行操作,在linux上使用原生目录时,不管怎么切换后台运行,总是会在一段时间运行后死掉。
方案:远程也不好debug,想了一下,干脆直接使用docker-compose运行,设置死了自动重启(restart=always)就完事了。
由于FTP与.NET程序是两个单独的程序,因此需要进行磁盘共享才可以正常使用,研究了一下怎么使用Docker进行磁盘共享的方法。
使用卷
可以使用命名卷或者匿名卷操作。
匿名卷
匿名数据卷(anonymous volume)是没有显式指定名称的数据卷。当定义了一个匿名卷时,Docker会为该卷分配一个随机的名称,并将其挂载到容器的文件系统中。这样做的好处是使得数据卷的管理更加简单,并且可以避免命名冲突。
使用匿名卷实现Docker容器间共享磁盘的Docker Compose配置:
version: '3.7'
services:
containerA:
image: myimageA
volumes:
- shared-data:/path/to/shared/directory
containerB:
image: myimageB
volumes:
- shared-data:/path/to/shared/directory
volumes:
shared-data:
上面定义了一个名为“shared-data”的匿名卷,并将其挂载到两个容器的相同目录中。这将使容器A和B都能够访问该目录并共享数据。
使用匿名卷有以下优点:
- 管理更加简单。因为不需要为每个数据卷分配一个唯一的名称,所以您可以更轻松地管理应用程序中的所有数据卷。
- 避免命名冲突。由于每个匿名卷都有一个随机的名称,所以可以避免命名冲突,从而提高整个应用程序的安全性和可靠性。
但是,使用匿名卷也有一些缺点:
- 不易识别。由于匿名卷没有名称,因此很难识别哪个卷属于哪个容器。
- 不易备份和恢复。由于匿名卷没有名称,因此在备份和恢复过程中可能会导致一些问题。
命名卷
命名卷(named volume)是需要显式指定名称的数据卷。通过添加name属性来指定这个卷的名称的好处是可以更清晰地识别哪个卷属于哪个容器,并且可以更方便地备份和恢复数据。
使用命名卷实现Docker容器间共享磁盘的Docker Compose配置:
version: '3.7'
services:
containerA:
image: myimageA
volumes:
- shared-data:/path/to/shared/directory
containerB:
image: myimageB
volumes:
- shared-data:/path/to/shared/directory
volumes:
shared-data:
name: my-named-volume
上面定义了一个名为“shared-data”的命名卷,并将其挂载到两个容器的相同目录中。与匿名卷不同的是,我们通过添加name属性来指定这个卷的名称为“my-named-volume”。这将使容器A和B都能够访问该目录并共享数据。
使用命名卷有以下优点:
- 易于识别。由于每个命名卷都有一个唯一的名称,因此可以更轻松地识别哪个卷属于哪个容器。
- 易于备份和恢复。由于命名卷有唯一的名称,可以更方便地备份和恢复数据。
但是,使用命名卷也有一些缺点:
- 需要手动指定名称。与匿名卷不同的是,需要为每个命名卷手动指定名称,这可能会导致一些问题。
- 命名冲突。如果多个容器试图使用相同的命名卷名称,则会发生命名冲突,这可能会影响应用程序的安全性和可靠性。
直接挂载宿主机目录
另一种实现Docker容器间共享磁盘的方法是直接将宿主机上的目录挂载到容器中的目录。这种方法非常简单,可以直接在Docker Compose文件中使用绝对路径来挂载一个目录。
下面是直接挂载宿主机目录实现Docker容器间共享磁盘的示例Docker Compose配置:
version: '3.7'
services:
containerA:
image: myimageA
volumes:
- /path/to/shared/directory:/path/to/shared/directory
containerB:
image: myimageB
volumes:
- /path/to/shared/directory:/path/to/shared/directory
以上直接将宿主机上的/path/to/shared/directory目录挂载到两个容器的相同目录中。这将使容器A和B都能够访问该目录并共享数据。
使用直接挂载宿主机目录有以下优点:
- 易于管理。可以轻松地访问、备份和恢复数据,因为它们存储在宿主机上。
- 易于识别。可以轻松地找到哪个目录属于哪个容器,从而更好地组织和管理数据。
但是,使用直接挂载宿主机目录也有一些缺点:
- 安全风险。如果宿主机被攻击或出现故障,数据可能会受到威胁。
- 不可移植。如果想要将应用程序移动到另一台机器上,必须确保拥有相同的目录结构和路径。
总结
最后我还是选择了命名卷的方法部署程序,主要考虑到以后保留迁移的可能性,但是又保留一定的程序独立启动与配置的功能。
本文编写借助了new bing,人工有所修改和校对,代码思路没有问题。
Docker容器共享磁盘的更多相关文章
- docker容器共享宿主机环境,从而为镜像体积减负
一.背景介绍 响应公司技术发展路线,开发的服务均需要将打成docker镜像,使用docker进行统一管理.可是随着服务越来越多,镜像也越来越多.每次制作镜像的时候都需要将依赖打进容器,这样一个jre的 ...
- docker容器安全
title: docker容器安全 tags: Docker,容器,安全策略 grammar_cjkRuby: true --- Docker容器的安全性 1.安全策略-Cgroup 1.限制Cpu ...
- Docker容器(一)——Docker的介绍与部署
(1).Docker概述 Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的Linux或Windows机器上,也可以实现虚拟化.容器是 ...
- Kubernetes & Docker 容器网络终极之战(十四)
目录 一.单主机 Docker 网络通信 1.1.host 模式 1.2 Bridge 模式 1.3 Container 模式 1.4.None 模式 二.跨主机 Docker 网络通信分类 2.1 ...
- 从Docker容器内部,如何连接到本机的本地主机?
原文 从Docker容器内部,如何连接到本机的本地主机? 编辑:如果您使用的是Docker-for-mac或Docker-for-Windows 18.03+,只需使用主机连接到您的mysql服务即可 ...
- Docker for window 无法共享磁盘
Docker for window 无法共享主机磁盘,环境如下: 操作系统: windown10 Docker version 18.09.0, build 4d60db4 症状如下: 如图,点击ap ...
- docker容器磁盘
docker容器磁盘扩容 一.配置文件里更改容器创建时的默认磁盘大小 [root@ip---- ~]# cat /etc/sysconfig/docker-storage DOCKER_STORAGE ...
- docker容器存放目录磁盘空间满了,转移数据修改Docker默认存储位置
原文:docker容器存放目录磁盘空间满了,转移数据修改Docker默认存储位置 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/qq_3767485 ...
- 5、docker容器数据卷: -v添加共享传递容器数据卷
1.是什么 1.docker理念 先来看看Docker的理念:* 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的* 容器之间希望有可能共享数据 2.保 ...
- docker容器互联,实现目录、服务共享
一.需求 docker使服务之间实现容器隔离,比如Javaweb项目前端.后端.数据库.数据库后台,分别把它们部署在不同的容器里面,实现隔离.但服务和服务之间也有互访的需求,这就涉及到容器网络和容器互 ...
随机推荐
- 简化版本的redis配置文件
# bind 192.168.1.100 10.0.0.1 # bind 127.0.0.1 ::1 #bind 127.0.0.1 protected-mode no port 6379 tcp-b ...
- es6有哪些新特性?
1. let 和 ocnst ,可以定义块级作用域 2. 新增了箭头函数,箭头函数简化了函数定义的定义 3.新增了promise解决回调地狱问题 ps:回调地狱是我们异步请求服务器数据时,通过then ...
- tekton初次安装报错“containers with incomplete status: [place-tools]”
报错内容 在按照官方部署方式部署完毕以后,执行第一个taskrun的时候就报错了,报错如下 Status: Conditions: Last Transition Time: 2022-08-08T0 ...
- 深入理解Java并发读写锁——ReentrantReadWriteLock
ReentrantReadWriteLock使用场景 ReentrantReadWriteLock 是 Java 的一种读写锁,它允许多个读线程同时访问,但只允许一个写线程访问(会阻塞所有的读写线程) ...
- 云原生周刊:KubeCon China 2023 详细议程公布 | 2023.8.7
开源项目推荐 Spiderpool Spiderpool 是一个 Kubernetes 底层网络解决方案.它提供丰富的 IPAM 功能和 CNI 集成能力,为开源社区的 CNI 项目提供支持,允许多个 ...
- 云原生周刊:12 个容易忽略的 Kubernetes 安装错误
文章推荐 12 个容易忽略的 Kubernetes 安装错误 这篇文章总结了 12 个在 Kubernetes 安装过程中容易忽略但却必须注意的错误.这些错误包括: 没有正确安装 kubectl. 没 ...
- 欢迎体验程序员Lingma的助攻手
如果你是一位软件开发者,(同义灵码)Lingma可以帮助你做基础架构的脚手架相关工作事宜以及部分代码开发,对比之前没有灵码,现在提效了她可以给予你零编码的快感,准确快速地读懂了你我的需求,例如答问场景 ...
- Linux利用ftp命令上传下载文件
Linux中如何使用ftp命令,包括如何连接ftp服务器,上传or下载文件以及创建文件夹.虽然现在有很多ftp桌面应用(例如:FlashFXP),但是在服务器.SSH.远程会话中掌握命令行ftp的使用 ...
- ClickHouse-查询优化
单表查询[使用的频率高] 1.prewhere代表where Prewhere 和 where 语句的作用相同,用来过滤数据.不同之处在于 prewhere 只支持*MergeTree 族系列引擎的表 ...
- Nuxt.js 应用中的 build:error 事件钩子详解
title: Nuxt.js 应用中的 build:error 事件钩子详解 date: 2024/11/7 updated: 2024/11/7 author: cmdragon excerpt: ...