如果我使用以下$ docker-compose down
运行.yml
,我似乎无法保持MySQL数据的持久性
version: '2'
services:
# other services
data:
container_name: flask_data
image: mysql:latest
volumes:
- /var/lib/mysql
command: "true"
mysql:
container_name: flask_mysql
restart: always
image: mysql:latest
environment:
MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
MYSQL_USER: 'test'
MYSQL_PASS: 'pass'
volumes_from:
- data
ports:
- "3306:3306"
我的理解是在我的data
容器中使用volumes: - /var/lib/mysql
将它映射到我的本地机器目录,其中mysql将数据存储到容器中,并且由于这种映射,即使容器被销毁,数据也应该保持不变。并且mysql
容器只是进入数据库的客户端接口,因为volumes_from: - data
而可以看到本地目录
尝试这个答案,它没有用。 Docker-Compose持久性数据问题
_编辑_
改变了我的.yml
,如下所示并创建了一个dir ./data
但是现在当我运行docker-compose up --build
时mysql
容器不会开始抛出错误说
data:
container_name: flask_data
image: mysql:latest
volumes:
- ./data:/var/lib/mysql
command: "true"
mysql:
container_name: flask_mysql
restart: always
image: mysql:latest
environment:
MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
MYSQL_USER: 'test'
MYSQL_PASS: 'pass'
volumes_from:
- data
ports:
- "3306:3306"
flask_mysql | mysqld: Can't create/write to file '/var/lib/mysql/is_writable' (Errcode: 13 - Permission denied)
flask_mysql | 2016-08-26T22:29:21.182144Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
flask_mysql | 2016-08-26T22:29:21.185392Z 0 [ERROR] --initialize specified but the data directory exists and is not writable. Aborting.
数据容器是一个多余的解决方法。 数据量 可以帮到你。将docker-compose.yml
更改为:
version: '2'
services:
mysql:
container_name: flask_mysql
restart: always
image: mysql:latest
environment:
MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
MYSQL_USER: 'test'
MYSQL_PASS: 'pass'
volumes:
- my-datavolume:/var/lib/mysql
volumes:
my-datavolume:
Docker将在/var/lib/docker/volumes
文件夹中为您创建卷。只要您没有输入docker-compose down -v
,此卷就会一直存在
有3种方式:
第一种方式
您需要在 主机上指定存储mysql数据的目录 。然后,您可以删除数据容器。您的mysql数据将保存在本地文件系统中。
Mysql容器定义必须如下所示:
mysql:
container_name: flask_mysql
restart: always
image: mysql:latest
environment:
MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
MYSQL_USER: 'test'
MYSQL_PASS: 'pass'
volumes:
- /opt/mysql_data:/var/lib/mysql
ports:
- "3306:3306"
第二种方式
在键入docker-compose down
之前提交数据容器:
docker commit my_data_container
docker-compose down
第三种方式
你也可以使用docker-compose stop
而不是docker-compose down
(那时你不需要提交容器)
您必须为mysql数据创建单独的卷。
所以它看起来像这样:
volumes_from:
- data
volumes:
- ./mysql-data:/var/lib/mysql
不,/var/lib/mysql
是mysql容器中的路径,与主机上的路径无关。您的主机甚至可能根本没有mysql。因此,目标是从mysql容器中持久保存内部文件夹。
实际上这是路径,你应该提到一个有效的路径来工作。如果你的数据目录在当前目录中,那么你应该提到my-data
而不是./my-data
,否则它也会在mysql
和mariadb
中给你这个错误。
volumes:
./my-data:/var/lib/mysql