OpenShift-セキュリティ

OpenShiftセキュリティは、主にセキュリティ制約を処理する2つのコンポーネントの組み合わせです。

  • セキュリティコンテキスト制約(SCC)
  • サービスアカウント

セキュリティコンテキスト制約(SCC)

これは基本的にポッド制限に使用されます。つまり、ポッドが実行できるアクションやクラスター内でアクセスできるすべてのものなど、ポッドの制限を定義します。

OpenShiftは、管理者が使用、変更、および拡張できる事前定義されたSCCのセットを提供します。

$ oc get scc
NAME              PRIV   CAPS  HOSTDIR  SELINUX    RUNASUSER         FSGROUP   SUPGROUP  PRIORITY
anyuid            false   []   false    MustRunAs  RunAsAny          RunAsAny  RunAsAny  10
hostaccess        false   []   true     MustRunAs  MustRunAsRange    RunAsAny  RunAsAny  <none>
hostmount-anyuid  false   []   true     MustRunAs  RunAsAny          RunAsAny  RunAsAny  <none>
nonroot           false   []   false    MustRunAs  MustRunAsNonRoot  RunAsAny  RunAsAny  <none>
privileged        true    []   true     RunAsAny   RunAsAny          RunAsAny  RunAsAny  <none>
restricted        false   []   false    MustRunAs  MustRunAsRange    RunAsAny  RunAsAny  <none>

事前定義されたsccを使用したい場合は、ユーザーまたはグループをsccグループに追加するだけで実行できます。

$ oadm policy add-user-to-scc <scc_name> <user_name>
$ oadm policy add-group-to-scc <scc_name> <group_name>

サービスアカウント

サービスアカウントは基本的に、OpenShiftマスターAPIへのアクセスを制御するために使用されます。これは、マスターマシンまたはノードマシンのいずれかからコマンドまたはリクエストが実行されたときに呼び出されます。

アプリケーションまたはプロセスが制限付きSCCによって付与されていない機能を必要とする場合は常に、特定のサービスアカウントを作成し、そのアカウントをそれぞれのSCCに追加する必要があります。ただし、SCCが要件に合わない場合は、最適なSCCを使用するよりも、要件に固有の新しいSCCを作成することをお勧めします。最後に、デプロイメント構成用に設定します。

$ oc create serviceaccount Cadmin
$ oc adm policy add-scc-to-user vipin -z Cadmin

コンテナセキュリティ

OpenShiftでは、コンテナーのセキュリティは、コンテナープラットフォームの安全性と、コンテナーが実行されている場所の概念に基づいています。コンテナのセキュリティと何に注意を払う必要があるかについて話すときに浮かび上がることが複数あります。

Image Provenance −本番環境で稼働しているコンテナがどこから来たのかを正確かつ議論の余地なく特定する安全なラベリングシステムが導入されています。

Security Scanning −イメージスキャナーは、既知の脆弱性についてすべてのイメージを自動的にチェックします。

Auditing −実稼働環境は定期的に監査され、すべてのコンテナーが最新のコンテナーに基づいており、ホストとコンテナーの両方が安全に構成されていることを確認します。

Isolation and Least Privilege−コンテナは、効果的に機能するために必要な最小限のリソースと特権で実行されます。ホストや他のコンテナに過度に干渉することはできません。

Runtime Threat Detection −実行時にコンテナ化されたアプリケーションに対するアクティブな脅威を検出し、それに自動的に応答する機能。

Access Controls − AppArmorやSELinuxなどのLinuxセキュリティモジュールは、アクセス制御を実施するために使用されます。

コンテナのセキュリティをアーカイブするための重要な方法はいくつかあります。

  • oAuthを介したアクセスの制御
  • セルフサービスのWebコンソール経由
  • プラットフォームの証明書による

OAuthによるアクセスの制御

この方法では、API制御アクセスへの認証がアーカイブされ、OpenShiftマスターマシンに組み込まれているOAuthサーバーを介した認証用の保護されたトークンを取得します。管理者は、OAuthサーバー構成の構成を変更することができます。

OAuthサーバー構成の詳細については、このチュートリアルの第5章を参照してください。

セルフサービスWebコンソール経由

