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ゲートウェイおよび仮想サービスの詳細