Azure DiskとAzure Filesの利用
演習の概要
このモジュールでは、Azure DiskとAzure Filesを利用した、 コンテナアプリのデータ保存を実行します。
Azure Disk用の永続ボリューム要求(Persistent Volume Claim, PVC)の作成
AROには、Azure Diskを使用するストレージクラス(managed-csi)が、予めデフォルトとして設定されています。 これにより、 Azure DiskのPremium SSD LRS (Locally Redundant Storage. ローカル冗長ストレージ)オプションがすぐに使えるように設定されています。
data:image/s3,"s3://crabby-images/c0e47/c0e47554bb27ecf6733a82f9d1f5132d6f57f98f" alt="storage class"
data:image/s3,"s3://crabby-images/bd965/bd965a1b23c2b43212c0a998458d924eb83eef2f" alt="managed csi"
ここでmanaged-csiストレージクラスを利用するために、新しく永続ボリューム要求(PVC)を作成します。 PVCの名前は任意の名前(下記画像の例では、test-pvc-20)を入力し、サイズは1GiBと指定します。
data:image/s3,"s3://crabby-images/95c1c/95c1c3a85fd1831dab673cc81aadba42c6c1d113" alt="pvc create1"
PVCはプロジェクトという名前空間の中にあるリソースです。 そのため、プロジェクトごとに同じ名前のPVCが存在できます。 例えば、プロジェクト1の中にPVC1、プロジェクト2の中にPVC1を作ることができます。 ただし、1つのプロジェクトの中のリソース名の重複は許可されていないため、 この例の場合だと、プロジェクト1の中にPVC1を2つ作ることはできません。 |
このmanaged-csiストレージクラスは、ボリュームバインディングモードが 「WaitForFirstConsumer」と指定されており、 最初にPodから永続ボリューム要求が利用されるまで、 永続ボリュームの割り当てが行われない(ステータスがPendingのまま)ようになっています。 なお、ボリュームバインディングモードが「Immediate」となっている場合、 PVC作成後すぐに永続ボリュームの割り当てが行われます。
data:image/s3,"s3://crabby-images/906eb/906eb4f654d9ef122d9acacb0b87422aa4f28bca" alt="pvc info1"
PVCによって作成されたAzure Diskは、Azure Portalからも確認できます。
Azureの aro-infra-XXXXX-<AROクラスター名>
リソースグループに、
pvc-
という接頭辞が付いたAzure Diskが作成されていることを確認できます。
data:image/s3,"s3://crabby-images/27287/27287a1cdb161e763d10d8deac97385bab43b588" alt="azure portal disk"
Azure Disk用のPVCを利用するPodの作成
Podを作成します。「Podの作成」から、次のYAMLファイルを入力してPodを作成します。 下記の「claimName: test-pvc-20」となっているところは、作成したPVCの名前に応じて、適宜変更してください。
PodはKubernetes/OpenShift上でのコンテナアプリの実行単位です。 下記のYAMLファイルにあるとおり、コンテナ(この例ではCentOSコンテナの最新版を利用)や コンテナが利用する永続ボリュームの設定などをまとめたものになります。 Podにはコンテナを複数まとめることもできますが、基本的には1つのPodには1つのコンテナを含むことを推奨しています。 |
apiVersion: v1
kind: Pod
metadata:
name: test-disk
spec:
volumes:
- name: disk-storage-vol
persistentVolumeClaim:
claimName: test-pvc-20
containers:
- name: test-disk
image: centos:latest
command: [ "/bin/bash", "-c", "--" ]
args: [ "while true; do touch /mnt/disk-data/verify-disk && echo 'hello disk' && sleep 30; done;" ]
volumeMounts:
- mountPath: "/mnt/disk-data"
name: disk-storage-vol
data:image/s3,"s3://crabby-images/9e0ff/9e0ff5107494309044d44a93b1fca336efbeb061" alt="pod create1"
data:image/s3,"s3://crabby-images/eb0be/eb0be09fc9792b3287bfd91aab6f89e204392527" alt="pod create2"
data:image/s3,"s3://crabby-images/43381/43381e1489e2bac4b2df23ce708923656a8a74b5" alt="pod create3"
test-diskという名前でPodが作成されて、Podにより「test-pvc-20」PVCが利用されて、 永続ボリュームとして外部ストレージの利用が開始されます。
data:image/s3,"s3://crabby-images/315d2/315d2c124d79fc907812a721f6df8de856aa2e90" alt="pod pvc"
このPodのログやターミナルから、永続ボリュームのマウント状況や動作状況を確認できます。
data:image/s3,"s3://crabby-images/a1482/a148271cd3ad72b7a6b872395b9455eeabad69cd" alt="pod log1"
data:image/s3,"s3://crabby-images/3179a/3179a3c684d2964f1f810c5a5c2dff0e650a5e1e" alt="pod terminal1"
ここで上記画像にあるように、Podのターミナルから、echoコマンドなどで永続ボリュームのマウントポイントである
/mnt/disk-data
ディレクトリに、適当なファイルを作成します。
Podを削除(該当Podを選択して、「アクション」→「Podの削除」を選択)した後に、
再度「test-pvc-20」PVCを指定してPodを作成すると、作成したテストファイルが残っていることを確認できます。
Azure Files用のPVCの作成
Azure Diskと同様に、Azure Filesを利用するためのストレージクラス(azurefile-csi)が、 デフォルトで作成されています。これはデフォルトのストレージクラスではありませんが、 明示的に指定することで利用できるようになっています。
data:image/s3,"s3://crabby-images/ab161/ab161623e5ea899b9f7f83a3216ffd3c6d786acf" alt="azurefile csi"
Azure Diskの時と同様に、azurefile-csiストレージクラスを利用した、 PVCを作成します。このとき、アクセスモードに「共有アクセス(RWX)」を選択します。
data:image/s3,"s3://crabby-images/c2235/c2235067cfc0f482817254272ebf051eebfcd7cb" alt="pvc create2"
data:image/s3,"s3://crabby-images/264ec/264ecde462ba497272e9366a27b19dc39d10d34f" alt="pvc info2"
RWXは複数台のワーカーノードから利用可能なアクセスモードです。 RWXに対応したPVCを利用することで、 複数ノード上でレプリケーション構成を取るアプリケーション(Azure Filesに保存したデータを共有)を ARO上で実行できるようになります。
PVCによって作成されたAzure Filesは、Azure Portalからも確認できます。
Azureの aro-infra-XXXXX-<AROクラスター名>
リソースグループに、
Azure Filesを利用するためのAzureストレージアカウントが自動作成され、
その中の「ファイル共有」から pvc-
という接頭辞が付いたAzure Filesが作成されていることを確認できます。
data:image/s3,"s3://crabby-images/9d2d1/9d2d1f5f99adba60c062ede8a553647f4ede644e" alt="azure portal files"
Azure Files用のPVCを利用するPodの作成
Azure Diskの時と同様に、次のYAMLファイルを入力して、 作成した「test-pvc-21」PVCを利用したPodを実行します。
apiVersion: v1
kind: Pod
metadata:
name: test-files
spec:
volumes:
- name: files-storage-vol
persistentVolumeClaim:
claimName: test-pvc-21
containers:
- name: test-files
image: centos:latest
command: [ "/bin/bash", "-c", "--" ]
args: [ "while true; do touch /mnt/files-data/verify-files && echo 'hello files' && sleep 30; done;" ]
volumeMounts:
- mountPath: "/mnt/files-data"
name: files-storage-vol
作成したPodのターミナルからAzure Filesのマウント状況を確認すると、 CIFSプロトコルでマウントされていることを確認できます。
data:image/s3,"s3://crabby-images/f3b7f/f3b7fbee9a2cec55da04fd052fdfbe8642e52eb2" alt="pod terminal2"
ここで作成したPodとは別のPodを新しく作成して、複数のPodから同じPVCを利用することで、 1つのファイルシステムを共有できることを確認します。 前述のPod作成に利用したYAMLファイルで、「name: test-files」を「name: test-files-new」などに 変更することで、変更したPod名で新規Podを実行してみます。
「test-files-new」Podでもマウント先のディレクトリへのファイル作成/削除や、 「test-files」Podで作成したファイルの修正ができることを、 当該Podの「ターミナル」タブから確認してみてください。