第17章 Stratis で階層化ローカルストレージの管理

Stratis の高レベルシステムに統合されている複雑なストレージ設定を簡単に設定および管理できます。

重要

Straits がテクノロジープレビューとして利用可能にテクノロジープレビュー機能に対する Red Hat のサポート範囲の詳細は、「テクノロジプレビュー機能のサポート範囲」を参照してください。

Stratis をデプロイしているお客様は、Red Hat にフィードバックをお寄せください。

17.1. Stratis ファイルシステムの設定

システム管理者は、Stratis ボリューム管理ファイルシステムをシステム上で有効にしてセットアップし、階層化ストレージを簡単に管理できます。

17.1.1. Stratis の目的と機能

Stratis は、Linux 用のローカルストレージ管理ソリューションです。これは、シンプルさと使いやすさに力を入れており、高度なストレージ機能にアクセスできます。

Stratis を使用すると、以下の活動をより簡単に行うことができます。

  • ストレージの初期設定
  • その後の変更
  • 高度なストレージ機能の使用

Stratis は、高度なストレージ機能に対応する、ユーザーとカーネルのハイブリッドローカルストレージ管理システムです。Stratis は、ストレージ プール の概念を中心としています。このプールは 1 つ以上のローカルディスクまたはパーティションから作成され、ボリュームはプールから作成されます。

プールにより、次のような多くの便利な機能を使用できます。

  • ファイルシステムのスナップショット
  • シンプロビジョニング
  • 階層化

17.1.2. Stratis ボリュームの構成要素

外部的には、Stratis は、コマンドラインインターフェースおよび API に次のボリュームコンポーネントを表示します。

blockdev
ディスクやディスクパーティションなどのブロックデバイス。
pool

1 つ以上のブロックデバイスで構成されています。

プールの合計サイズは固定で、ブロックデバイスのサイズと同じです。

プールには、dm-cache ターゲットを使用した不揮発性データキャッシュなど、ほとんどの Stratis レイヤーが含まれています。

Stratis は、各プールの /stratis/my-pool/ ディレクトリーを作成します。このディレクトリーには、プール内の Stratis ファイルシステムを表すデバイスへのリンクが含まれています。

filesystem

各プールには、ファイルを格納する 1 つ以上のファイルシステムを含めることができます。

ファイルシステムはシンプロビジョニングされており、合計サイズは固定されていません。ファイルシステムの実際のサイズは、そこに格納されているデータとともに大きくなります。データのサイズがファイルシステムの仮想サイズに近づくと、Stratis はシンボリュームとファイルシステムを自動的に拡張します。

ファイルシステムは XFS でフォーマットされています。

重要

Stratis は、Stratis を使用して作成したファイルシステムに関する情報を追跡し、XFS はそれを認識しません。また、XFS を使用して変更を行っても、自動的に Stratisに更新を作成しません。ユーザーは、Stratis が管理する XFS ファイルシステムを再フォーマットまたは再構成しないでください。

Stratis は、パスが /stratis/my-pool/my-fs のファイルシステムへのリンクを作成します。

注記

Stratis は、dmsetup リストと /proc/partitions ファイルに表示される多くの Device Mapper デバイスを使用します。同様に、lsblk コマンドの出力は、Stratis の内部の仕組みとレイヤーを反映します。

17.1.3. Stratis で使用可能なブロックデバイス

本セクションでは、Stratis に使用できるストレージデバイスを一覧で紹介します。

対応デバイス

Stratis プールは、次の種類のブロックデバイスで動作するかどうかをテスト済みです。

  • LUKS
  • LVM 論理ボリューム
  • MD RAID
  • DM Multipath
  • iSCSI
  • HDD および SSD
  • NVMe デバイス
警告

Stratis は、現行バージョンでは、ハードドライブまたはその他のハードウェアの不具合に対応しません。複数のハードウェアデバイスに Stratis プールを作成すると、データにアクセスするために複数のデバイスが動作状態になっているため、データを損失するリスクが高まります。

対応していないデバイス

Stratis にはシンプロビジョニングレイヤーが含まれているため、Red Hat はすでにシンプロビジョニングされているブロックデバイスに Stratis プールを配置することを推奨しません。

関連情報

  • iSCSI や、ネットワークを必要とするその他のブロックデバイスの _netdev マウントオプションに関する情報は、man ページの systemd.mount(5) を参照してください。

17.1.4. Stratis のインストール