このWebコンソールのセキュリティ機能は、OpenShiftWebコンソールに組み込まれています。このコンソールは、一緒に作業しているすべてのチームが認証なしで他の環境にアクセスできないようにします。OpenShiftのマルチテルネットマスターには、以下のセキュリティ機能があります-

  • TCLレイヤーが有効になっている
  • 認証にx.509証明書を使用
  • マスターマシンのetcd構成を保護します

プラットフォームの証明書による

この方法では、Ansibleを介したインストール中に、各ホストの証明書が構成されます。Rest APIを介したHTTPS通信プロトコルを使用するため、さまざまなコンポーネントやオブジェクトへのTCLで保護された接続が必要です。これらは事前定義された証明書ですが、マスターのクラスターにアクセス用にカスタム証明書をインストールすることもできます。マスターの初期セットアップ中に、を使用して既存の証明書をオーバーライドすることにより、カスタム証明書を構成できます。openshift_master_overwrite_named_certificates パラメータ。

Example

openshift_master_named_certificates = [{"certfile": "/path/on/host/to/master.crt", 
"keyfile": "/path/on/host/to/master.key", 
"cafile": "/path/on/host/to/mastercert.crt"}]

カスタム証明書を生成する方法の詳細については、次のリンクにアクセスしてください-

https://www.linux.com/learn/creating-self-signed-ssl-certificates-apache-linux

ネットワークセキュリティー

OpenShiftでは、Software Defined Networking(SDN)が通信に使用されます。ネットワーク名前空間は、クラスター内の各ポッドに使用されます。各ポッドは、独自のIPと、ネットワークトラフィックを取得するためのポートの範囲を取得します。この方法では、他のプロジェクトのポッドと通信できないため、ポッドを分離できます。

プロジェクトの分離

これは、クラスター管理者が以下を使用して実行できます。 oadm command CLIから。

$ oadm pod-network isolate-projects <project name 1> <project name 2>

これは、上記で定義されたプロジェクトがクラスター内の他のプロジェクトと通信できないことを意味します。

ボリュームセキュリティ

ボリュームセキュリティとは、OpenShiftクラスター内のプロジェクトのPVとPVCを保護することを意味します。OpenShiftのボリュームへのアクセスを制御するための主に4つのセクションがあります。

  • 補足グループ
  • fsGroup
  • runAsUser
  • seLinuxOptions

補足グループ-補足グループは通常のLinuxグループです。プロセスがシステムで実行されると、ユーザーIDとグループIDで実行されます。これらのグループは、共有ストレージへのアクセスを制御するために使用されます。

次のコマンドを使用して、NFSマウントを確認します。

# showmount -e <nfs-server-ip-or-hostname>
Export list for f21-nfs.vm:
/opt/nfs *

次のコマンドを使用して、マウントサーバーのNFSの詳細を確認します。

# cat /etc/exports
/opt/nfs *(rw,sync,no_root_squash)
...
# ls -lZ /opt/nfs -d
drwxrws---. nfsnobody 2325 unconfined_u:object_r:usr_t:s0 /opt/nfs
# id nfsnobody
uid = 65534(nfsnobody) gid = 454265(nfsnobody) groups = 454265(nfsnobody)

/ opt / NFS /エクスポートのUIDでアクセス可能です454265 とグループ 2325

apiVersion: v1
kind: Pod
...
spec:
   containers:
   - name: ...
      volumeMounts:
      - name: nfs
         mountPath: /usr/share/...
   securityContext:
      supplementalGroups: [2325]
   volumes:
   - name: nfs
      nfs:
      server: <nfs_server_ip_or_host>
      path: /opt/nfs

fsGroup

fsGroupは、コンテナー補足グループを追加するために使用されるファイルシステムグループを表します。サプリメントグループIDは共有ストレージに使用され、fsGroupはブロックストレージに使用されます。

kind: Pod
spec:
   containers:
   - name: ...
   securityContext:
      fsGroup: 2325

runAsUser

runAsUserは、通信にユーザーIDを使用します。これは、ポッド定義でコンテナイメージを定義する際に使用されます。必要に応じて、単一のIDユーザーをすべてのコンテナーで使用できます。

コンテナの実行中、定義されたIDはエクスポートの所有者IDと照合されます。指定されたIDが外部で定義されている場合、そのIDはポッド内のすべてのコンテナーに対してグローバルになります。特定のポッドで定義されている場合は、単一のコンテナーに固有になります。

spec:
   containers:
   - name: ...
      securityContext:
         runAsUser: 454265