【问题标题】:initdb: could not change permissions of directory on Postgresql containerinitdb:无法更改 Postgresql 容器上目录的权限
【发布时间】:2017-07-03 04:59:21
【问题描述】:

我是 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

但是,在调用 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 的完全访问权限。

【问题讨论】:

    标签: postgresql docker docker-compose


    【解决方案1】:

    我猜这将与 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 主机卷挂载。

    【讨论】:

    • 现代 WSL 或 WSL 2 对此有何更新?
    • 我个人没试过。但是 WSL/WSL2 应该原生支持 Linux 权限。如果它不起作用并且存在可能是单独的问题并且需要单独的问题。
    • 如果我使用命名卷,它工作正常,但如果我使用卷: - ./pgsql/data:/var/lib/pgsql/data/pgdata
    【解决方案2】:

    根据上面@liam-mitchell 的说明,这就是答案。使用命名卷,如下所示:

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

    【讨论】:

      【解决方案3】:

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

      在我的情况下,解决方案是使用 red hat 存储库中的官方 postgres 图像,red hat 存储库中的图像已解决此问题,这可以作为替代方案。

      【讨论】:

      • 这条评论应该是一个宝石。就我而言,我使用 Jhipster 部署到 Openshift。在将 Postgres 映像从 Redhat 存储库更改为一个后,我还必须更改部署配置中的以下环境变量名称(由 JHipster 生成)。 POSTGRES_USER 到 POSTGRESQL_USER POSTGRES_PASSWORD 到 POSTGRESQL_PASSWOD POSTGRES_DATABASE 到 POSTGRESQL_DATABASE 基本上,我将 QL 附加到 POSTGRES 上。
      猜你喜欢
      • 1970-01-01
      • 2019-04-10
      • 2022-07-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-11-01
      • 2018-10-03
      • 2012-04-23
      相关资源
      最近更新 更多