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

ari*_*nmz 6 postgresql docker docker-compose

我是 docker 生态系统的新手,我正在尝试使用 yaml composer 文件启动一个简单的 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
Run Code Online (Sandbox Code Playgroud)

但是,在调用时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. 可能是什么问题呢?我也在没有 root 权限的情况下运行 docker,将我的用户添加到 docker 组,并且该用户还可以完全访问上述挂载点/mnt/storage

And*_*inn 7

我猜这将与 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上发现了另一个相关问题,该问题讨论了能够在挂载时设置权限. 但是无法通过chmod或进行更改chown(这可能是这种情况下失败的原因)。

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

  • 如果我使用命名卷,它工作正常,但如果我使用卷: - ./pgsql/data:/var/lib/pgsql/data/pgdata (5认同)
  • 现代 WSL 或 WSL 2 对此有何更新? (4认同)

CGu*_*ess 5

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

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

...

volumes:
  postgres:

Run Code Online (Sandbox Code Playgroud)


小智 5

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

就我而言,解决方案是使用红帽存储库中的官方 postgres 映像,红帽存储库中的映像已修复此问题,这可以作为替代方案。


小智 5

我在 WSL2 上使用 docker 时遇到了同样的问题。设置 :Z 标志进行挂载,而不是挂载到 Windows 文件系统目录 ( /mnt/*),而是挂载到 Linux 目录 ( /home/*)对我有用。

我的作文:

version: '3.3'
services:
    postgres:
        container_name: dbs2-postgres
        environment:
            - POSTGRES_PASSWORD=mysecretpassword
            - PGDATA=/var/lib/postgresql/data/pgdata
        volumes:
            - './data:/var/lib/postgresql/data:Z'
        image: postgres
Run Code Online (Sandbox Code Playgroud)