问题
如果我挂载父目录 /var/lib 而不是 /var/lib/mysql,则使用数据容器存储 MySQL 数据无法正常工作
基础设施
我正在使用 3 个 Docker 容器来提供一个网站:
- nginx 容器运行网络服务器
- mariadb 数据库容器
- 创建的用户数据的数据容器
使用以下 docker 命令创建数据容器:
$ docker create \
-v /var/lib \
-v /var/www \
--name [appname]-data \
tianon/true /bin/true
使用以下命令检查 [appname]-data 的可用挂载点$ docker inspect [appname]-data
:
"Mounts": [
{
"Name": "361ed7b3e38371653f2df75652973e1c48db52d59c4c5371f634c1930291af0c",
"Source": "/var/lib/docker/volumes/361ed7b3e38371653f2df75652973e1c48db52d59c4c5371f634c1930291af0c/_data",
"Destination": "/var/lib",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
},
...
容器使用 docker-compose 启动。两个容器都应使用数据容器上可用的所有挂载。我的 docker-compose.yml:
[appname]-nginx:
container_name: [appname]-nginx
image: nginx:9-apache
links:
- [appname]-mariadb:mysql
volumes_from:
- [appname]-data
restart: always
expose:
- "80"
[appname]-mariadb:
image: mariadb:10.1
container_name: [appname]-mariadb
restart: always
volumes_from:
- [appname]-data
environment:
MYSQL_ROOT_PASSWORD: pas$w0rd
TERM: dumb
输出 $ docker exec -it [appname]-nginx ls -lha /var/lib/mysql
:
total 8.0K
drwxr-xr-x 2 root root 4.0K Jun 27 16:30 .
drwxr-xr-x 3 root root 4.0K Jul 21 10:19 ..
输出$ docker exec -it [appname]-mariadb ls -lha /var/lib/mysql
:
total 109M
drwxr-xr-x 4 mysql mysql 4.0K Jul 21 10:19 .
drwxr-xr-x 3 root root 4.0K Jul 21 10:19 ..
-rw-rw---- 1 mysql mysql 16K Jul 21 07:57 aria_log.00000001
-rw-rw---- 1 mysql mysql 52 Jul 21 07:57 aria_log_control
-rw-rw---- 1 mysql mysql 48M Jul 21 07:57 ib_logfile0
-rw-rw---- 1 mysql mysql 48M Jul 21 07:56 ib_logfile1
-rw-rw---- 1 mysql mysql 12M Jul 21 07:57 ibdata1
-rw-rw---- 1 mysql mysql 0 Jul 21 07:56 multi-master.info
drwx------ 2 mysql mysql 4.0K Jul 21 07:57 mysql
drwx------ 2 mysql mysql 4.0K Jul 21 07:56 performance_schema
-rw-rw---- 1 mysql mysql 24K Jul 21 07:57 tc.log
mount
在两个容器上执行显示相同的内容:
/dev/dm-0 on /var/lib type ext4 (rw,relatime,data=ordered)
/dev/dm-0 on /var/www type ext4 (rw,relatime,data=ordered)
但是对于 [appname]-mariadb,存在一个额外的 /var/lib/mysql 挂载:
/dev/dm-0 on /var/lib/mysql type ext4 (rw,relatime,data=ordered)
问题
为什么不能在 /var/lib 上创建卷挂载来将所有存储的数据保存在数据容器中?
我是否遗漏了什么?
这是 MySQL/MariaDB 的问题吗?
答案1
为什么你不docker-compose.yml
也创建你的docker卷?下面的方法应该有效:
version: '2'
services:
nginx:
image: nginx:9-apache
expose:
- '80'
volumes:
- app-data:/var/www
mariadb:
image: mariadb:10.1
volumes:
- app-data:/var/lib
environment:
MYSQL_ROOT_PASSWORD: pas$w0rd
TERM: dumb
volumes:
app-data:
不过,我很奇怪为什么你会希望两个容器都将其数据存储在同一个卷上。我认为最好将nginx
和mariadb
的数据分别存储在不同的卷上。