Преглед на файлове

ci: update performance test

Ivan Dyachkov преди 2 години
родител
ревизия
1779491f5e
променени са 1 файла, в които са добавени 176 реда и са изтрити 40 реда
  1. 176 40
      .github/workflows/performance_test.yaml

+ 176 - 40
.github/workflows/performance_test.yaml

@@ -5,12 +5,20 @@ on:
     branches:
       - 'perf/**'
   schedule:
-    - cron:  '0 1 * * *'
+    - cron:  '0 1 * * MON-FRI'
   workflow_dispatch:
     inputs:
       ref:
         required: false
 
+env:
+  TF_AWS_REGION: eu-west-1
+  TF_VAR_s3_bucket_name: tf-emqx-performance-test2
+  TF_VAR_test_duration: 1800
+  TF_VAR_prometheus_remote_write_region: eu-west-1
+  TF_VAR_prometheus_remote_write_url: ${{ secrets.TF_EMQX_PERF_TEST_PROMETHEUS_REMOTE_WRITE_URL }}
+  SLACK_WEBHOOK_URL: ${{ secrets.TF_EMQX_PERF_TEST_SLACK_URL }}
+
 jobs:
   prepare:
     runs-on: ubuntu-latest
@@ -52,10 +60,6 @@ jobs:
       - prepare
     env:
       TF_VAR_package_file: ${{ needs.prepare.outputs.PACKAGE_FILE }}
-      TF_AWS_REGION: eu-west-1
-      TF_VAR_test_duration: 1800
-      TF_VAR_prometheus_remote_write_url: ${{ secrets.TF_EMQX_PERF_TEST_PROMETHEUS_REMOTE_WRITE_URL }}
-      TF_VAR_prometheus_remote_write_region: eu-west-1
 
     steps:
     - name: Configure AWS Credentials
@@ -69,7 +73,7 @@ jobs:
       with:
         repository: emqx/tf-emqx-performance-test
         path: tf-emqx-performance-test
-        ref: v0.2.2
+        ref: v0.2.3
     - uses: actions/download-artifact@v3
       with:
         name: emqx-ubuntu20.04
@@ -78,8 +82,7 @@ jobs:
       uses: hashicorp/setup-terraform@v2
       with:
         terraform_wrapper: false
-    - name: 1on1 scenario
-      id: scenario_1on1
+    - name: run scenario
       working-directory: ./tf-emqx-performance-test
       timeout-minutes: 60
       env:
@@ -87,28 +90,92 @@ jobs:
         TF_VAR_use_emqttb: 1
         TF_VAR_use_emqtt_bench: 0
         TF_VAR_emqttb_instance_count: 1
-        TF_VAR_emqttb_instance_type: "c5.2xlarge"
-        TF_VAR_emqttb_scenario: "@pubsub_fwd -n 50_000 --pub-qos 1 --sub-qos 1"
-        TF_VAR_emqx_instance_type: "c5.xlarge"
+        TF_VAR_emqttb_instance_type: c5.2xlarge
+        TF_VAR_emqttb_scenario: '@pubsub_fwd -n 50_000 --pub-qos 1 --sub-qos 1'
+        TF_VAR_emqx_instance_type: c5.2xlarge
         TF_VAR_emqx_instance_count: 3
       run: |
         terraform init
         terraform apply -auto-approve
         ./wait-emqttb.sh
         ./fetch-metrics.sh
-        MESSAGES_RECEIVED=$(cat metrics.json | jq '[.[]."messages.received"] | add')
-        MESSAGES_SENT=$(cat metrics.json | jq '[.[]."messages.sent"] | add')
-        echo MESSAGES_DROPPED=$(cat metrics.json | jq '[.[]."messages.dropped"] | add') >> $GITHUB_OUTPUT
-        echo PUB_MSG_RATE=$(($MESSAGES_RECEIVED / $TF_VAR_test_duration)) >> $GITHUB_OUTPUT
-        echo SUB_MSG_RATE=$(($MESSAGES_SENT / $TF_VAR_test_duration)) >> $GITHUB_OUTPUT
         terraform destroy -auto-approve
+        aws s3 sync --exclude '*' --include '*.tar.gz' s3://$TF_VAR_s3_bucket_name/$TF_VAR_bench_id .
     - name: Send notification to Slack
