From f342e406a7cd8685f31b157297c87793162bb37b Mon Sep 17 00:00:00 2001 From: Csaky Date: Wed, 23 Oct 2024 14:53:27 -0700 Subject: [PATCH] Minimize crunchydb resource requirements --- .github/environments/values.dev.yaml | 48 +++++++++++++++---------- .github/environments/values.pr.yaml | 14 ++++++-- .github/environments/values.prod.yaml | 51 ++++++++++++++++++++++----- .github/environments/values.test.yaml | 44 ++++++++++++++++++++--- charts/coms/Chart.yaml | 4 +-- charts/coms/values.yaml | 2 +- charts/postgres/Chart.yaml | 2 +- 7 files changed, 125 insertions(+), 40 deletions(-) diff --git a/.github/environments/values.dev.yaml b/.github/environments/values.dev.yaml index e1d63d35..b2585436 100644 --- a/.github/environments/values.dev.yaml +++ b/.github/environments/values.dev.yaml @@ -32,25 +32,6 @@ postgres: # --------crunchydb config: ------ # -------------------------------- - # # --- resource allocation ---- - # instances: - # - name: db # do not change this name after initial install, pvc (data) and stateful sets will be deleted - # replicas: 2 - # dataVolumeClaimSpec: - # accessModes: - # - "ReadWriteOnce" - # resources: - # requests: - # storage: 0.5Gi - # storageClassName: "netapp-block-standard" - # resources: - # requests: - # cpu: 50m - # memory: 128Mi - # limits: - # cpu: 100m - # memory: 256Mi - # -------- backups --------- pgBackRestConfig: global: @@ -71,3 +52,32 @@ postgres: requests: storage: 2Gi storageClassName: "netapp-file-backup" + manual: + repoName: repo1 + options: + - --type=full + repoHost: + resources: + requests: + cpu: 20m + memory: 128Mi + limits: + cpu: 50m + memory: 256Mi + sidecars: + pgbackrest: + resources: + requests: + cpu: 5m + memory: 16Mi + limits: + cpu: 20m + memory: 64Mi + jobs: + resources: + requests: + cpu: 10m + memory: 64Mi + limits: + cpu: 50m + memory: 128Mi diff --git a/.github/environments/values.pr.yaml b/.github/environments/values.pr.yaml index 6f4820a2..55dd5b49 100644 --- a/.github/environments/values.pr.yaml +++ b/.github/environments/values.pr.yaml @@ -11,16 +11,15 @@ postgres: # --------crunchydb config: ------ # -------------------------------- - # --- resource allocation ---- instances: - name: db # do not change this name after initial install, pvc (data) and stateful sets will be deleted - replicas: 1 + replicas: 3 dataVolumeClaimSpec: accessModes: - "ReadWriteOnce" resources: requests: - storage: 0.5Gi + storage: .5Gi storageClassName: "netapp-block-standard" resources: requests: @@ -29,6 +28,15 @@ postgres: limits: cpu: 100m memory: 256Mi + sidecars: + replicaCertCopy: + resources: + requests: + cpu: 1m + memory: 32Mi + limits: + cpu: 50m + memory: 64Mi # -------- backups --------- pgBackRestConfig: {} diff --git a/.github/environments/values.prod.yaml b/.github/environments/values.prod.yaml index e1cc0650..b36460c7 100644 --- a/.github/environments/values.prod.yaml +++ b/.github/environments/values.prod.yaml @@ -32,7 +32,6 @@ postgres: # --------crunchydb config: ------ # -------------------------------- - # --- cluster resource allocation ---- instances: - name: db # do not change this name after initial install, pvc (data) and stateful sets will be deleted replicas: 3 @@ -41,18 +40,56 @@ postgres: - "ReadWriteOnce" resources: requests: - storage: 5Gi + storage: 2Gi storageClassName: "netapp-block-standard" resources: requests: - cpu: 1m - memory: 256Mi + cpu: 50m + memory: 128Mi limits: cpu: 100m - memory: 512Mi + memory: 256Mi + sidecars: + replicaCertCopy: + resources: + requests: + cpu: 1m + memory: 32Mi + limits: + cpu: 50m + memory: 64Mi # -------- backups --------- pgBackRestConfig: + manual: + repoName: repo1 + options: + - --type=full + repoHost: + resources: + requests: + cpu: 20m + memory: 128Mi + limits: + cpu: 50m + memory: 256Mi + sidecars: + pgbackrest: + resources: + requests: + cpu: 5m + memory: 16Mi + limits: + cpu: 20m + memory: 64Mi + jobs: + resources: + requests: + cpu: 10m + memory: 64Mi + limits: + cpu: 50m + memory: 128Mi configuration: # secret for saving backups to S3 - secret: @@ -87,10 +124,6 @@ postgres: endpoint: https://nrs.objectstore.gov.bc.ca region: us-east-1 - # # ----- pgBouncer (network pooling) ------ - # pgBouncerConfig: - # replicas: 2 - # -------- monitoring --------- monitoring: true monitoringConfig: diff --git a/.github/environments/values.test.yaml b/.github/environments/values.test.yaml index 933f01f4..743c4c26 100644 --- a/.github/environments/values.test.yaml +++ b/.github/environments/values.test.yaml @@ -41,7 +41,7 @@ postgres: - "ReadWriteOnce" resources: requests: - storage: 0.5Gi + storage: 1Gi storageClassName: "netapp-block-standard" resources: requests: @@ -50,9 +50,47 @@ postgres: limits: cpu: 100m memory: 256Mi + sidecars: + replicaCertCopy: + resources: + requests: + cpu: 1m + memory: 32Mi + limits: + cpu: 50m + memory: 64Mi # -------- backups --------- pgBackRestConfig: + manual: + repoName: repo1 + options: + - --type=full + repoHost: + resources: + requests: + cpu: 20m + memory: 128Mi + limits: + cpu: 50m + memory: 256Mi + sidecars: + pgbackrest: + resources: + requests: + cpu: 5m + memory: 16Mi + limits: + cpu: 20m + memory: 64Mi + jobs: + resources: + requests: + cpu: 10m + memory: 64Mi + limits: + cpu: 50m + memory: 128Mi global: # log-level-console: debug # --- pvc @@ -71,7 +109,3 @@ postgres: requests: storage: 2Gi storageClassName: "netapp-file-backup" - - # # ----- pgBouncer (network pooling) ------ - # pgBouncerConfig: - # replicas: 2 diff --git a/charts/coms/Chart.yaml b/charts/coms/Chart.yaml index 4bc0df82..3b1286b2 100644 --- a/charts/coms/Chart.yaml +++ b/charts/coms/Chart.yaml @@ -3,7 +3,7 @@ name: common-object-management-service # This is the chart version. This version number should be incremented each time you make changes # to the chart and its templates, including the app version. # Versions are expected to follow Semantic Versioning (https://semver.org/) -version: 1.1.3 +version: 1.1.4 kubeVersion: ">= 1.13.0" description: A microservice for managing access control to S3 Objects # A chart can be either an 'application' or a 'library' chart. @@ -28,7 +28,7 @@ sources: - https://github.com/bcgov/common-object-management-service dependencies: - name: postgrescluster - version: 1.1.3 + version: 1.1.4 repository: "file://../postgres" condition: postgres.enabled alias: postgres diff --git a/charts/coms/values.yaml b/charts/coms/values.yaml index 40443b0b..d7a8cc29 100644 --- a/charts/coms/values.yaml +++ b/charts/coms/values.yaml @@ -217,7 +217,7 @@ postgres: - "ReadWriteOnce" resources: requests: - storage: 0.5Gi + storage: 1Gi storageClassName: "netapp-block-standard" resources: requests: diff --git a/charts/postgres/Chart.yaml b/charts/postgres/Chart.yaml index c8e06973..017dec6e 100644 --- a/charts/postgres/Chart.yaml +++ b/charts/postgres/Chart.yaml @@ -3,5 +3,5 @@ name: postgrescluster description: A Helm chart for Kubernetes type: application # The version below should match the version on the PostgresCluster CRD -version: 1.1.3 +version: 1.1.4 appVersion: 5.6.0