2

我正在启动多个链接容器。所有容器都将主机目录 /var/log/tipsi/ 挂载到同一个内部目录。我仅从最后一个容器中看到 /var/log/tipsi 中的文件的问题:

  1. tipsi_solr 和tipsi_erl 具有相同的文件集
  2. Tipsi_web 容器(最后启动的容器)看不到上面的文件,只能看到它自己的文件
  3. 主机目录仅包含来自 #2 (tipsi_web) 的文件

我正在使用图启动容器。这是使用的配置:

solr:
    build: ../tipsi_solr/
    volumes:
     - /var/log/tipsi:/var/log/tipsi
     - /home/docker/code/tipsi/solr/collection1/data

erl:
    build: ../tipsi_erl/
    volumes:
     - /var/log/tipsi:/var/log/tipsi

web:
   build: .
   volumes:
     - /var/log/tipsi:/var/log/tipsi
     - /etc/cert:/etc/cert

   ports:
     - "443:443"
     - "80:80"

   links:
     - solr:tipsi-solr.local
     - erl:tipsi-erl.local

有趣的是 - lsof 显示了tipsi_erl pid 的缺失文件(在主机上启动):

prompt:~$ sudo lsof -p 12717
COMMAND    PID USER   FD   TYPE DEVICE SIZE/OFF    NODE NAME
beam.smp 12717 root   12w   REG  252,0        0 9323763 /var/log/tipsi/stacked_cache_error.log
beam.smp 12717 root   13w   REG  252,0   739192 9323765 /var/log/tipsi/stacked_cache_debug.log

但其他应用程序无法访问它们:

ls /var/log/tipsi/stacked_cache_debug.log                                                                                                             22:35:29
ls: cannot access /var/log/tipsi/stacked_cache_debug.log: No such file or directory

此外,我尝试在 Dockerfile 中为所有容器指定和删除 VOLUME 参数,但没有任何运气。任何想法为什么不显示这些文件?

4

1 回答 1

4

我相信你正在点击https://github.com/docker/fig/issues/447

如果您VOLUME在某一时刻添加到 Dockerfile,则在重新创建时会不断获取该卷的内容。

您应该fig rm --force清除旧容器,然后它应该开始工作并使用主机卷。

于 2015-01-02T22:34:00.940 回答