Kubernetesオブジェクトを使用したアプリケーションのデプロイ

VerrazzanoおよびOAMは、アプリケーションを定義およびカスタマイズするためのワークロードとTraitを提供します。ただし、状況によっては、提供されるリソース以外のリソースが必要な場合があります。その場合、他の既存のKubernetesリソースを使用できます。todo-listの例では、複数のComponentでこの機能を利用して、一意のServiceおよびConfigMap要件をサポートします。

ほとんどのKubernetesリソースは、Component内にワークロードとして埋め込むことができます。次のサンプルは、DeploymentをComponent内にワークロードとして埋め込む方法を示しています。oam-kubernetes-runtimeオペレータは、Componentを処理し、デプロイメント中に別のリソースにDeploymentを抽出します。

apiVersion: core.oam.dev/v1alpha2
kind: Component
...
spec:
  workload:
    kind: Deployment
    apiVersion: apps/v1
    name: ...
    spec:
      selector:
        ...
      template:
        ...

ほとんどのKubernetesリソースは、ApplicationConfiguration内にTraitとして埋め込むこともできます。次の例は、ApplicationConfiguration内にTraitとしてIngressを埋め込む方法を示しています。oam-kubernetes-runtimeオペレータは、ApplicationConfigurationを処理し、デプロイメント中に別のリソースにIngressを抽出します。次のサンプルでは、IngressがKubernetes Ingressで、Verrazzanoが提供するIngressTraitではないことに注意してください。

apiVersion: core.oam.dev/v1alpha2
kind: ApplicationConfiguration
...
spec:
  components:
    - componentName: ...
      traits:
        - trait:
            apiVersion: networking.k8s.io/v1beta1
            kind: Ingress
            ...
            spec:
              rules:
                ...
oam-kubernetes-runtimeオペレータのクラスタ・ロール権限は、デフォルトでは次のセットに限定されています。

APIグループ リソース 動詞
configmapseventsservices createdeletedeletecollectiongetlistpatchupdatewatch
persistentvolumeclaims createdeletedeletecollectiongetlistpatchupdate
apps deploymentscontrollerrevisions createdeletedeletecollectiongetlistpatchupdatewatch
core.oam.dev * createdeletedeletecollectiongetlistpatchupdatewatch
oam.verrazzano.io * createdeletedeletecollectiongetlistpatchupdatewatch

一部のKubernetesリソースをワークロードまたはトレイトとして使用できるようにするには、クラスタ管理者がoam-kubernetes-runtimeオペレータに追加権限を付与する必要がある場合があります。ワークロードまたはトレイトとして埋め込まれる特定のリソースに追加のロールとロール・バインディングを作成します。次のClusterRoleおよびClusterRoleBindingの例は、oam-kubernetes-runtimeにIngressリソースを管理するための権限を付与する方法を示しています。

apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: oam-kubernetes-runtime-ingresses
rules:
  - apiGroups:
    - networking.k8s.io
    - extensions
    resources:
    - ingresses
    verbs:
    - create
    - delete
    - get
    - list
    - patch
    - update

apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: oam-kubernetes-runtime-ingresses
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: oam-kubernetes-runtime-ingresses
subjects:
  - kind: ServiceAccount
    name: oam-kubernetes-runtime
    namespace: verrazzano-system

Kubernetesデプロイメントおよびサービスの作成

次の手順を使用して、Kubernetesデプロイメントおよびサービスを作成します

メトリックとログの収集

メトリックとログの収集の詳細

証明書管理

アプリケーションに対するセキュアなパブリック・アクセス

認可ポリシー

認可ポリシーの詳細

Istioゲートウェイおよび仮想サービス

Istioゲートウェイおよび仮想サービスの詳細