docker-compose问题:尝试创建/装入卷时权限被拒绝

时间:2019-01-11 01:27:46

标签: docker docker-compose ubuntu-16.04 docker-volume

我有以下docker-compose.yml文件:

version: "3"
services:
  dbs-poa-loc001d:
    image: percona
    volumes:
      - ./mysql_backup:/var/lib/mysql
      - ./create_databases:/docker-entrypoint-initdb.d
    hostname: "dbs-poa-loc001d"
    container_name: dbs-poa-loc001d
    environment:
      MYSQL_ALLOW_EMPTY_PASSWORD: "yes"
    ports:
      - "3306:3306"
    networks:
      - azion-network
...

当我尝试创建dbs-poa-loc001d服务(项目的数据库)时,出现以下错误:

Starting dbs-poa-loc001d ... done
Attaching to dbs-poa-loc001d
dbs-poa-loc001d    | Initializing database
dbs-poa-loc001d    | mysqld: Can't create/write to file '/var/lib/mysql/is_writable' (Errcode: 13 - Permission denied)
dbs-poa-loc001d    | 2019-01-11T01:17:52.060984Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
dbs-poa-loc001d    | 2019-01-11T01:17:52.062286Z 0 [ERROR] --initialize specified but the data directory exists and is not writable. Aborting.
dbs-poa-loc001d    | 2019-01-11T01:17:52.062299Z 0 [ERROR] Aborting
dbs-poa-loc001d    | 
dbs-poa-loc001d exited with code 1

在我的工作中,我的MacOS计算机上不会发生此错误,但在我的家用计算机(运行Ubuntu 16.04)中会发生此错误。我确实注意到创建的用于保存卷数据的主机上的mysql_backup文件夹设置为组AND用户root。谁能告诉我怎么回事,如何解决?已经尝试不成功:

  • 使用sudo运行docker-compose命令
  • 手动将文件夹的所有者和用户更改为我的实际(低特权)用户。

我当前的设置和安装版本是:

  • Ubuntu 16.04
  • Docker版本18.09.0,构建4d60db4
  • docker-compose版本1.23.2,内部版本1110ad0
  • docker-compose是使用sudo pip install docker-compose
  • 安装的

1 个答案:

答案 0 :(得分:1)

您可以尝试将mysql_backup的权限设置为1001:0吗?
类似sudo chown -R 1001:0 ./mysql_backup
或作为替代,但仅在文件夹为空 sudo chmod 777 ./mysql_backup

关于percona Dockerfile mysql用户ID为1001 https://github.com/percona/percona-docker/blob/master/percona-server.80/Dockerfile