V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
alfredhuo
V2EX  ›  Docker

docker 容器中的 IO 速度和 宿主机上的 IO 速度是什么关系?

  •  
  •   alfredhuo · 2021-05-19 21:07:33 +08:00 · 2036 次点击
    这是一个创建于 1066 天前的主题,其中的信息可能已经有所发展或是发生改变。
    是否是宿主机上的 IO 高,容器中的 IO 也会高呢
    8 条回复    2021-05-20 10:40:36 +08:00
    geekvcn
        1
    geekvcn  
       2021-05-19 21:36:35 +08:00 via iPhone
    肯定啊,宿主机决定 IO 上限,docker IO 操作用的就是宿主机内核,你映射的目录和驱动器也是宿主机。但是仅限于 Linux,windows 和 mac 的 docker 不是内核直接兼容的,是通过虚拟机跑 linux 实现的,这就有 IO 损耗了,但是再损耗也肯定是宿主机 IO 速度越快容器中也越快
    BeautifulSoap
        2
    BeautifulSoap  
       2021-05-19 21:43:32 +08:00 via Android
    docker 哪来的宿主啊,又不是虚拟机。docker 里的进程都是直接跑在你系统上的本地进程,所以性能没有多大损失(不过 Windows 和 mac 下的 docker 是跑在 linux 上的所以 io 性能是有损失的。windows 下用 wsl2 backend 的话似乎文件 io 会更差点,但是直接在 wsl2 中和 docker 交互的话性能就非常好了)
    yitingbai
        3
    yitingbai  
       2021-05-19 22:25:46 +08:00
    mac 上的 docker io 速度慢到离谱, 不知道现在新版本解决了没有
    mxalbert1996
        4
    mxalbert1996  
       2021-05-20 00:32:23 +08:00 via Android
    @BeautifulSoap Docker 当然存在 host 和 container 的概念。
    @yitingbai 用了 gRPC-FUSE 以后好了一些,但还是很慢。
    whileFalse
        5
    whileFalse  
       2021-05-20 08:22:01 +08:00
    @yitingbai 你是指把 Mac 下的卷挂到容器里的时候慢到离谱吗?
    good
        6
    good  
       2021-05-20 09:37:17 +08:00
    @yitingbai #3 在虚拟机里跑 docker 吧
    yitingbai
        7
    yitingbai  
       2021-05-20 10:03:02 +08:00
    @whileFalse 不管挂不挂都慢, 曾经我以为 docker 比较轻量比虚拟机快, 想用来编译 Android 源码, 结果那 IO 速度极慢, 根本无法使用, 当然我也没仔细研究, 好像装个什么软件可以优化一下, 但是也远比 Linux 上的 Docker 慢
    whileFalse
        8
    whileFalse  
       2021-05-20 10:40:36 +08:00
    @yitingbai 首先,Docker for Mac 是跑在虚拟机里的,所以只可能比虚拟机慢或相同,不可能比虚拟机快;其次,Docker for Mac 所使用的挂载卷通过网络协议挂载的,所以会非常慢。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1483 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 17:11 · PVG 01:11 · LAX 10:11 · JFK 13:11
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.