@@ -6,7 +6,7 @@ weight: 45
6
6
7
7
<!-- overview -->
8
8
9
- ストレージ容量は、Podが実行されるノードごとに制限があったり、大きさが異なる可能性があります。たとえば、NASがすべてのノードからはアクセスできなかったり、初めはストレージがノードローカルでしか利用できない可能性があります 。
9
+ ストレージ容量は、Podが実行されるノードごとに制限があったり、大きさが異なる可能性があります。たとえば、NASがすべてのノードからはアクセスできなかったり、初めからストレージがノードローカルでしか利用できない可能性があります 。
10
10
11
11
{{< feature-state for_k8s_version="v1.19" state="alpha" >}}
12
12
@@ -29,26 +29,26 @@ weight: 45
29
29
ストレージ容量の情報がKubernetesのスケジューラーで利用されるのは、以下のすべての条件を満たす場合です。
30
30
31
31
- ` CSIStorageCapacity ` フィーチャーゲートがtrueである
32
- - Podがまだ作成されていないボリュームを使用している
32
+ - Podがまだ作成されていないボリュームを使用する時
33
33
- そのボリュームが、CSIドライバーを参照し、[ volume binding mode] ( /docs/concepts/storage/storage-classes/#volume-binding-mode ) に` WaitForFirstConsumer ` を使う{{< glossary_tooltip text="StorageClass" term_id="storage-class" >}}を使用している
34
34
35
- その場合、スケジューラーはPodに対して、十分なストレージが利用できるノードだけを考慮するようになります 。このチェックは非常に単純で、ボリュームのサイズと、` CSIStorageCapacity ` オブジェクトに一覧された容量を、ノードを含むトポロジで比較するだけです 。
35
+ その場合、スケジューラーはPodに対して、十分なストレージ容量が利用できるノードだけを考慮するようになります 。このチェックは非常に単純で、ボリュームのサイズと、` CSIStorageCapacity ` オブジェクトに一覧された容量を、ノードを含むトポロジーで比較するだけです 。
36
36
37
- volume binding modeが` Immediate ` のボリュームの場合、ボリュームを使用するPodとは独立に、ストレージドライバーがボリュームの作成場所を決定します 。次に、スケジューラーはボリュームが作成された後、Podをボリュームが利用できるノードにスケジューリングします。
37
+ volume binding modeが` Immediate ` のボリュームの場合、ストレージドライバーはボリュームを使用するPodとは関係なく、ボリュームを作成する場所を決定します 。次に、スケジューラーはボリュームが作成された後、Podをボリュームが利用できるノードにスケジューリングします。
38
38
39
39
[ CSI ephemeral volumes] ( /docs/concepts/storage/volumes/#csi ) の場合、スケジューリングは常にストレージ容量を考慮せずに行われます。このような動作になっているのは、このボリュームタイプはノードローカルな特別なCSIドライバーでのみ使用され、そこでは特に大きなリソースが必要になることはない、という想定に基づいています。
40
40
41
41
## 再スケジューリング
42
42
43
- ` WaitForFirstConsumer ` ボリュームがあるPodに対してノードが選択された場合は、その決定はまだ一時的なものです。次のステップで、CSIストレージドライバーに対して、選択されたノード上でボリュームが利用可能になることが予定されているというヒントを付きでボリュームの作成を要求します 。
43
+ ` WaitForFirstConsumer ` ボリュームがあるPodに対してノードが選択された場合は、その決定はまだ一時的なものです。次のステップで、CSIストレージドライバーに対して、選択されたノード上でボリュームが利用可能になることが予定されているというヒントを使用してボリュームの作成を要求します 。
44
44
45
45
Kubernetesは古い容量の情報をもとにノードを選択する場合があるため、実際にはボリュームが作成できないという可能性が存在します。その場合、ノードの選択がリセットされ、KubernetesスケジューラーはPodに割り当てるノードを再び探します。
46
46
47
47
## 制限
48
48
49
49
ストレージ容量を追跡することで、1回目の試行でスケジューリングが成功する可能性が高くなります。しかし、スケジューラーは潜在的に古い情報に基づいて決定を行う可能性があるため、成功を保証することはできません。通常、ストレージ容量の情報が存在しないスケジューリングと同様のリトライの仕組みによって、スケジューリングの失敗に対処します。
50
50
51
- スケジューリングが永続的に失敗する状況の1つは、Podが複数のボリュームを使用する場合で、あるトポロジーのセグメントで1つのボリュームがすでに作成された後、もう1つのボリュームのために十分な容量が残っていないような場合です。この状況から回復するには、たとえば、容量を増加させたり、すでに作成されたボリュームを削除するなどの手動の仲介が必要です 。この問題に自動的に対処するためには、まだ[ 追加の作業] ( https://github.com/kubernetes/enhancements/pull/1703 ) が必要となっています。
51
+ スケジューリングが永続的に失敗する状況の1つは、Podが複数のボリュームを使用する場合で、あるトポロジーのセグメントで1つのボリュームがすでに作成された後、もう1つのボリュームのために十分な容量が残っていないような場合です。この状況から回復するには、たとえば、容量を増加させたり、すでに作成されたボリュームを削除するなどの手動での対応が必要です 。この問題に自動的に対処するためには、まだ[ 追加の作業] ( https://github.com/kubernetes/enhancements/pull/1703 ) が必要となっています。
52
52
53
53
## ストレージ容量の追跡を有効にする {#enabling-storage-capacity-tracking}
54
54
0 commit comments