From ad71359bfcaefc8b290f40f5c23a80363fb891de Mon Sep 17 00:00:00 2001 From: Maciej Borsz Date: Mon, 7 Jun 2021 11:34:18 +0200 Subject: [PATCH] Add separate configmaps-secrets module --- clusterloader2/testing/load/config.yaml | 30 +++++++++++++ .../load/modules/configmaps-secrets.yaml | 45 +++++++++++++++++++ .../load/modules/reconcile-objects.yaml | 12 ----- 3 files changed, 75 insertions(+), 12 deletions(-) create mode 100644 clusterloader2/testing/load/modules/configmaps-secrets.yaml diff --git a/clusterloader2/testing/load/config.yaml b/clusterloader2/testing/load/config.yaml index edd1ec785a..2f2ae86bcc 100644 --- a/clusterloader2/testing/load/config.yaml +++ b/clusterloader2/testing/load/config.yaml @@ -84,9 +84,17 @@ tuningSets: parallelismLimitedLoad: parallelismLimit: {{$schedulerThroughputNamespaces}} # TODO(https://github.com/kubernetes/perf-tests/issues/1024): This TuningSet is used only for pod-startup-latency, get rid of it +# Uniform5qps: for each running phase, use 5 qps. - name: Uniform5qps qpsLoad: qps: 5 +# Global100qps: use 100 qps globally: +# * split equally qps among all running phases +# * if some phase finishes, other phases will get more qps. +- name: Global100qps + globalQPSLoad: + qps: 100 + burst: 1 - name: RandomizedSaturationTimeLimited RandomizedTimeLimitedLoad: timeLimit: {{$saturationTime}}s @@ -130,6 +138,18 @@ steps: - basename: daemonset-priorityclass objectTemplatePath: daemonset-priorityclass.yaml +# Moved from reconcile-objects.yaml to mitigate https://github.com/kubernetes/kubernetes/issues/96635. +# TODO(https://github.com/kubernetes/perf-tests/issues/1823): Merge back to reconcile-objects.yaml once the k/k bug is fixed. +- module: + path: /modules/configmaps-secrets.yaml + params: + actionName: create + tuningSet: Global100qps + namespaces: {{$namespaces}} + bigDeploymentsPerNamespace: {{$bigDeploymentsPerNamespace}} + mediumDeploymentsPerNamespace: {{$mediumDeploymentsPerNamespace}} + smallDeploymentsPerNamespace: {{$smallDeploymentsPerNamespace}} + - module: path: /modules/reconcile-objects.yaml params: @@ -306,6 +326,16 @@ steps: pvSmallStatefulSetSize: {{$SMALL_STATEFUL_SETS_PER_NAMESPACE}} pvMediumStatefulSetSize: {{$MEDIUM_STATEFUL_SETS_PER_NAMESPACE}} +- module: + path: /modules/configmaps-secrets.yaml + params: + actionName: delete + tuningSet: Global100qps + namespaces: {{$namespaces}} + bigDeploymentsPerNamespace: {{$bigDeploymentsPerNamespace}} + mediumDeploymentsPerNamespace: {{$mediumDeploymentsPerNamespace}} + smallDeploymentsPerNamespace: {{$smallDeploymentsPerNamespace}} + - name: Deleting PriorityClass for DaemonSets phases: - replicasPerNamespace: 0 diff --git a/clusterloader2/testing/load/modules/configmaps-secrets.yaml b/clusterloader2/testing/load/modules/configmaps-secrets.yaml new file mode 100644 index 0000000000..1aac578af3 --- /dev/null +++ b/clusterloader2/testing/load/modules/configmaps-secrets.yaml @@ -0,0 +1,45 @@ +# To mitigate https://github.com/kubernetes/kubernetes/issues/96635 we have to delete +# configmaps and secrets only AFTER the pods using that configmap/secret are deleted. +# TODO(mborsz): Merge this back to reconcile-objects.yaml once the issue above is fixed. + +{{$actionName := printf "%s objects" .actionName}} +{{$namespaces := .namespaces}} +{{$tuningSet := .tuningSet}} + +{{$bigDeploymentsPerNamespace := .bigDeploymentsPerNamespace}} +{{$mediumDeploymentsPerNamespace := .mediumDeploymentsPerNamespace}} +{{$smallDeploymentsPerNamespace := .smallDeploymentsPerNamespace}} + +steps: +- name: {{$actionName}} configmaps and secrets + phases: + - namespaceRange: + min: 1 + max: {{$namespaces}} + replicasPerNamespace: {{$bigDeploymentsPerNamespace}} + tuningSet: {{$tuningSet}} + objectBundle: + - basename: big-deployment + objectTemplatePath: configmap.yaml + - basename: big-deployment + objectTemplatePath: secret.yaml + - namespaceRange: + min: 1 + max: {{$namespaces}} + replicasPerNamespace: {{$mediumDeploymentsPerNamespace}} + tuningSet: {{$tuningSet}} + objectBundle: + - basename: medium-deployment + objectTemplatePath: configmap.yaml + - basename: medium-deployment + objectTemplatePath: secret.yaml + - namespaceRange: + min: 1 + max: {{$namespaces}} + replicasPerNamespace: {{$smallDeploymentsPerNamespace}} + tuningSet: {{$tuningSet}} + objectBundle: + - basename: small-deployment + objectTemplatePath: configmap.yaml + - basename: small-deployment + objectTemplatePath: secret.yaml diff --git a/clusterloader2/testing/load/modules/reconcile-objects.yaml b/clusterloader2/testing/load/modules/reconcile-objects.yaml index 75b68b8b20..264fa55d5e 100644 --- a/clusterloader2/testing/load/modules/reconcile-objects.yaml +++ b/clusterloader2/testing/load/modules/reconcile-objects.yaml @@ -96,10 +96,6 @@ steps: replicasPerNamespace: {{$bigDeploymentsPerNamespace}} tuningSet: {{$tuningSet}} objectBundle: - - basename: big-deployment - objectTemplatePath: configmap.yaml - - basename: big-deployment - objectTemplatePath: secret.yaml {{if $ENABLE_NETWORKPOLICIES}} - basename: big-deployment objectTemplatePath: networkpolicy.yaml @@ -119,10 +115,6 @@ steps: replicasPerNamespace: {{$mediumDeploymentsPerNamespace}} tuningSet: {{$tuningSet}} objectBundle: - - basename: medium-deployment - objectTemplatePath: configmap.yaml - - basename: medium-deployment - objectTemplatePath: secret.yaml {{if $ENABLE_NETWORKPOLICIES}} - basename: medium-deployment objectTemplatePath: networkpolicy.yaml @@ -141,10 +133,6 @@ steps: replicasPerNamespace: {{$smallDeploymentsPerNamespace}} tuningSet: {{$tuningSet}} objectBundle: - - basename: small-deployment - objectTemplatePath: configmap.yaml - - basename: small-deployment - objectTemplatePath: secret.yaml {{if $ENABLE_NETWORKPOLICIES}} - basename: small-deployment objectTemplatePath: networkpolicy.yaml