22

我意识到其他人也有类似的问题,但这使用 v2 compose 文件格式,我没有找到任何相关信息。

我想制作一个非常简单的测试应用程序来使用 MemSQL,但我无法让卷在docker-compose down. 如果我对 Docker Docs 的理解正确,那么不应该在没有明确告知的情况下删除卷。一切似乎都可以正常工作,docker-compose up但是在下降然后再次上升之后,所有数据都会从数据库中删除。

作为一种好的做法,我使用单独的 memsqldata 服务作为单独的数据层。

这是我的 docker-compose.yml:

version: '2'
services:
    app:
        build: .
        links:
            - memsql
    memsql:
        image: memsql/quickstart
        volumes_from:
            - memsqldata
        ports:
            - "3306:3306"
            - "9000:9000"
    memsqldata:
        image: memsql/quickstart
        command: /bin/true
        volumes:
            - memsqldatavolume:/data

volumes:
    memsqldatavolume:
        driver: local
4

5 回答 5

30

我意识到这是一个古老且已解决的线程,其中 OP 指向容器中的目录而不是它们已安装的卷,但想清除我看到的一些错误信息。

docker-compose down不删除卷,docker-compose down -v如果您还想删除卷,则需要运行。这是直接来自 docker-compose 的帮助文本(注意“默认”列表):

$ docker-compose down --help
Stops containers and removes containers, networks, volumes, and images
created by `up`.

By default, the only things removed are:

- Containers for services defined in the Compose file
- Networks defined in the `networks` section of the Compose file
- The default network, if one is used

Networks and volumes defined as `external` are never removed.

Usage: down [options]

Options:
...
    -v, --volumes       Remove named volumes declared in the `volumes` section
                        of the Compose file and anonymous volumes
                        attached to containers.
...

$ docker-compose --version
docker-compose version 1.12.0, build b31ff33

这是一个带有要测试的命名卷和一个虚拟命令的示例 yml:

$ cat docker-compose.vol-named.yml
version: '2'

volumes:
  data:

services:
  test:
    image: busybox
    command: tail -f /dev/null
    volumes:
    - data:/data

$ docker-compose -f docker-compose.vol-named.yml up -d
Creating volume "test_data" with default driver
Creating test_test_1

启动容器后,卷初始化为空,因为该位置的映像为空。我在那个位置创建了一个快速的hello world:

$ docker exec -it test_test_1 /bin/sh
/ # ls -al /data
total 8
drwxr-xr-x    2 root     root          4096 May 23 01:24 .
drwxr-xr-x    1 root     root          4096 May 23 01:24 ..
/ # echo "hello volume" >/data/hello.txt
/ # ls -al /data
total 12
drwxr-xr-x    2 root     root          4096 May 23 01:24 .
drwxr-xr-x    1 root     root          4096 May 23 01:24 ..
-rw-r--r--    1 root     root            13 May 23 01:24 hello.txt
/ # cat /data/hello.txt
hello volume
/ # exit

该卷在 docker 外部可见,并且在 a 之后仍然存在docker-compose down

$ docker volume ls | grep test_
local               test_data

$ docker-compose -f docker-compose.vol-named.yml down
Stopping test_test_1 ... done
Removing test_test_1 ... done
Removing network test_default

$ docker volume ls | grep test_
local               test_data

重新创建容器使用旧卷,其中文件仍然可见:

$ docker-compose -f docker-compose.vol-named.yml up -d
Creating network "test_default" with the default driver
Creating test_test_1

$ docker exec -it test_test_1 /bin/sh
/ # cat /data/hello.txt
hello volume
/ # exit

并运行docker-compose down -vfinally 删除容器和卷:

$ docker-compose -f docker-compose.vol-named.yml down -v
Stopping test_test_1 ... done
Removing test_test_1 ... done
Removing network test_default
Removing volume test_data

$ docker volume ls | grep test_

$

如果您发现您的数据仅在使用停止/启动而不是向下/向上时才被持久化,那么您的数据将存储在容器(或可能是匿名卷)而不是您的命名卷中,并且容器不是执着的。确保容器内数据的位置正确以避免这种情况。

要调试数据存储在容器中的位置,我建议docker diff在容器上使用。这将显示在该容器内创建、修改或删除的所有文件,这些文件在容器被删除时将丢失。例如:

$ docker run --name test-diff busybox \
  /bin/sh -c "echo hello docker >/etc/hello.conf"

$ docker diff test-diff
C /etc
A /etc/hello.conf
于 2017-05-23T01:35:43.933 回答
4

您正在使用docker-compose down,如果您查看此处的文档

停止容器并删除由up. 默认情况下仅删除容器和网络。

你是对的,它不应该删除卷(默认情况下)。这可能是一个错误,或者您可能更改了默认配置。但我认为适合您的命令是docker-compose stop. 我将尝试使用更简单的命令案例进行一些测试down

于 2016-02-25T08:17:32.100 回答
4

这可以追溯到 MemSQL 的错误文档。memsql/quickstart容器中的MemSQL 数据路径/memsql/var/lib/memsql独立安装(和 MemSQL 文档中)不同,而且绝对/data不像有人告诉我的那样。

于 2016-03-09T18:21:11.810 回答
3

最简单的解决方案是使用docker-compose stop而不是docker-compose down. 然后docker-compose start重新启动。

根据文档down“停止容器并删除由 up 创建的容器、网络、卷和图像。”

于 2017-05-23T00:14:04.010 回答
3

不确定这是否有帮助。当您使用docker-compose up -d容器时,将下载容器并创建图像。要停止 docker 图像,请使用docker-compose down,图像将保留并可以重新启动docker-compose start

我正在使用向上/向下命令并一直丢失我的数据,直到我尝试停止/启动并且现在数据仍然存在。

于 2016-10-12T13:27:38.953 回答