postgresql - 初始化数据库 : could not change permissions of directory on Postgresql container

标签 postgresql docker docker-compose

我是 docker 生态系统的新手,我正在尝试启动一个简单的 postgres 容器以及一个卷,以便它通过使用 yaml Composer 文件来持久保存其数据。文件如下:

# 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 时,出现以下错误:

fixing permissions on existing directory /var/lib/postgresql/data/pgdata ... initdb: could not change permissions of directory "/var/lib/postgresql/data/pgdata": Operation not permitted

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

最佳答案

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

关于postgresql - 初始化数据库 : could not change permissions of directory on Postgresql container,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44878062/

相关文章:

docker - 运行多个网站-Docker Compose

postgresql - 仅对支持类型的列执行 LIKE 操作

scala - 已启动 Web 应用程序的 Docker 和 http url

java - 如何 Dockerize Jmeter(使用 Docker 和 Jmeter 进行分布式测试)

docker - 如何增加 docker 镜像内 activeMQ 的堆内存

Dockerfile CMD 不接受变量替换

python - 如何从 GCS 读取 json gzip 文件并写入表?

sql - 在sql中保留=左边的列有什么区别

postgresql - 从 PostgreSQL 中的 TRIGGER 返回错误消息

python - 有没有办法自动激活 virtualenv 作为 docker 入口点?