Mi rendo conto che questo è un thread vecchio e risolto in cui l'OP stava puntando a una directory nel contenitore piuttosto che al volume che avevano montato, ma voleva chiarire parte della disinformazione che sto vedendo.
docker-compose down
non rimuove i volumi, è necessario eseguire docker-compose down -v
se si desidera eliminare anche i volumi.Ecco il testo della guida direttamente dalla finestra mobile-composizione (notare il "default" lista):
$ 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
Ecco un yml campione con un volume di nome per testare e un comando fittizio:
$ 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
Dopo l'avvio il contenitore, il volume è inizializzato vuoto poiché l'immagine è vuota in quella posizione. Ho creato un mondo ciao veloce in quella posizione:
$ 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
Il volume è visibile al di fuori finestra mobile ed è ancora lì dopo un 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
Ricreare il contenitore utilizza il vecchio volume con il file ancora all'interno visibile:
$ 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
e l'esecuzione di un docker-compose down -v
finalmente rimuove sia il contenitore e il volume:
$ 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_
$
Se trovate i dati è solo essere persisteva se si utilizza uno stop/start, piuttosto che un down/up, quindi i dati vengono archiviati nel contenitore, piuttosto che un volume, e il contenitore non è persistente . Assicurati che la posizione dei dati all'interno del contenitore sia corretta per evitare questo.
Vorrei provare senza il contenitore memsqldata. Poiché stai utilizzando un volume con nome, non è necessario un contenitore del volume di dati. Ho provato 'down', e non rimuove alcun volume per impostazione predefinita. – dnephin
È possibile che i dati mysql non siano nel volume? Non penso che usi '/ data' normalmente. – dnephin