ファインチューニングエラー検出
SUSE® Rancher Prime Continuous Deliveryは、デプロイされたリソースの`status`フィールドを監視し、`Bundle`が正常かエラーかを判断します。特定のケースでは、SUSE® Rancher Prime Continuous Deliveryがステータスフィールドの条件をエラーとして解釈することがありますが、それが予期されるものであったり無害であったりする場合もあります。
この動作は2つの方法で調整できます:
-
`fleet.yaml`の条件を無視する
-
環境変数でエラーマッピングをカスタマイズする
| + 環境変数を使用してSUSE® Rancher Prime Continuous Deliveryでレディネス検出を設定する必要はほとんどありません。もし必要であれば、デフォルトのレディネス検出を改善するために、問題を開くかプルリクエストを提出してください。 |
`fleet.yaml`の条件を無視する
`fleet.yaml`ファイルの`ignore.conditions`設定を使用して、SUSE® Rancher Prime Continuous Deliveryに特定の条件を無視するよう指示します。
# from ref-fleet-yaml
# Ignore fields when monitoring a Bundle. This can be used when {product_name} thinks
# some conditions in Custom Resources makes the Bundle to be in an error state
# when it shouldn't.
ignore:
# Conditions to be ignored
conditions:
# In this example a condition will be ignored if it contains
# {"type": "Active", "status", "False"}
- type: Active
status: "False"
この方法は、カスタムリソースまたはコントローラーが条件を設定し、それによってSUSE® Rancher Prime Continuous Deliveryがバンドルを失敗としてマークする場合に役立ちますが、リソースは正常です。
環境変数でエラーマッピングを設定する
SUSE® Rancher Prime Continuous Delivery v0.13では、エラー検出が強化され、より多くの制御が可能になりました。環境変数`CATTLE_WRANGLER_CHECK_GVK_ERROR_MAPPING`を使用して、リソース条件の解釈方法をカスタマイズできます。
この変数を使用すると、Group、Version、Kind(GVK)によって、どの条件値をエラーとして扱うべきか、または明示的にエラーとして扱わないべきかを定義できます。
この変数を、extraEnv`を使用してFleet Helmチャートデプロイメント(`values.yaml)に設定します。値はJSONでなければなりません。
# Extra environment variables passed to the fleet pods.
# extraEnv:
# - name: OCI_STORAGE
# value: "false"
| + この設定はすべてのFleetコントローラーにグローバルであり、すべての`GitRepo`に適用されます。特定のバンドルのエラーハンドリングのみを調整する必要がある場合は、代わりに`fleet.yaml`の`ignoreConditions`オプションを使用してください。 |
マージ動作
マッピングを`CATTLE_WRANGLER_CHECK_GVK_ERROR_MAPPING`で上書きする場合:
-
新しい条件は、事前定義された条件とマージされます。
-
条件の値は、再定義した条件に対して置き換えられます。
例えば、デフォルトマッピングを考えてみてください:
HelmChart.Failed=["True"]
これは、`Failed=True`がエラーとして扱われることを意味します。
上書きする場合は:
-
HelmChart.Failed=["False"] -
HelmChart.Ready=["False"]
これにより、次のようになります:
-
Failed=["False"]`がデフォルトマッピングを置き換えます。これは、`Failed=Falseが現在エラーとして扱われることを意味します。 -
Ready=["False"]`が追加されるため、`Ready=Falseもエラーとして扱われます。 -
他の条件は変更されません。
エラー解釈無効化の例
`Failed`のすべての値が以前はエラーとして解釈されていたと仮定します。例えば:
{ "type": "Failed", "status": ["True", "False"] }
このマッピングを絞り込んで、`Failed=True`のみをエラーとして扱うには、次のように設定します:
[
{
"gvk": "sample.cattle.io/v1, Kind=Sample",
"conditionMappings": [
{ "type": "Failed", "status": ["True"] }
]
}
]
この設定は、Failed=Trueのみがエラーとして扱われることを意味します。`Failed=False`はもはやエラーとは見なされません。
`Failed`の任意の値に対してエラーを無効にすることもできます。
{ "type": "Failed", "status": [""] }
この設定は、no value of Failedがエラーとして扱われることを保証します。
| + 条件の上書きは、デフォルトのエラーマッピングにのみ影響します(デフォルトエラーマッピングを参照)。SUSE® Rancher Prime Continuous Deliveryは、`kstatus`ライブラリからの他のチェックがカスタマイズ後も実行され続けるため、リソースをエラーとしてマークする可能性があります。 |
デフォルトのエラーマッピング
SUSE® Rancher Prime Continuous Deliveryは、`status`フィールド内の特定のリソース条件をエラーとして解釈するためにデフォルトのエラーマッピングを追加します。これらのマッピングは、Kubernetes `kstatus`ライブラリによって実行されるような他のレディネスチェックの他に適用されます。
以下のデフォルトマッピングが適用されます:
-
HelmChart (
helm.cattle.io/v1) -
JobCreated:`True`も`False`もエラーとは見なされません。 -
Failed: `True`はエラーと見なされます。 -
Node (
v1) -
OutOfDisk: `True`はエラーと見なされます。 -
MemoryPressure: `True`はエラーと見なされます。 -
DiskPressure: `True`はエラーと見なされます。 -
NetworkUnavailable: `True`はエラーと見なされます。 -
デプロイメント (
apps/v1) -
ReplicaFailure: `True`はエラーと見なされます。 -
Progressing: `False`はエラーと見なされます。 -
ReplicaSet (
apps/v1) -
ReplicaFailure: `True`はエラーと見なされます。