initdb:无法更改Postgresql容器上的目录权限

时间:2017-07-03 04:59:22

标签: postgresql docker docker-compose

我是docker生态系统的新手,我正在尝试使用一个yuml编写器文件来创建一个简单的postgres容器和一个卷,以便它保持其数据。该文件如下:

# Use postgres/example user/password credentials
version: '3.3'
services:
    db:
        image: postgres
        environment:
            POSTGRES_DB: recrow
            POSTGRES_USER: recrow
            POSTGRES_PASSWORD: recrow_db_1000
            PGDATA: /var/lib/pgsql/data/pgdata
        volumes:
          - ./pgsql/data:/var/lib/pgsql/data/pgdata

但是,在调用docker-compose -f stack.yml up时,我收到以下错误:

  

修复现有目录的权限   / var / lib / postgresql / data / pgdata ... initdb:无法更改   目录的权限" / var / lib / postgresql / data / pgdata":操作   不允许

/var/lib/pgsql/data/pgdata应该是相对于容器根目录的目录,而./pgsql/data是主机上的路径。我正在/mnt/storage上安装的ntfs-3g分区运行容器。可能是什么问题呢?通过将我的用户添加到docker组,我也运行没有root权限的docker,并且该用户也可以完全访问前面提到的挂载点/mnt/storage

3 个答案:

答案 0 :(得分:0)

我猜这将与ntfs-3g不兼容。 PostgreSQL映像包含一个入口点脚本,它对容器启动进行了一些权限更改:https://github.com/docker-library/postgres/blob/972294a377463156c8d61297320c872fc7d370a9/9.6/docker-entrypoint.sh#L32-L38。我在https://askubuntu.com/questions/11840/how-do-i-use-chmod-on-an-ntfs-or-fat32-partition找到了另一个相关问题,该问题涉及能够在挂载时设置权限。但无法通过chmodchown进行更改(这可能是本案失败的原因)。

不幸的是,我认为这里的答案是您不能安全地使用ntfs-3g来支持Docker主机卷安装。

答案 1 :(得分:0)

下面是@ liam-mitchell的注释,这就是答案。使用如下所示的命名卷:

services:
  db:
    image: postgres:12-alpine
    volumes:
      - "postgres:/data/postgres"
    environment:
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=postgres
      - PGDATA=/data/postgres

...

volumes:
  postgres:

答案 2 :(得分:0)

我使用 OpenShift 并且在从 Docker Hub 运行这个官方镜像时遇到了同样的问题。

就我而言,解决方案是使用来自 red hat 存储库的官方 postgres 图像,来自 red hat 存储库的图像已解决此问题,这是一个替代方案。