この手順では、Stratis の使用に必要なパッケージをすべてインストールします。

手順

  1. Stratis サービスとコマンドラインユーティリティーを提供するパッケージをインストールします。

    # yum install stratisd stratis-cli
  2. stratisd サービスが有効になっていることを確認してください。

    # systemctl enable --now stratisd

17.1.5. Stratis プールの作成

この手順では、1 つ以上のブロックデバイスから Stratis プールを作成します。

前提条件

  • Stratis がインストールされている。「Stratis のインストール」を参照してください。
  • stratisd サービスが実行している。
  • Stratis プールを作成するブロックデバイスは使用されておらず、マウントされていない。
  • Stratis プールを作成するブロックデバイスが、それぞれ 1 GiB 以上である。
  • IBM Z アーキテクチャーでは、/dev/dasd* ブロックデバイスをパーティションに分割している。Stratis プールでパーティションを使用します。

    DASD デバイスのパーティション設定には、「IBM Z への Linux インスタンスの設定」を参照してください。

手順

  1. 選択したブロックデバイスにファイルシステム、パーティションテーブル、または RAID 署名が含まれている場合は消去します。

    # wipefs --all block-device

    block-device を、ブロックデバイスへのパス (例: /dev/sdb) に置き換えます。

  2. ブロックデバイスに Stratis プールを作成するには、次のコマンドを実行します。

    # stratis pool create my-pool block-device
    • my-pool を、プールの任意の名前に置き換えます。
    • block-device を、空または消去したブロックデバイスへのパス (例: /dev/sdb) に置き換えます。

    複数のブロックデバイスからプールを作成するには、すべてのブロックデバイスをコマンドラインに追加します。

    # stratis pool create my-pool device-1 device-2 device-n
  3. 確認のために、システムにあるプールを一覧表示します。

    # stratis pool list

関連情報

  • man ページの stratis(8)

次のステップ

17.1.6. Stratis ファイルシステムの作成

この手順では、既存の Stratis プールに Stratis ファイルシステムを作成します。

前提条件

手順

  1. Stratis ファイルシステムをプールに作成するには、次のコマンドを実行します。

    # stratis fs create my-pool my-fs
    • my-pool を、既存の Stratis プールの名前に置き換えます。
    • my-fs を、ファイルシステムの任意の名前に置き換えます。
  2. 確認のために、プールにあるファイルシステムの一覧を表示します。

    # stratis fs list my-pool

関連情報

  • man ページの stratis(8)

次のステップ

17.1.7. Stratis ファイルシステムのマウント

この手順では、コンテンツにアクセスするために既存の Stratis ファイルシステムをマウントします。

前提条件

手順

  • ファイルシステムをマウントするには、/stratis/ ディレクトリーで Stratis が維持するエントリーを使用します。

    # mount /stratis/my-pool/my-fs mount-point

これでファイルシステムは mount-point ディレクトリーにマウントされ、使用できるようになりました。

関連情報

  • man ページの mount(8)

17.1.8. Stratis ファイルシステムを永続的に維持

この手順では、Stratis ファイルシステムを永続的にマウントして、システムが起動した後に自動的に利用できるようにします。

前提条件

手順

  1. ファイルシステムの UUID 属性を調べます。

    $ lsblk --output=UUID /stratis/my-pool/my-fs

    以下に例を示します。

    例17.1 Stratis ファイルシステムの UUID の表示

    $ lsblk --output=UUID /stratis/my-pool/fs1
    
    UUID
    a1f0b64a-4ebb-4d4e-9543-b1d79f600283
  2. このマウントポイントのディレクトリーがない場合は、作成します。

    # mkdir --parents mount-point
  3. root で /etc/fstab ファイルを編集し、ファイルシステムに行を追加します (UUID で識別されます)。xfs をファイルシステムのタイプとして使用し、x-systemd.requires=stratisd.service オプションを追加します。

    以下に例を示します。

    例17.2 /etc/fstab の /fs1 マウントポイント

    UUID=a1f0b64a-4ebb-4d4e-9543-b1d79f600283 /fs1 xfs defaults,x-systemd.requires=stratisd.service 0 0
  4. システムが新しい設定を登録するように、マウントユニットを再生成します。

    # systemctl daemon-reload
  5. ファイルシステムをマウントして、設定が機能することを確認します。

    # mount mount-point

このページには機械翻訳が使用されている場合があります (詳細はこちら)。