Skip to main content
NetApp virtualization solutions
日本語は機械翻訳による参考訳です。内容に矛盾や不一致があった場合には、英語の内容が優先されます。

OpenNebula用のONTAP NVMe/FCでLVM Thinを設定

共同作成者 sureshthoppay

NVMe over Fibre Channelプロトコルを使用して、NetApp ONTAPとともに、OpenNebulaホスト間で共有データストア用のLogical Volume Manager(LVM)を構成します。この構成により、最新のNVMeプロトコルを使用して、低レイテンシでハイパフォーマンスなブロックレベルのストレージ アクセスが提供されます。

仮想化管理者の初期タスク

NVMe/FC 接続用に OpenNebula ホストを準備し、ストレージ管理者に必要な情報を収集するために、これらの初期タスクを完了してください。

  1. 2 つの HBA インターフェイスが使用可能であることを確認します。

  2. クラスター内のすべてのOpenNebulaホストで、次のコマンドを実行して WWPN 情報を収集し、nvme-cli パッケージがインストールされていることを確認します。

    Debian/Ubuntu
    apt update
    apt install nvme-cli
    cat /sys/class/fc_host/host*/port_name
    nvme show-hostnqn
    RHEL/AlmaLinux
    dnf update
    dnf install nvme-cli
    cat /sys/class/fc_host/host*/port_name
    nvme show-hostnqn
  3. 収集したホストNQNおよびWWPN情報をストレージ管理者に提供し、必要なサイズのNVMe名前空間を要求します。ファブリック ゾーニングにはWWPNが必要です。これらの情報を、ファブリック ゾーニングを担当する管理者に提供します。

ストレージ管理者のタスク

ONTAPを初めて使用する場合は、System Manager を使用すると使いやすくなります。

  1. NVMe プロトコルが有効になっている SVM が使用可能であることを確認します。参照 "ONTAP 9のNVMeタスクに関するドキュメント"

  2. コントローラごとに 2 つの LIF が作成され、NVMe/FC 専用になっていることを確認します。作成された NVMe/FC LIF の WWPN アドレスを収集し、ファブリック ゾーニングを担当する管理者に提供します。

  3. NVMe 名前空間を作成します。

  4. サブシステムを作成し、ホストNQNを割り当てます。

  5. セキュリティ タブでランサムウェア対策が有効になっていることを確認します。

  6. NVMe 名前空間が作成されたことを仮想化管理者に通知します。

最終的な仮想化管理者のタスク

これらのタスクを完了して、NVMe名前空間をOpenNebulaで共有LVMストレージとして構成します。

  1. クラスタ内の各OpenNebulaホストのシェルに移動し、新しいネームスペースが表示されていることを確認します。

  2. 名前空間の詳細を確認します。

    nvme list
  3. デバイスの詳細を検査して収集します。

    nvme list
    nvme netapp ontapdevices
    nvme list-subsys
    lsblk -N
  4. フロントエンド サーバーの 1 つに SSH で接続し、必要なデータストア タイプに基づいて構成ファイルを作成します。完全な属性リストについては、 "OpenNebula LVMドキュメント"を参照してください。サンプルファイルを以下に示します:

    バックアップ
    1. Resticの場合、

    $cat nvmefc-restic.conf
    NAME = "Backup-Restic-NVMEFC"
    TYPE = "BACKUP_DS"
    
    DS_MAD = "restic"
    TM_MAD = "-"
    
    RESTIC_PASSWORD = "<restic_password>"
    RESTIC_SFTP_SERVER = "<backup server>"
    1. Rsyncの場合、

    $cat nvmefc-rsync.conf
    NAME = "Backup-Rsync-NVMEFC"
    TYPE = "BACKUP_DS"
    
    DS_MAD = "rsync"
    TM_MAD = "-"
    
    RSYNC_USER = "<rsync_user>"
    RSYNC_HOST = "<backup server>"
    ファイル
    $cat nvmefc-kernel.conf
    NAME = "File-Kernel-NVMEFC"
    TYPE = "FILE_DS"
    DS_MAD = "fs"
    TM_MAD = "local"
    SAFE_DIRS = "/var/tmp/files"
    イメージ
    $cat nvmefc-image.conf
    NAME = "Image-NVMEFC01"
    TYPE = "IMAGE_DS"
    DS_MAD = "fs"
    TM_MAD = "fs_lvm_ssh"
    DISK_TYPE = "block"
    LVM_THIN_ENABLE = "yes"
    システム
    $cat nvmefc-system.conf
    NAME = "System-NVMEFC02"
    TYPE = "SYSTEM_DS"
    TM_MAD = "fs_lvm_ssh"
    DISK_TYPE = "block"
    BRIDGE_LIST = "<space-separated list of OpenNebula hosts>" # If NVMe namespace not presented to frontend hosts
    LVM_THIN_ENABLE = "yes"
  5. 実行 onedatastore create <configuration file>。作成後に返されるデータストア ID をメモします。

    onedatastore create nvmefc-system.conf ID:108

  6. `vgcreate <vg_name> <nvme_device>`コマンドを使用して、NVMe名前空間にボリュームグループを作成します。イメージデータストアの場合、ボリュームグループ名には任意の名前を付けることができます。システムデータストアの場合、ボリュームグループ名は `vg-one-<datastore id>`の形式にする必要があります。これは、OpenNebulaがシステムデータストアの正しいボリュームグループを識別するために必要です。バックアップ/ファイル/イメージデータストアを作成する場合は、次の手順に進みます。システムデータストアの場合は、ここで停止します。

  7. `lvcreate -l 100%FREE -n <logical volume name> <volume group name>`コマンドを使用して論理ボリュームシンプールを作成します。システムデータストアの場合、OpenNebulaは必要に応じてLVMシンプールを自動的に作成します。

  8. `mkfs.ext4 /dev/<volume group>/<logical volume>`コマンドを使用して、論理ボリューム上にファイルシステムを作成します。システムデータストアでは、ファイルシステムの作成は必要ありません。

  9. /etc/fstab または automount 設定を更新して、必要なマウント オプションでデータストアをマウントします。デフォルトのデータストアの場所は /var/lib/one/datastores とします。 `onedatastore show <datastore_id>`で検証できます。そうでない場合は、/etc/one/oned.conf の DATASTORE_LOCATION パラメータを確認してください。データストアの場所の下に<datastore_id>フォルダが存在することを確認してください。サンプル エントリを以下に示します:

    /etc/fstab の使用
    /dev/<vg name>/<logical volume> /var/lib/one/datastores/<datastore_id> ext4 _netdev,noauto,x-systemd.automount,nofail 0 2
    自動マウントの使用
    /var/lib/one/datastores/<datastore_id> -fstype=ext4,_netdev,noauto,x-systemd.automount,nofail,rw :/dev/<vg name>/<logical volume>
  10. `mount -a`または `systemctl reload autofs`コマンドを使用してデータストアをマウントします。

  11. マウントコマンドでデータストアがマウントされていることを確認し、 `onedatastore show <datastore_id>`コマンドでデータストアの容量を確認します。

  12. oneadmin ユーザーとグループがデータストア フォルダーを所有していることを確認します。 `chown -R oneadmin:oneadmin /var/lib/one/datastores/<datastore_id>`コマンドを使用して権限を調整します。