Kubernetesデプロイメントおよびサービスの作成
次の手順を使用して、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グループ | リソース | 動詞 | 
|---|---|---|
| configmaps、events、services | create、delete、deletecollection、get、list、patch、update、watch | |
| persistentvolumeclaims | create、delete、deletecollection、get、list、patch、update | |
| apps | deployments、controllerrevisions | create、delete、deletecollection、get、list、patch、update、watch | 
| core.oam.dev | * | create、delete、deletecollection、get、list、patch、update、watch | 
| oam.verrazzano.io | * | create、delete、deletecollection、get、list、patch、update、watch | 
一部の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デプロイメントおよびサービスを作成します
メトリックとログの収集の詳細
アプリケーションに対するセキュアなパブリック・アクセス
認可ポリシーの詳細
Istioゲートウェイおよび仮想サービスの詳細