5.4. Policy as Code の管理
ポリシーを Kubernetes カスタムリソース (CR) として保存し、Argo CD などの Kubernetes ネイティブの継続的デリバリー (CD) ツールを使用してクラスターに適用することで、Policy as Code を作成および管理できます。
5.4.1. polices as code の管理 リンクのコピーリンクがクリップボードにコピーされました!
ポリシーを Kubernetes カスタムリソース (CR) として保存し、Argo CD などの Kubernetes ネイティブの継続的デリバリー (CD) ツールを使用してクラスターに適用することで、Policy as Code を作成および管理できます。
Policy as Code は、RHACS ポータルを使用する代わりに、YAML または JSON でポリシーを作成する Kubernetes セキュリティーアーキテクトにとって便利です。GitOps ワークフローを使用して Kubernetes 設定をすでに管理している GitOps 管理者にとっても、これは便利です。
RHACS では、デフォルトのポリシーの使用やシステム用のカスタムポリシーの作成が可能です。Policy as Code 機能を使用すると、カスタムポリシーをダウンロードして変更するか、空のファイルから作成して、ローカルでカスタムポリシーを作成できます。ローカルでポリシーを作成するには、ポリシーの望ましい状態を表す CR を作成します。次に、Argo CD などの継続的デリバリーツールを使用して、RHACS を実行しているクラスターを追跡、管理し、ポリシーを適用します。CR を作成または更新し、CI/CD ツールを使用して適用すると、RHACS データベースに保存されているポリシーが作成または更新されます。
この機能を使用すると、RHACS は Central がインストールされている namespace (通常は stackrox namespace) に新しい Kubernetes コントローラーをインストールします。Argo CD ワークフローでは、RHACS がインストールされているのと同じ namespace に Policy as Code を適用するように Argo CD を設定します。この接続を設定すると、RHACS のコントローラーは、個別の Kubernetes CR ファイルとして管理される新規、更新、または削除されたポリシーに関する情報を Kubernetes API から受信します。RHACS は、ポリシー CR を RHACS データベースに保存されているポリシーと調整します。
Argo CD を使用しない GitOps ワークフローでは、RHACS API を介して RHACS の Central に接続するように GitOps リポジトリーを設定します。CR は使用されません。
5.4.1.1. ポリシードリフトについて リンクのコピーリンクがクリップボードにコピーされました!
ポリシーは RHACS ポータルで編集、削除、および作成でき、外部からも作成できるため、ポリシーのドリフト が発生する可能性があります。ドリフトは、RHACS の Central のポリシーのバージョンが Kubernetes のポリシーのバージョンと一致しない場合に発生します。
ドリフトは、Kubernetes カスタムリソースを変更する代わりに、RHACS ポータルまたは API を使用して外部で管理されているポリシーに変更を適用したときに発生する可能性があります。RHACS はドリフトを防ぐことができず、(手動での変更は可能であるが) RHACS を使用した変更は推奨されません。ドリフトは、導入後 10 時間以内に自動的に解決されます。
5.4.1.2. RHACS ポータルを使用したコードでのポリシーの作成 リンクのコピーリンクがクリップボードにコピーされました!
RHACS ポータルを使用して既存のポリシーを YAML ファイルとして保存することで、コード内に新しいポリシーを作成できます。
前提条件
- RHACS リリース 4.6 以降がインストールされている。
マニフェストインストールメソッド (
roxctlメソッドとも呼ばれます) を使用して RHACS をインストールした場合は、次のコマンドを使用して、helm/chart/crds/config.stackrox.io_securitypolicies.yamlの .zip ファイルにあるconfig.stackrox.ioCRD を手動で適用する必要があります。kubectl create -f helm/chart/crds/config.stackrox.io_securitypolicies.yaml
$ kubectl create -f helm/chart/crds/config.stackrox.io_securitypolicies.yamlCopy to Clipboard Copied! Toggle word wrap Toggle overflow
手順
RHACS ポータルを使用して CR を作成し、コードで新しいポリシーを作成するには以下を実行します。
Policy Management ページで、新しいポリシーを作成するか、デフォルトポリシーを複製します。
注記デフォルトポリシーを CR として保存する前に、そのポリシーを複製する必要があります。
-
ポリシーが表示されている行のオーバーフローメニュー (
) をクリックしてから、Save as Custom Resource を選択します。複数のポリシーを一度に保存するには、それらを選択して、Bulk actions Save as Custom Resources をクリックします。 ポリシーを編集した後、次のいずれかの方法で保存した CR を適用できます。
-
oc applyまたはkubectl applyコマンドを使用して、Central がインストールされている Kubernetes namespace に CR を直接適用します。 - Argo CD または GitOps ツールを使用して、Central がインストールされている Kubernetes namespace に CR をプッシュします。
-
5.4.1.3. CR を構築することによるコードでのポリシーの作成 リンクのコピーリンクがクリップボードにコピーされました!
ポリシーの CR を構築することで、コード内に新しいポリシーを作成できます。
エディターを使用して、次の属性のポリシーの CR を作成します。
Copy to Clipboard Copied! Toggle word wrap Toggle overflow ヒントポリシー仕様を定義するために使用できるフィールドを理解するには、
kubectl explain securitypolicy.specなどのコマンドを入力してオンラインドキュメントを使用します。次のいずれかを実行して、保存された CR を適用します。
-
oc applyまたはkubectl applyコマンドを使用して、Central がインストールされている Kubernetes namespace に CR を直接適用します。 - Argo CD または GitOps ツールを使用して、Central がインストールされている Kubernetes namespace に CR をプッシュします。
-
5.4.1.4. policy as code 機能の無効化 リンクのコピーリンクがクリップボードにコピーされました!
policy as code 機能は、RHACS をインストールすると自動的に有効になりますが、無効にすることもできます。
手順
policy as code 機能を無効にするには、RHACS のインストールに使用した方法に応じて、次のいずれかのタスクを実行します。
-
Operator を使用して RHACS をインストールした場合は、
spec.configAsCode.configAsCodeComponentフィールドをDisabledに設定します。 -
Helm チャートを使用して RHACS をインストールした場合は、
values.yamlファイルのconfigAsCode.enabledフィールドをfalseに設定します。 マニフェストインストールメソッド (
roxctlメソッドとも呼ばれます) を使用して RHACS をインストールした場合は、次のコマンドを実行してconfig-controllerデプロイメントを削除します。kubectl -n stackrox delete deployment config-controller
$ kubectl -n stackrox delete deployment config-controller1 Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- OpenShift Container Platform の場合は、
kubectlの代わりにocを使用します。