Skip to content

Integrate Capsuleβš“οΈŽ

This article outlines how the EPAM Delivery Platform (EDP) leverages Capsule capabilities to enable isolation for both the core platform components and the business applications workload.

EPAM Delivery Platform uses Capsule to ensure resource isolation. It is crucial to define constraints through the Capsule tenant approach. This approach serves two primary objectives: limiting the resources allocated to the EDP components and regulating the resources utilized by each deployed environment.

To ensure isolation for the core platform components, create the edp namespace under the Capsule tenant. Use the template provided in this instruction to create the Capsule tenant specifically for the core components.

Integrationβš“οΈŽ

The following scheme outlines the general steps involved in configuring Capsule for seamless integration with EDP. This process ensures efficient resource isolation, allowing for the deployment and management of both EDP core platform components and business application workloads. Follow the sequential flow of the scheme to successfully integrate Capsule with the EPAM Delivery Platform:

graph LR;
    A(Capsule Installation) --> B(Tenant Configuration) --> C(Impersonation) --> D(Create EDP Namespace)--> E(Deploy EDP)
  1. Capsule Installation - This initial step involves setting up Capsule on your environment.

  2. Tenant Configuration - Once Capsule is installed, the next critical step is configuring the Capsule tenant. This involves defining specific parameters and constraints to regulate the allocation of resources to EDP components.

  3. Impersonation - Impersonation plays a role in managing user identities and permissions within the Capsule environment. This step ensures secure and controlled access to resources.

  4. Create EDP Namespace - The creation of a dedicated namespace under Capsule is crucial for isolating and managing the core components of EDP. This step establishes the environment where EDP will be deployed.

  5. Deploy EDP - The final step involves deploying the EPAM Delivery Platform within the configured Capsule environment.

Installationβš“οΈŽ

The installation procedure consists of two steps:

  1. Define the namespace where EDP will be installed in Capsule values:

    values.yaml
    manager:
      options:
        # -- Boolean, enforces the Tenant owner, during Namespace creation, to name it using the selected Tenant name as prefix, separated by a dash
        forceTenantPrefix: true
        # enable capsule for EDP tenant and cd-pipeline-operator
        # NOTE: Capsule cannot manage cluster system namespaces
        capsuleUserGroups:
          - capsule.clastix.io
          # enable for cd-pipeline-operator https://github.com/epam/edp-cd-pipeline-operator/blob/release/2.17/deploy-templates/values.yaml#L10
          - system:serviceaccounts:edp # (1)!
          - masters # (2)!
          # uncomment if Argo CD manage main EDP tenant
          #- system:serviceaccounts:argocd
          # uncomment if edp-oidc-admins group manage main EDP tenant https://epam.github.io/edp-install/operator-guide/edp-access-model
          #- edp-oidc-admins
    
    1. Namespace where EDP will be installed.
    2. Group that manages the main EDP tenant.
  2. To install the Capsule tool, use the Cluster Add-Ons approach. For more details, please refer to the Capsule official page.

Configurationβš“οΈŽ

After installing Capsule, the next crucial step is configuration. Follow the guidelines provided below to configure Capsule and ensure seamless integration with your system:

  1. Specify the Capsule tenant configuration:

    edp-tenant-example.yaml
    apiVersion: capsule.clastix.io/v1beta2
    kind: Tenant
    metadata:
      name: edp-tenant
    spec:
      ...
      owners:
        - clusterRoles:
            - admin
            - capsule-namespace-deleter
          kind: Group
          name: system:masters # (1)!
        #
        # Uncomment if Argo CD manage main EDP tenant
        #- clusterRoles:
        #    - admin
        #    - capsule-namespace-deleter
        #  kind: ServiceAccount
        #  name: system:serviceaccount:argocd:argocd-application-controller
        #
        # Uncomment if edp-oidc-admins group manage main EDP tenant
        #- clusterRoles:
        #    - admin
        #    - capsule-namespace-deleter
        #  kind: Group
        #  name: edp-oidc-admins
      ...
    
    1. Group that manages the main EDP tenant. Must be declared in Capsule configuration.

    The following example includes additional specifications that can be used to manage the EDP tenant:

    Tenant configuration example
    apiVersion: capsule.clastix.io/v1beta2
    kind: Tenant
    metadata:
      name: edp-tenant
    spec:
      ingressOptions:
        allowWildcardHostnames: false
        allowedHostnames:
          allowedRegex: ^.*example.com$ # DNSwildcard for EDP usage
        hostnameCollisionScope: Tenant
      limitRanges:
        items:
          - limits:
                # The default limits apply to each container unless otherwise specified by default
              - default:
                  cpu: 768m
                  memory: 768Mi
                # The default requests apply to each container unless otherwise specified by default
                defaultRequest:
                  cpu: 256m
                  memory: 512Mi
                type: Container
          - limits:
              # In case Tekton pipelines need to use volume workspaces. If use emptydir please set it to 0.
              - max:
                  storage: 3Gi
                min:
                  storage: 3Gi
                type: PersistentVolumeClaim
      # Since EDP uses one namespace, the namespace quota is set to 1
      namespaceOptions:
        quota: 1
      networkPolicies:
        items:
          - ingress:
              - from:
                  - namespaceSelector:
                      matchLabels:
                        capsule.clastix.io/tenant: edp-tenant
                  - podSelector: {}
                  - ipBlock:
                      cidr: 172.32.0.0/16
            podSelector: {}
            policyTypes:
              - Ingress
      # Default EDP admins group to make admin users tenant owners
      owners:
        - clusterRoles:
            - admin
            - capsule-namespace-deleter
          kind: Group
          name: system:masters
        #
        # Uncomment if Argo CD manage main EDP tenant
        #- clusterRoles:
        #    - admin
        #    - capsule-namespace-deleter
        #  kind: ServiceAccount
        #  name: system:serviceaccount:argocd:argocd-application-controller
        #
        # Uncomment if edp-oidc-admins group manage main EDP tenant
        #- clusterRoles:
        #    - admin
        #    - capsule-namespace-deleter
        #  kind: Group
        #  name: sandbox-oidc-cluster-admins
      resourceQuotas:
        items:
            # The maximum CPU and Memory capacity for the EDP tenant
          - hard:
              limits.cpu: '2'
              limits.memory: 2Gi
            # The maximum number of pods that can be deployed within a namespace
          - hard:
              pods: '15'
        scope: Tenant
      serviceOptions:
        # Enable the capabilities to create ClusterIP service types only
        allowedServices:
          externalName: false
          loadBalancer: false
          nodePort: false
    
  2. To install the Capsule tenant, use the Cluster Add-Ons approach.

  3. Create namespace for the EDP tenant:

    1. Log in as a system:masters member and create a namespace for platform deployment under the Capsule tenant using the following command:

      kubectl create namespace edp
      
    2. To ensure that the edp namespace is successfully created under the Capsule tenant, you can verify the status of the Capsule tenant using the following command:

      kubectl get tenant edp-tenant -o yaml
      

      Expected output:

      ...
      status:
        namespaces:
        - edp
        size: 1
        state: Active
      
  4. Enable Capsule in the values.yaml file to make it possible to manage deployable environments:

    values.yaml
    cd-pipeline-operator:
       tenancyEngine: "capsule"
    

As a result of following these instructions, Capsule policies are used to manage the EDP core components and deployable environments. By adhering to these guidelines, you should successfully install EDP with Capsule enabled as the tenancyEngine.