启动 postgres 容器时出错 - mkdir:权限被拒绝

pun*_*r12 6 postgresql nfs docker docker-compose

我正在使用以下 docker-compose.yml 启动 postgres 容器

version: '3'
services:
  db:
    image: postgres:latest
    container_name: postgres
    environment:
      POSTGRES_USER: usr
      POSTGRES_PASSWORD: pswd
      POSTGRES_DB: db
      PGDATA: /var/lib/postgresql/data/pgdata
    ports:
        - 5432:5432
    volumes:
        - nfs_cur_dir:/var/lib/postgresql/data

volumes:
  nfs_cur_dir:
    driver: local
    driver_opts:
      type: nfs
      o: "addr=10.15.187.88,rw"
      device: ":/u/uname/home/database"
Run Code Online (Sandbox Code Playgroud)

启动容器时出现以下错误

$sudo ./docker-compose  up db
Starting postgres ... done
Attaching to postgres
postgres    | mkdir: cannot create directory ‘/var/lib/postgresql/data’: Permission denied
postgres exited with code 1
Run Code Online (Sandbox Code Playgroud)

database目录权限为 777

drwxrwxrwx 3 uname grpname 4096 May 5 22:57 database

失败后,我还看到pgdata创建的目录是这样的 -

drwx------ 2 polkitd root 4096 May 5 22:57 pgdata

笔记:

  • postgres 的数据目录映射到 NFS 位置。因此,我在 docker-compose 中定义了一个新的 NFS 卷并将其映射到 postgres 容器。
  • 我正在使用 PGDATA env 变量为数据目录定义不同的位置。
  • 除了以上两点,没有什么特别的。如果我为数据目录使用本地驱动器位置,这工作正常!

小智 0

您应该检查 NFS 共享公开的权限。根据你的说法,如果你使用本地驱动器,则可以正常工作。这就是为什么我认为 NFS 共享的权限没有按您的预期工作。也许您应该在尝试运行应用程序之前创建该目录。