0

我正在尝试将我的应用程序中的运行时数据外部化,以保存在 OpenMediaVault 共享文件夹中。我能够创建共享文件夹并配置 NFS,或者至少我是这么认为的。我看到的配置OMV/Services/NFS/Shares是:

Shared folder: NasFolder[on /dev/sda1, nas/]
Client: 192.168.50.0/24
Privelage: Read/Write
Extra options: subtree_check,insecure

现在在那个共享文件夹中我有这个结构(我使用 Windows SMB/CIFS 配置检查了它)

\\nfs-ip\NasFolder
          |- mysql
          |   \- some my sql folders...
          |- TEST.txt

我想使用这个mysql文件夹来存储 MariaDB 运行时数据(我知道名字搞砸了,我正在迁移到 Maria...)。并为其他服务创建一些其他文件夹。这是我的配置docker-compose.yml

version: '3.2'
services:
  mysqldb:
    image: arm64v8/mariadb:latest
    ports:
      - 3306:3306
    restart: on-failure:3
    volumes:
      - type: volume
        source: nfs-volume
        target: /mysql
        volume:
          nocopy: true
    environment:
      - MYSQL_ROOT_PASSWORD=my-secret-pw
    command: --character-set-server=utf8 --collation-server=utf8_general_ci

volumes:
  nfs-volume:
    driver: local
    driver_opts:
      type: "nfs"
      o: addr=192.168.50.70,nolock,soft,rw
      device: ":/NasFolder"

现在,当我docker stack deploy -c docker-compose.yml --with-registry-auth maprealm在管理器节点上运行时,出现maprealm_mysqldb.1如下错误:

"Err": "starting container failed: error while mounting volume '/var/lib/docker/volumes/maprealm_nfs-volume/_data': failed to mount local volume: mount :/NasFolder:/var/lib/docker/volumes/maprealm_nfs-volume/_data, data: addr=192.168.50.70,nolock,soft: permission denied",

我对集成的东西很陌生。这是我的家庭服务器,我只是找不到很好的教程来“通过我的厚脑袋”如何配置那些 NFS 路径和​​权限,或者至少除了遇到这个错误之外我该如何调试它。我知道这volumes.nfs-volume.driver_opts.device应该是一条路径,但我不确定那应该是什么路径。我试图从这里调整配置:https ://gist.github.com/ruanbekker/4a9c0d250bce9f84482f2a788ce92131

编辑1)一些额外的细节:

  • Docker swarm 有 3 个节点,只有一个节点是具有可用性暂停的管理器。
  • OMV 在不属于集群的独立机器上运行
4

1 回答 1

0

好的,如果有人正在寻找解决方案:

  1. OMV 默认/export/用于 NFS,因此需要更新卷。我需要更新 mysql 的卷并更新volumes.mysql-volume.driver_opts.device以包含该前缀,并且我还添加了文件夹的/export/路径以具有仅供服务使用的卷:mysqlmysqldb
volumes:
  mysql-volume:
    driver: local
    driver_opts:
      type: "nfs"
      o: addr=192.168.50.70,nolock,soft,rw
      device: ":/export/NasFolder/mysql"
  1. 在这些更改之后,需要更新 mysql/mariadb 上的卷配置:
  mysqldb:
    image: arm64v8/mariadb:latest
    ports:
      - 3306:3306
    restart: on-failure:3
    volumes:
      - type: volume
        source: mysql-volume
        target: /var/lib/mysql
        volume:
          nocopy: true
    environment:
      - MYSQL_ROOT_PASSWORD=my-secret-pw
    command: --character-set-server=utf8 --collation-server=utf8_general_ci

mysqldb.volumes.source指向在步骤 1 中定义的卷的名称 -mysql-volume mysqldb.volumes.target是存储容器运行时数据内部的位置。在 mysql/mariadb 数据库中存储运行时数据,/var/lib/mysql因此您想要指向它并且只能使用完整路径。

  1. 由于我使用了默认的 OMV 配置,因此存在权限问题。所以我更新OMV/Services/NFS/Shares到这个:
Shared folder: NasFolder[on /dev/sda1, nas/]
#here you can see note 'The location of the files to share. The share will be accessible at /export/.'
Client: 192.168.50.0/24
Privelage: Read/Write
Extra options: rw,sync,no_root_squash,anonuid=1000,anongid=1000,no_acl
于 2022-02-16T14:02:12.910 回答