-      uses: slackapi/slack-github-action@v1.23.0
+      uses: slackapi/slack-github-action@v1.24.0
+      with:
+        payload-file-path: "./tf-emqx-performance-test/slack-payload.json"
+    - name: terraform destroy
+      if: always()
+      working-directory: ./tf-emqx-performance-test
+      run: |
+        terraform destroy -auto-approve
+    - uses: actions/upload-artifact@v3
+      if: success()
+      with:
+        name: metrics
+        path: |
+          "./tf-emqx-performance-test/*.tar.gz"
+    - uses: actions/upload-artifact@v3
+      if: failure()
+      with:
+        name: terraform
+        path: |
+          ./tf-emqx-performance-test/.terraform
+          ./tf-emqx-performance-test/*.tfstate
+
+  scenario_fanout:
+    runs-on: ubuntu-latest
+    needs:
+      - prepare
+      - scenario_1on1
+    env:
+      TF_VAR_package_file: ${{ needs.prepare.outputs.PACKAGE_FILE }}
+
+    steps:
+    - name: Configure AWS Credentials
+      uses: aws-actions/configure-aws-credentials@v2
+      with:
+        aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_PERF_TEST }}
+        aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_PERF_TEST }}
+        aws-region: eu-west-1
+    - name: Checkout tf-emqx-performance-test
+      uses: actions/checkout@v3
+      with:
+        repository: emqx/tf-emqx-performance-test
+        path: tf-emqx-performance-test
+        ref: v0.2.3
+    - uses: actions/download-artifact@v3
+      with:
+        name: emqx-ubuntu20.04
+        path: tf-emqx-performance-test/
+    - name: Setup Terraform
+      uses: hashicorp/setup-terraform@v2
+      with:
+        terraform_wrapper: false
+    - name: run scenario
+      working-directory: ./tf-emqx-performance-test
+      timeout-minutes: 60
       env:
-        SLACK_WEBHOOK_URL: ${{ secrets.TF_EMQX_PERF_TEST_SLACK_URL }}
+        TF_VAR_bench_id: "${{ needs.prepare.outputs.BENCH_ID }}/fan-out"
+        TF_VAR_use_emqttb: 1
+        TF_VAR_use_emqtt_bench: 0
+        TF_VAR_emqttb_instance_count: 1
+        TF_VAR_emqttb_instance_type: c5.2xlarge
+        TF_VAR_emqttb_scenario: '@pub --topic "t/%n" --conninterval 10ms --pubinterval 20ms --num-clients 5 --size 16 @sub --topic "t/#" --conninterval 10ms --num-clients 1000'
+        TF_VAR_emqx_instance_type: c5.large
+        TF_VAR_emqx_instance_count: 3
+      run: |
+        terraform init
+        terraform apply -auto-approve
+        ./wait-emqttb.sh
+        ./fetch-metrics.sh
+        terraform destroy -auto-approve
+        aws s3 sync --exclude '*' --include '*.tar.gz' s3://$TF_VAR_s3_bucket_name/$TF_VAR_bench_id .
+    - name: Send notification to Slack
+      uses: slackapi/slack-github-action@v1.24.0
       with:
-        payload: |
-          {"text": "Performance test result for 1on1 scenario (50k pub, 50k sub): ${{ job.status }}\nhttps://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}\n*Pub message rate*: `${{ steps.scenario_1on1.outputs.PUB_MSG_RATE }}`\n*Sub message rate*: `${{ steps.scenario_1on1.outputs.SUB_MSG_RATE }}`\nDropped messages: `${{ steps.scenario_1on1.outputs.MESSAGES_DROPPED }}`"}
+        payload-file-path: "./tf-emqx-performance-test/slack-payload.json"
     - name: terraform destroy
       if: always()
       working-directory: ./tf-emqx-performance-test
@@ -118,7 +185,81 @@ jobs:
       if: success()
       with:
         name: metrics
-        path: "./tf-emqx-performance-test/*.json"
+        path: |
+          "./tf-emqx-performance-test/*.tar.gz"
+    - uses: actions/upload-artifact@v3
+      if: failure()
+      with:
+        name: terraform
+        path: |
+          ./tf-emqx-performance-test/.terraform
+          ./tf-emqx-performance-test/*.tfstate
+
+  scenario_fanin:
+    runs-on: ubuntu-latest
+    needs:
+      - prepare
+      - scenario_1on1
+      - scenario_fanout
+    env:
+      TF_VAR_package_file: ${{ needs.prepare.outputs.PACKAGE_FILE }}
+
+    steps:
+    - name: Configure AWS Credentials
+      uses: aws-actions/configure-aws-credentials@v2
+      with:
+        aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_PERF_TEST }}
+        aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_PERF_TEST }}
+        aws-region: eu-west-1
+    - name: Checkout tf-emqx-performance-test
+      uses: actions/checkout@v3
+      with:
+        repository: emqx/tf-emqx-performance-test
+        path: tf-emqx-performance-test
+        ref: v0.2.3
+    - uses: actions/download-artifact@v3
+      with:
+        name: emqx-ubuntu20.04
+        path: tf-emqx-performance-test/
+    - name: Setup Terraform
+      uses: hashicorp/setup-terraform@v2
+      with:
+        terraform_wrapper: false
+    - name: run scenario
+      working-directory: ./tf-emqx-performance-test
+      timeout-minutes: 60
+      env:
+        TF_VAR_bench_id: "${{ needs.prepare.outputs.BENCH_ID }}/fan-in"
+        TF_VAR_use_emqttb: 1
+        TF_VAR_use_emqtt_bench: 0
+        TF_VAR_emqttb_instance_count: 2
+        TF_VAR_emqttb_start_n_multiplier: 25000
+        TF_VAR_emqttb_instance_type: c5.xlarge
+        TF_VAR_emqttb_scenario: '@pub --topic t/%n --conninterval 10ms --pubinterval 1s --num-clients 25_000 --start-n $START_N --size 16 @sub --topic \$share/perf/t/# --conninterval 10ms --num-clients 250'
+        TF_VAR_emqx_instance_type: c5.2xlarge
+        TF_VAR_emqx_instance_count: 3
+      run: |
+        terraform init
+        terraform apply -auto-approve
+        ./wait-emqttb.sh
+        ./fetch-metrics.sh
+        terraform destroy -auto-approve
+        aws s3 sync --exclude '*' --include '*.tar.gz' s3://$TF_VAR_s3_bucket_name/$TF_VAR_bench_id .
+    - name: Send notification to Slack
+      uses: slackapi/slack-github-action@v1.24.0
+      with:
+        payload-file-path: "./tf-emqx-performance-test/slack-payload.json"
+    - name: terraform destroy
+      if: always()
+      working-directory: ./tf-emqx-performance-test
+      run: |
+        terraform destroy -auto-approve
+    - uses: actions/upload-artifact@v3
+      if: success()
+      with:
+        name: metrics
+        path: |
+          "./tf-emqx-performance-test/*.tar.gz"
     - uses: actions/upload-artifact@v3
       if: failure()
       with:
@@ -131,13 +272,11 @@ jobs:
     runs-on: ubuntu-latest
     needs:
       - prepare
+      - scenario_fanin
+      - scenario_fanout
       - scenario_1on1
     env:
       TF_VAR_package_file: ${{ needs.prepare.outputs.PACKAGE_FILE }}
-      TF_AWS_REGION: eu-west-1
-      TF_VAR_test_duration: 1800
-      TF_VAR_prometheus_remote_write_url: ${{ secrets.TF_EMQX_PERF_TEST_PROMETHEUS_REMOTE_WRITE_URL }}
-      TF_VAR_prometheus_remote_write_region: eu-west-1
 
     steps:
     - name: Configure AWS Credentials
@@ -151,7 +290,7 @@ jobs:
       with:
         repository: emqx/tf-emqx-performance-test
         path: tf-emqx-performance-test
-        ref: v0.2.2
+        ref: v0.2.3
     - uses: actions/download-artifact@v3
       with:
         name: emqx-ubuntu20.04
@@ -160,33 +299,29 @@ jobs:
       uses: hashicorp/setup-terraform@v2
       with:
         terraform_wrapper: false
-    - name: 1m conns scenario
-      id: scenario_1m_conns
+    - name: run scenario
       working-directory: ./tf-emqx-performance-test
       timeout-minutes: 60
       env:
-        TF_VAR_bench_id: "${{ needs.prepare.outputs.BENCH_ID }}/scenario_1m_conns"
+        TF_VAR_bench_id: "${{ needs.prepare.outputs.BENCH_ID }}/1m-connections"
         TF_VAR_use_emqttb: 1
         TF_VAR_use_emqtt_bench: 0
         TF_VAR_emqttb_instance_count: 5
-        TF_VAR_emqttb_instance_type: "c5.xlarge"
-        TF_VAR_emqttb_scenario: "@conn -N 200_000 --conninterval 1ms"
-        TF_VAR_emqx_instance_type: "c5.xlarge"
-        TF_VAR_emqx_instance_count: 5
+        TF_VAR_emqttb_instance_type: c5.2xlarge
+        TF_VAR_emqttb_scenario: '@conn -N 200_000 --conninterval 1ms'
+        TF_VAR_emqx_instance_type: c5.2xlarge
+        TF_VAR_emqx_instance_count: 3
       run: |
         terraform init
         terraform apply -auto-approve
         ./wait-emqttb.sh
         ./fetch-metrics.sh
-        echo CLIENT_CONNECT=$(cat metrics.json | jq '[.[]."client.connect"] | add') >> $GITHUB_OUTPUT
         terraform destroy -auto-approve
+        aws s3 sync --exclude '*' --include '*.tar.gz' s3://$TF_VAR_s3_bucket_name/$TF_VAR_bench_id .
     - name: Send notification to Slack
-      uses: slackapi/slack-github-action@v1.23.0
-      env:
-        SLACK_WEBHOOK_URL: ${{ secrets.TF_EMQX_PERF_TEST_SLACK_URL }}
+      uses: slackapi/slack-github-action@v1.24.0
       with:
-        payload: |
-          {"text": "Performance test result for 1m conns: ${{ job.status }}\nhttps://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}\n*client.connect*: `${{ steps.scenario_1m_conns.outputs.CLIENT_CONNECT }}`"}
+        payload-file-path: "./tf-emqx-performance-test/slack-payload.json"
     - name: terraform destroy
       if: always()
       working-directory: ./tf-emqx-performance-test
@@ -196,7 +331,8 @@ jobs:
       if: success()
       with:
         name: metrics
-        path: "./tf-emqx-performance-test/*.json"
+        path: |
+          "./tf-emqx-performance-test/*.tar.gz"
     - uses: actions/upload-artifact@v3
       if: failure()
       with: