From 4d35de3bf25a1222d454fa1e2f34dd7f2e3705ee Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Mon, 23 Aug 2021 14:54:24 -0700 Subject: [PATCH 01/10] init commit for stress --- sdk/eventhub/azure-eventhub/stress/Dockerfile | 19 ++++++++++ .../stress/app_insights_metric.py | 5 +-- .../azure_eventhub_consumer_stress_sync.py | 36 +++++++++++++------ sdk/eventhub/azure-eventhub/stress/logger.py | 1 - 4 files changed, 45 insertions(+), 16 deletions(-) create mode 100644 sdk/eventhub/azure-eventhub/stress/Dockerfile diff --git a/sdk/eventhub/azure-eventhub/stress/Dockerfile b/sdk/eventhub/azure-eventhub/stress/Dockerfile new file mode 100644 index 000000000000..2098f3a8765a --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/Dockerfile @@ -0,0 +1,19 @@ +# syntax=docker/dockerfile:1 + +FROM python:3.8-slim-buster + +WORKDIR /app + +COPY ./sdk/eventhub ./sdk/eventhub + +WORKDIR /app/sdk/eventhub/azure-eventhub +RUN python3 setup.py install + +WORKDIR /app/sdk/eventhub/azure-eventhub-checkpointstoreblob +RUN python3 setup.py install + +WORKDIR /app/sdk/eventhub/azure-eventhub-checkpointstoreblob-aio +RUN python3 setup.py install + +WORKDIR /app/sdk/eventhub/azure-eventhub/stress +RUN pip3 install -r dev_requirement.txt diff --git a/sdk/eventhub/azure-eventhub/stress/app_insights_metric.py b/sdk/eventhub/azure-eventhub/stress/app_insights_metric.py index 7b0945eb07a1..9f814fdf2845 100644 --- a/sdk/eventhub/azure-eventhub/stress/app_insights_metric.py +++ b/sdk/eventhub/azure-eventhub/stress/app_insights_metric.py @@ -2,9 +2,6 @@ # Copyright (c) Microsoft Corporation. All rights reserved. # Licensed under the MIT License. See License.txt in the project root for license information. # -------------------------------------------------------------------------------------------- - -import os - from opencensus.ext.azure import metrics_exporter from opencensus.stats import aggregation as aggregation_module from opencensus.stats import measure as measure_module @@ -26,7 +23,7 @@ def __init__(self, test_name, test_description=None): self.desc = test_description events_measure_name = "The number of events handled by " + self.name - events_measure_desc = "The number of events handled by " + self.desc if self.desc else None + events_measure_desc = "The number of events handled by" + self.desc if self.desc else None memory_measure_name = "memory usage percentage for " + self.name memory_measure_desc = "memory usage percentage for " + self.desc if self.desc else None cpu_measure_name = "cpu usage percentage for " + self.name diff --git a/sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_sync.py b/sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_sync.py index b7c74e765a71..28f8bff99ca7 100644 --- a/sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_sync.py +++ b/sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_sync.py @@ -11,6 +11,7 @@ import logging from collections import defaultdict from functools import partial +from dotenv import load_dotenv from azure.identity import ClientSecretCredential from azure.eventhub.extensions.checkpointstoreblob import BlobCheckpointStore @@ -20,6 +21,9 @@ from process_monitor import ProcessMonitor from app_insights_metric import AzureMonitorMetric +ENV_FILE = os.environ.get('ENV_FILE') +load_dotenv(dotenv_path=ENV_FILE, override=True) + def parse_starting_position(args): starting_position = None @@ -37,17 +41,17 @@ def parse_starting_position(args): parser = argparse.ArgumentParser() -parser.add_argument("--link_credit", default=3000, type=int) -parser.add_argument("--output_interval", type=float, default=1000) -parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=30) -parser.add_argument("--consumer_group", help="Consumer group name", default="$default") +parser.add_argument("--link_credit", default=int(os.environ.get("LINK_CREDIT", 3000)), type=int) +parser.add_argument("--output_interval", type=float, default=int(os.environ.get("OUTPUT_INTERVAL", 5000))) +parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 864000))) +parser.add_argument("--consumer_group", help="Consumer group name", default=os.environ.get("CONSUMER_GROUP", "$default")) parser.add_argument("--auth_timeout", help="Authorization Timeout", type=float, default=60) -parser.add_argument("--starting_offset", help="Starting offset", type=str) +parser.add_argument("--starting_offset", help="Starting offset", type=str, default=os.environ.get("STARTING_OFFSET", "-1")) parser.add_argument("--starting_sequence_number", help="Starting sequence number", type=int) parser.add_argument("--starting_datetime", help="Starting datetime string, should be format of YYYY-mm-dd HH:mm:ss") parser.add_argument("--partitions", help="Number of partitions. 0 means to get partitions from eventhubs", type=int, default=0) parser.add_argument("--recv_partition_id", help="Receive from a specific partition if this is set", type=int) -parser.add_argument("--max_batch_size", type=int, default=0, +parser.add_argument("--max_batch_size", type=int, default=int(os.environ.get("MAX_BATCH_SIZE", 0)), help="Call EventHubConsumerClient.receive_batch() if not 0, otherwise call receive()") parser.add_argument("--max_wait_time", type=float, default=0, help="max_wait_time of EventHubConsumerClient.receive_batch() or EventHubConsumerClient.receive()") @@ -55,8 +59,8 @@ def parse_starting_position(args): parser.add_argument("--track_last_enqueued_event_properties", action="store_true") parser.add_argument("--load_balancing_interval", help="time duration in seconds between two load balance", type=float, default=10) parser.add_argument("--conn_str", help="EventHub connection string", - default=os.environ.get('EVENT_HUB_PERF_32_CONN_STR')) -parser.add_argument("--eventhub", help="Name of EventHub") + default=os.environ.get('EVENT_HUB_CONN_STR')) +parser.add_argument("--eventhub", help="Name of EventHub", default=os.environ.get('EVENT_HUB_NAME')) parser.add_argument("--address", help="Address URI to the EventHub entity") parser.add_argument("--sas-policy", help="Name of the shared access policy to authenticate with") parser.add_argument("--sas-key", help="Shared access key") @@ -82,7 +86,14 @@ def parse_starting_position(args): args = parser.parse_args() starting_position = parse_starting_position(args) -LOGGER = get_logger(args.log_filename, "stress_receive_sync", level=logging.INFO, print_console=args.print_console) +print_console = args.print_console or (os.environ.get("PRINT_CONSOLE") == "1") + +LOGGER = get_logger( + args.log_filename, + "stress_receive_sync", + level=logging.INFO, + print_console=print_console +) LOG_PER_COUNT = args.output_interval start_time = time.perf_counter() @@ -105,7 +116,6 @@ def on_event_received(process_monitor, partition_context, event): recv_cnt_map[partition_context.partition_id] += 1 if event else 0 if recv_cnt_map[partition_context.partition_id] % LOG_PER_COUNT == 0: total_time_elapsed = time.perf_counter() - start_time - partition_previous_time = recv_time_map.get(partition_context.partition_id) partition_current_time = time.perf_counter() recv_time_map[partition_context.partition_id] = partition_current_time @@ -213,7 +223,11 @@ def create_client(args): def run(args): - with ProcessMonitor("monitor_{}".format(args.log_filename), "consumer_stress_sync", print_console=args.print_console) as process_monitor: + with ProcessMonitor( + "monitor_{}".format(args.log_filename), + "consumer_stress_sync", + print_console=print_console + ) as process_monitor: kwargs_dict = { "prefetch": args.link_credit, "partition_id": str(args.recv_partition_id) if args.recv_partition_id else None, diff --git a/sdk/eventhub/azure-eventhub/stress/logger.py b/sdk/eventhub/azure-eventhub/stress/logger.py index 0875c2e8a7e0..f8014397569e 100644 --- a/sdk/eventhub/azure-eventhub/stress/logger.py +++ b/sdk/eventhub/azure-eventhub/stress/logger.py @@ -3,7 +3,6 @@ # Licensed under the MIT License. See License.txt in the project root for license information. # -------------------------------------------------------------------------------------------- -import os import sys import logging from logging.handlers import RotatingFileHandler From b67815de9d59ef5e0eec693e3a2ccf2bff90e6be Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Mon, 23 Aug 2021 17:55:02 -0700 Subject: [PATCH 02/10] add dotenv dep --- sdk/eventhub/azure-eventhub/stress/dev_requirement.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt b/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt index e4817ded436f..8ef609bb47a6 100644 --- a/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt +++ b/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt @@ -6,3 +6,4 @@ azure-servicebus==0.50.3 azure-storage-blob azure-identity opencensus-ext-azure +dotenv From 71a299cbd03f9e27381278bdede03fcc039fe7b2 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Tue, 24 Aug 2021 11:51:25 -0700 Subject: [PATCH 03/10] docker, helm, k8s --- sdk/eventhub/azure-eventhub/stress/Chart.lock | 6 + sdk/eventhub/azure-eventhub/stress/Chart.yaml | 13 ++ sdk/eventhub/azure-eventhub/stress/Dockerfile | 13 +- .../azure-eventhub/stress/dev_requirement.txt | 9 - .../azure-eventhub/stress/parameters.json | 5 + .../{ => scripts}/app_insights_metric.py | 0 .../azure_eventhub_consumer_stress_async.py | 0 .../azure_eventhub_consumer_stress_sync.py | 0 .../azure_eventhub_producer_stress.py | 14 +- .../stress/{ => scripts}/common_use_scripts | 0 .../stress/scripts/dev_requirement.txt | 9 + .../stress/{ => scripts}/logger.py | 0 .../stress/{ => scripts}/process_monitor.py | 0 .../stress/{ => scripts}/stress_runner.cfg | 0 .../stress/{ => scripts}/stress_runner.py | 0 .../stress/templates/testjob.yml | 12 ++ .../azure-eventhub/stress/test-resources.json | 202 ++++++++++++++++++ 17 files changed, 258 insertions(+), 25 deletions(-) create mode 100644 sdk/eventhub/azure-eventhub/stress/Chart.lock create mode 100644 sdk/eventhub/azure-eventhub/stress/Chart.yaml delete mode 100644 sdk/eventhub/azure-eventhub/stress/dev_requirement.txt create mode 100644 sdk/eventhub/azure-eventhub/stress/parameters.json rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/app_insights_metric.py (100%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/azure_eventhub_consumer_stress_async.py (100%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/azure_eventhub_consumer_stress_sync.py (100%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/azure_eventhub_producer_stress.py (97%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/common_use_scripts (100%) create mode 100644 sdk/eventhub/azure-eventhub/stress/scripts/dev_requirement.txt rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/logger.py (100%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/process_monitor.py (100%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/stress_runner.cfg (100%) rename sdk/eventhub/azure-eventhub/stress/{ => scripts}/stress_runner.py (100%) create mode 100644 sdk/eventhub/azure-eventhub/stress/templates/testjob.yml create mode 100644 sdk/eventhub/azure-eventhub/stress/test-resources.json diff --git a/sdk/eventhub/azure-eventhub/stress/Chart.lock b/sdk/eventhub/azure-eventhub/stress/Chart.lock new file mode 100644 index 000000000000..c3c0a4b0aa0b --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/Chart.lock @@ -0,0 +1,6 @@ +dependencies: +- name: stress-test-addons + repository: https://stresstestcharts.blob.core.windows.net/helm/ + version: 0.1.6 +digest: sha256:b97697ef5f303eec43e9a94fca8e312d20b8aed71318250499344aeca9880d31 +generated: "2021-08-24T11:24:15.375395-07:00" diff --git a/sdk/eventhub/azure-eventhub/stress/Chart.yaml b/sdk/eventhub/azure-eventhub/stress/Chart.yaml new file mode 100644 index 000000000000..73d1700fbc64 --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/Chart.yaml @@ -0,0 +1,13 @@ +apiVersion: v2 +name: python-eventhubs-stress-test +description: python event hubs stress test. +version: 0.1.0 +appVersion: v0.1 +annotations: + stressTest: 'true' + namespace: python-eventhubs-stress-test-ns + +dependencies: +- name: stress-test-addons + version: 0.1.6 + repository: https://stresstestcharts.blob.core.windows.net/helm/ \ No newline at end of file diff --git a/sdk/eventhub/azure-eventhub/stress/Dockerfile b/sdk/eventhub/azure-eventhub/stress/Dockerfile index 2098f3a8765a..05c55e17da28 100644 --- a/sdk/eventhub/azure-eventhub/stress/Dockerfile +++ b/sdk/eventhub/azure-eventhub/stress/Dockerfile @@ -4,16 +4,7 @@ FROM python:3.8-slim-buster WORKDIR /app -COPY ./sdk/eventhub ./sdk/eventhub +COPY ./scripts /app/stress/scripts -WORKDIR /app/sdk/eventhub/azure-eventhub -RUN python3 setup.py install - -WORKDIR /app/sdk/eventhub/azure-eventhub-checkpointstoreblob -RUN python3 setup.py install - -WORKDIR /app/sdk/eventhub/azure-eventhub-checkpointstoreblob-aio -RUN python3 setup.py install - -WORKDIR /app/sdk/eventhub/azure-eventhub/stress +WORKDIR /app/stress/scripts RUN pip3 install -r dev_requirement.txt diff --git a/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt b/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt deleted file mode 100644 index 8ef609bb47a6..000000000000 --- a/sdk/eventhub/azure-eventhub/stress/dev_requirement.txt +++ /dev/null @@ -1,9 +0,0 @@ -psutil -.. -../../azure-eventhub-checkpointstoreblob -../../azure-eventhub-checkpointstoreblob-aio -azure-servicebus==0.50.3 -azure-storage-blob -azure-identity -opencensus-ext-azure -dotenv diff --git a/sdk/eventhub/azure-eventhub/stress/parameters.json b/sdk/eventhub/azure-eventhub/stress/parameters.json new file mode 100644 index 000000000000..2df20a6d1780 --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/parameters.json @@ -0,0 +1,5 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#", + "contentVersion": "1.0.0.0", + "parameters": { } +} \ No newline at end of file diff --git a/sdk/eventhub/azure-eventhub/stress/app_insights_metric.py b/sdk/eventhub/azure-eventhub/stress/scripts/app_insights_metric.py similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/app_insights_metric.py rename to sdk/eventhub/azure-eventhub/stress/scripts/app_insights_metric.py diff --git a/sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_async.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_async.py rename to sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py diff --git a/sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_sync.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_sync.py similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/azure_eventhub_consumer_stress_sync.py rename to sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_sync.py diff --git a/sdk/eventhub/azure-eventhub/stress/azure_eventhub_producer_stress.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py similarity index 97% rename from sdk/eventhub/azure-eventhub/stress/azure_eventhub_producer_stress.py rename to sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py index bf6812d82d46..49dee4387783 100644 --- a/sdk/eventhub/azure-eventhub/stress/azure_eventhub_producer_stress.py +++ b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py @@ -9,6 +9,7 @@ import time import asyncio from argparse import ArgumentParser +from dotenv import load_dotenv from azure.eventhub import EventHubProducerClient, EventData, EventHubSharedKeyCredential, TransportType from azure.eventhub.exceptions import EventHubError @@ -20,6 +21,8 @@ from process_monitor import ProcessMonitor from app_insights_metric import AzureMonitorMetric +ENV_FILE = os.environ.get('ENV_FILE') + def handle_exception(error, ignore_send_failure, stress_logger, azure_monitor_metric): err_msg = "Sync send failed due to error: {}".format(repr(error)) @@ -89,9 +92,9 @@ async def stress_send_list_async(producer: EventHubProducerClientAsync, args, st class StressTestRunner(object): def __init__(self, argument_parser): self.argument_parser = argument_parser - self.argument_parser.add_argument("-m", "--method", required=True) - self.argument_parser.add_argument("--output_interval", type=float, default=1000) - self.argument_parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=30) + self.argument_parser.add_argument("-m", "--method", default="stress_send_list_sync") + self.argument_parser.add_argument("--output_interval", type=float, default=int(os.environ.get("OUTPUT_INTERVAL", 5000))) + self.argument_parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 864000))) self.argument_parser.add_argument( "--partitions", help="Number of partitions. 0 means to get partitions from eventhubs", @@ -109,9 +112,9 @@ def __init__(self, argument_parser): type=str ) self.argument_parser.add_argument("--conn_str", help="EventHub connection string", - default=os.environ.get('EVENT_HUB_PERF_32_CONN_STR')) + default=os.environ.get('EVENT_HUB_CONN_STR')) parser.add_argument("--auth_timeout", help="Authorization Timeout", type=float, default=60) - self.argument_parser.add_argument("--eventhub", help="Name of EventHub") + self.argument_parser.add_argument("--eventhub", help="Name of EventHub", default=os.environ.get('EVENT_HUB_NAME')) self.argument_parser.add_argument( "--transport_type", help="Transport type, 0 means AMQP, 1 means AMQP over WebSocket", @@ -412,6 +415,7 @@ async def run_test_method_parallel_async(self, test_method, worker, logger, proc if __name__ == '__main__': + load_dotenv(dotenv_path=ENV_FILE, override=True) parser = ArgumentParser() runner = StressTestRunner(parser) runner.run() diff --git a/sdk/eventhub/azure-eventhub/stress/common_use_scripts b/sdk/eventhub/azure-eventhub/stress/scripts/common_use_scripts similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/common_use_scripts rename to sdk/eventhub/azure-eventhub/stress/scripts/common_use_scripts diff --git a/sdk/eventhub/azure-eventhub/stress/scripts/dev_requirement.txt b/sdk/eventhub/azure-eventhub/stress/scripts/dev_requirement.txt new file mode 100644 index 000000000000..d3ffc7a78295 --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/scripts/dev_requirement.txt @@ -0,0 +1,9 @@ +psutil +azure-eventhub +azure-eventhub-checkpointstoreblob +azure-eventhub-checkpointstoreblob-aio +azure-servicebus==0.50.3 +azure-storage-blob +azure-identity +opencensus-ext-azure +python-dotenv diff --git a/sdk/eventhub/azure-eventhub/stress/logger.py b/sdk/eventhub/azure-eventhub/stress/scripts/logger.py similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/logger.py rename to sdk/eventhub/azure-eventhub/stress/scripts/logger.py diff --git a/sdk/eventhub/azure-eventhub/stress/process_monitor.py b/sdk/eventhub/azure-eventhub/stress/scripts/process_monitor.py similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/process_monitor.py rename to sdk/eventhub/azure-eventhub/stress/scripts/process_monitor.py diff --git a/sdk/eventhub/azure-eventhub/stress/stress_runner.cfg b/sdk/eventhub/azure-eventhub/stress/scripts/stress_runner.cfg similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/stress_runner.cfg rename to sdk/eventhub/azure-eventhub/stress/scripts/stress_runner.cfg diff --git a/sdk/eventhub/azure-eventhub/stress/stress_runner.py b/sdk/eventhub/azure-eventhub/stress/scripts/stress_runner.py similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/stress_runner.py rename to sdk/eventhub/azure-eventhub/stress/scripts/stress_runner.py diff --git a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml new file mode 100644 index 000000000000..3e3ea681998c --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml @@ -0,0 +1,12 @@ +{{- include "stress-test-addons.deploy-job-template.from-pod" (list . "stress.python-eh-stress") -}} +{{- define "stress.python-eh-stress" -}} +metadata: + labels: + testName: "deploy-python-eh-stress" +spec: + containers: + - name: python-eh-stress + image: stresstestregistry.azurecr.io/yuling/py-eh-stress:v1 + {{- include "stress-test-addons.container-env" . | nindent 10 }} + command: ['bash', '-c', 'python3 azure_eventhub_producer_stress.py && python3 azure_eventhub_consumer_stress_sync.py'] +{{- end -}} \ No newline at end of file diff --git a/sdk/eventhub/azure-eventhub/stress/test-resources.json b/sdk/eventhub/azure-eventhub/stress/test-resources.json new file mode 100644 index 000000000000..3566eb9745f9 --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/test-resources.json @@ -0,0 +1,202 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "baseName": { + "type": "string", + "defaultValue": "[resourceGroup().name]", + "metadata": { + "description": "The base resource name." + } + }, + "subscriptionId": { + "type": "string", + "defaultValue": "[subscription().subscriptionId]", + "metadata": { + "description": "The subscription ID to which the application and resources belong." + } + }, + "tenantId": { + "type": "string", + "defaultValue": "[subscription().tenantId]", + "metadata": { + "description": "The tenant ID to which the application and resources belong." + } + }, + "testApplicationOid": { + "type": "string", + "metadata": { + "description": "The client OID to grant access to test resources." + } + }, + "testApplicationId": { + "type": "string", + "metadata": { + "description": "The application client ID used to run tests." + } + }, + "testApplicationSecret": { + "type": "string", + "metadata": { + "description": "The application client secret used to run tests." + } + }, + "location": { + "type": "string", + "defaultValue": "[resourceGroup().location]", + "metadata": { + "description": "The location of the resources. By default, this is the same as the resource group." + } + }, + "storageEndpointSuffix": { + "type": "string", + "defaultValue": "core.windows.net", + "metadata": { + "description": "The url suffix to use when creating storage connection strings." + } + }, + "perTestExecutionLimitMinutes": { + "type": "string", + "defaultValue": "10", + "metadata": { + "description": "The maximum duration, in minutes, that a single test is permitted to run before it is considered at-risk for being hung." + } + } + }, + "variables": { + "ehVersion": "2017-04-01", + "contributorRoleId": "b24988ac-6180-42a0-ab88-20f7382dd24c", + "eventHubsDataOwnerRoleId": "f526a384-b230-433a-b45c-95f59c4a2dec", + "eventHubsNamespace": "[concat('eh-', parameters('baseName'))]", + "eventHubName": "[concat('eh-', parameters('baseName'), '-hub')]", + "eventHubAuthRuleName": "[concat('eh-', parameters('baseName'), '-hub-auth-rule')]", + "storageAccount": "[concat('blb', parameters('baseName'))]", + "containerName": "your-blob-container-name", + "defaultSASKeyName": "RootManageSharedAccessKey", + "eventHubsAuthRuleResourceId": "[resourceId('Microsoft.EventHub/namespaces/authorizationRules', variables('eventHubsNamespace'), variables('defaultSASKeyName'))]", + "storageAccountId": "[resourceId('Microsoft.Storage/storageAccounts', variables('storageAccount'))]", + }, + "resources": [ + { + "apiVersion": "[variables('ehVersion')]", + "name": "[variables('eventHubsNamespace')]", + "type": "Microsoft.EventHub/Namespaces", + "location": "[parameters('location')]", + "sku": { + "name": "Standard", + "tier": "Standard" + }, + "resources": [ + { + "type": "Microsoft.EventHub/namespaces/eventhubs", + "apiVersion": "[variables('ehVersion')]", + "name": "[concat(variables('eventHubsNamespace'), '/', variables('eventHubName'))]", + "location": "[parameters('location')]", + "dependsOn": [ + "[resourceId('Microsoft.EventHub/namespaces', variables('eventHubsNamespace'))]" + ], + "properties": { + "messageRetentionInDays": 7, + "partitionCount": 1 + }, + "resources": [ + { + "apiVersion": "[variables('ehVersion')]", + "name": "[variables('eventHubAuthRuleName')]", + "type": "authorizationRules", + "dependsOn": [ + "[variables('eventHubName')]" + ], + "properties": { + "Rights": ["Manage", "Send", "Listen"] + } + } + ] + } + ], + "properties": {} + }, + { + "type": "Microsoft.Storage/storageAccounts", + "apiVersion": "2019-06-01", + "name": "[variables('storageAccount')]", + "location": "[parameters('location')]", + "sku": { + "name": "Standard_LRS", + "tier": "Standard" + }, + "kind": "StorageV2", + "properties": { + "accessTier": "Hot" + }, + "resources": [ + { + "type": "blobServices/containers", + "apiVersion": "2019-06-01", + "name": "[concat('default/', variables('containerName'))]", + "dependsOn": [ + "[variables('storageAccount')]" + ] + } + ] + }, + { + "type": "Microsoft.Authorization/roleAssignments", + "apiVersion": "2019-04-01-preview", + "name": "[guid(resourceGroup().id, deployment().name, parameters('baseName'), variables('eventHubsDataOwnerRoleId'), parameters('testApplicationOid'))]", + "properties": { + "roleDefinitionId": "[resourceId('Microsoft.Authorization/roleDefinitions', variables('eventHubsDataOwnerRoleId'))]", + "principalId": "[parameters('testApplicationOid')]", + "scope": "[resourceGroup().id]" + } + }, + { + "type": "Microsoft.Authorization/roleAssignments", + "apiVersion": "2019-04-01-preview", + "name": "[guid(resourceGroup().id, deployment().name, parameters('baseName'), variables('contributorRoleId'), parameters('testApplicationOid'))]", + "properties": { + "roleDefinitionId": "[resourceId('Microsoft.Authorization/roleDefinitions', variables('contributorRoleId'))]", + "principalId": "[parameters('testApplicationOid')]", + "scope": "[resourceGroup().id]" + } + } + ], + "outputs": { + "EVENT_HUB_NAMESPACE": { + "type": "string", + "value": "[variables('eventHubsNamespace')]" + }, + "EVENT_HUB_HOSTNAME": { + "type": "string", + "value": "[concat(variables('eventHubsNamespace'), '.servicebus.windows.net')]" + }, + "EVENT_HUB_CONN_STR": { + "type": "string", + "value": "[listkeys(variables('eventHubAuthRuleName'), variables('ehVersion')).primaryConnectionString]" + }, + "EVENT_HUB_NAME": { + "type": "string", + "value": "[variables('eventHubName')]" + }, + "EVENT_HUB_SAS_POLICY":{ + "type": "string", + "value": "[variables('eventHubAuthRuleName')]" + }, + "EVENT_HUB_SAS_KEY":{ + "type": "string", + "value": "[listkeys(variables('eventHubAuthRuleName'), variables('ehVersion')).primaryKey]" + }, + "AZURE_STORAGE_CONN_STR": { + "type": "string", + "value": "[concat('DefaultEndpointsProtocol=https;AccountName=', variables('storageAccount'), ';AccountKey=', listKeys(variables('storageAccountId'), providers('Microsoft.Storage', 'storageAccounts').apiVersions[0]).keys[0].value, ';EndpointSuffix=', parameters('storageEndpointSuffix'))]" + }, + "AZURE_STORAGE_ACCOUNT": { + "type": "string", + "value": "[variables('storageAccount')]" + }, + "AZURE_STORAGE_ACCESS_KEY":{ + "type": "string", + "value": "[listKeys(variables('storageAccountId'), providers('Microsoft.Storage', 'storageAccounts').apiVersions[0]).keys[0].value]" + } + } +} From f5972609baff99350b8522b888abdc4acea23082 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Tue, 24 Aug 2021 16:40:42 -0700 Subject: [PATCH 04/10] apply changes --- sdk/eventhub/azure-eventhub/stress/Chart.yaml | 2 +- .../azure_eventhub_consumer_stress_async.py | 23 ++-- .../stress/templates/testjob.yml | 10 +- .../stress/test-resources.bicep | 107 ++++++++++++++++++ .../azure-eventhub/stress/test-resources.json | 41 +------ 5 files changed, 132 insertions(+), 51 deletions(-) create mode 100644 sdk/eventhub/azure-eventhub/stress/test-resources.bicep diff --git a/sdk/eventhub/azure-eventhub/stress/Chart.yaml b/sdk/eventhub/azure-eventhub/stress/Chart.yaml index 73d1700fbc64..8a638170f88b 100644 --- a/sdk/eventhub/azure-eventhub/stress/Chart.yaml +++ b/sdk/eventhub/azure-eventhub/stress/Chart.yaml @@ -1,7 +1,7 @@ apiVersion: v2 name: python-eventhubs-stress-test description: python event hubs stress test. -version: 0.1.0 +version: 0.1.1 appVersion: v0.1 annotations: stressTest: 'true' diff --git a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py index ad99f73455c0..63067036e3b3 100644 --- a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py +++ b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py @@ -11,6 +11,7 @@ import logging from collections import defaultdict from functools import partial +from dotenv import load_dotenv from azure.identity.aio import ClientSecretCredential from azure.eventhub.aio import EventHubConsumerClient @@ -22,6 +23,9 @@ from process_monitor import ProcessMonitor from app_insights_metric import AzureMonitorMetric +ENV_FILE = os.environ.get('ENV_FILE') +load_dotenv(dotenv_path=ENV_FILE, override=True) + def parse_starting_position(args): starting_position = None @@ -39,25 +43,26 @@ def parse_starting_position(args): parser = argparse.ArgumentParser() -parser.add_argument("--link_credit", default=3000, type=int) -parser.add_argument("--output_interval", type=float, default=1000) -parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=30) -parser.add_argument("--consumer_group", help="Consumer group name", default="$default") +parser.add_argument("--link_credit", default=int(os.environ.get("LINK_CREDIT", 3000)), type=int) +parser.add_argument("--output_interval", type=float, default=int(os.environ.get("OUTPUT_INTERVAL", 5000))) +parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 864000))) +parser.add_argument("--consumer_group", help="Consumer group name", default=os.environ.get("CONSUMER_GROUP", "$default")) parser.add_argument("--auth_timeout", help="Authorization Timeout", type=float, default=60) -parser.add_argument("--starting_offset", help="Starting offset", type=str) +parser.add_argument("--starting_offset", help="Starting offset", type=str, default=os.environ.get("STARTING_OFFSET", "-1")) parser.add_argument("--starting_sequence_number", help="Starting sequence number", type=int) -parser.add_argument("--starting_datetime", help="Starting datetime string, should be format of YYYY-mm-dd HH:mm:ss", type=str) +parser.add_argument("--starting_datetime", help="Starting datetime string, should be format of YYYY-mm-dd HH:mm:ss") parser.add_argument("--partitions", help="Number of partitions. 0 means to get partitions from eventhubs", type=int, default=0) parser.add_argument("--recv_partition_id", help="Receive from a specific partition if this is set", type=int) -parser.add_argument("--max_batch_size", type=int, default=0, +parser.add_argument("--max_batch_size", type=int, default=int(os.environ.get("MAX_BATCH_SIZE", 0)), help="Call EventHubConsumerClient.receive_batch() if not 0, otherwise call receive()") parser.add_argument("--max_wait_time", type=float, default=0, help="max_wait_time of EventHubConsumerClient.receive_batch() or EventHubConsumerClient.receive()") + parser.add_argument("--track_last_enqueued_event_properties", action="store_true") parser.add_argument("--load_balancing_interval", help="time duration in seconds between two load balance", type=float, default=10) parser.add_argument("--conn_str", help="EventHub connection string", - default=os.environ.get('EVENT_HUB_PERF_32_CONN_STR')) -parser.add_argument("--eventhub", help="Name of EventHub") + default=os.environ.get('EVENT_HUB_CONN_STR')) +parser.add_argument("--eventhub", help="Name of EventHub", default=os.environ.get('EVENT_HUB_NAME')) parser.add_argument("--address", help="Address URI to the EventHub entity") parser.add_argument("--sas_policy", help="Name of the shared access policy to authenticate with") parser.add_argument("--sas_key", help="Shared access key") diff --git a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml index 3e3ea681998c..2d8327c837de 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml +++ b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml @@ -6,7 +6,9 @@ metadata: spec: containers: - name: python-eh-stress - image: stresstestregistry.azurecr.io/yuling/py-eh-stress:v1 - {{- include "stress-test-addons.container-env" . | nindent 10 }} - command: ['bash', '-c', 'python3 azure_eventhub_producer_stress.py && python3 azure_eventhub_consumer_stress_sync.py'] -{{- end -}} \ No newline at end of file + image: stresstestregistry.azurecr.io/yuling/py-eh-stress:v2 + {{- include "stress-test-addons.container-env" . | nindent 6 }} + command: ['bash', '-c', 'python3 azure_eventhub_producer_stress.py & python3 azure_eventhub_consumer_stress_sync.py'] + # async test command + # command: ['bash', '-c', 'python3 azure_eventhub_producer_stress.py -m stress_send_list_async & python3 azure_eventhub_consumer_stress_async.py'] +{{- end -}} diff --git a/sdk/eventhub/azure-eventhub/stress/test-resources.bicep b/sdk/eventhub/azure-eventhub/stress/test-resources.bicep new file mode 100644 index 000000000000..353192bab4f7 --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/test-resources.bicep @@ -0,0 +1,107 @@ +@description('The base resource name.') +param baseName string = resourceGroup().name + +@description('The client OID to grant access to test resources.') +param testApplicationOid string + +@description('The location of the resources. By default, this is the same as the resource group.') +param location string = resourceGroup().location + +@description('The url suffix to use when creating storage connection strings.') +param storageEndpointSuffix string = 'core.windows.net' + +var ehVersion = '2017-04-01' +var contributorRoleId = 'b24988ac-6180-42a0-ab88-20f7382dd24c' +var eventHubsDataOwnerRoleId = 'f526a384-b230-433a-b45c-95f59c4a2dec' +var eventHubsNamespace_var = 'eh-${baseName}' +var eventHubName = 'eh-${baseName}-hub' +var eventHubAuthRuleName = 'eh-${baseName}-hub-auth-rule' +var storageAccount_var = replace('blb${baseName}', '-', '') +var containerName = 'your-blob-container-name' +var defaultSASKeyName = 'RootManageSharedAccessKey' +var eventHubsAuthRuleResourceId = resourceId('Microsoft.EventHub/namespaces/authorizationRules', eventHubsNamespace_var, defaultSASKeyName) +var storageAccountId = storageAccount.id + +resource eventHubsNamespace 'Microsoft.EventHub/Namespaces@[variables(\'ehVersion\')]' = { + name: eventHubsNamespace_var + location: location + sku: { + name: 'Standard' + tier: 'Standard' + } + properties: {} +} + +resource eventHubsNamespace_eventHubName 'Microsoft.EventHub/namespaces/eventhubs@[variables(\'ehVersion\')]' = { + name: '${eventHubsNamespace_var}/${eventHubName}' + location: location + properties: { + messageRetentionInDays: 1 + partitionCount: 32 + } + dependsOn: [ + eventHubsNamespace + ] +} + +resource eventHubsNamespace_eventHubName_eventHubAuthRuleName 'Microsoft.EventHub/namespaces/eventhubs/authorizationRules@[variables(\'ehVersion\')]' = { + name: '${eventHubsNamespace_var}/${eventHubName}/${eventHubAuthRuleName}' + properties: { + Rights: [ + 'Manage' + 'Send' + 'Listen' + ] + } + dependsOn: [ + eventHubsNamespace_eventHubName + ] +} + +resource storageAccount 'Microsoft.Storage/storageAccounts@2019-06-01' = { + name: storageAccount_var + location: location + sku: { + name: 'Standard_LRS' + tier: 'Standard' + } + kind: 'StorageV2' + properties: { + accessTier: 'Hot' + } +} + +resource storageAccount_default_containerName 'Microsoft.Storage/storageAccounts/blobServices/containers@2019-06-01' = { + name: '${storageAccount_var}/default/${containerName}' + dependsOn: [ + storageAccount + ] +} + +resource id_name_baseName_eventHubsDataOwnerRoleId_testApplicationOid 'Microsoft.Authorization/roleAssignments@2019-04-01-preview' = { + name: guid(resourceGroup().id, deployment().name, baseName, eventHubsDataOwnerRoleId, testApplicationOid) + properties: { + roleDefinitionId: resourceId('Microsoft.Authorization/roleDefinitions', eventHubsDataOwnerRoleId) + principalId: testApplicationOid + scope: resourceGroup().id + } +} + +resource id_name_baseName_contributorRoleId_testApplicationOid 'Microsoft.Authorization/roleAssignments@2019-04-01-preview' = { + name: guid(resourceGroup().id, deployment().name, baseName, contributorRoleId, testApplicationOid) + properties: { + roleDefinitionId: resourceId('Microsoft.Authorization/roleDefinitions', contributorRoleId) + principalId: testApplicationOid + scope: resourceGroup().id + } +} + +output EVENT_HUB_NAMESPACE string = eventHubsNamespace_var +output EVENT_HUB_HOSTNAME string = '${eventHubsNamespace_var}.servicebus.windows.net' +output EVENT_HUB_CONN_STR string = listkeys(eventHubAuthRuleName, ehVersion).primaryConnectionString +output EVENT_HUB_NAME string = eventHubName +output EVENT_HUB_SAS_POLICY string = eventHubAuthRuleName +output EVENT_HUB_SAS_KEY string = listkeys(eventHubAuthRuleName, ehVersion).primaryKey +output AZURE_STORAGE_CONN_STR string = 'DefaultEndpointsProtocol=https;AccountName=${storageAccount_var};AccountKey=${listKeys(storageAccountId, providers('Microsoft.Storage', 'storageAccounts').apiVersions[0]).keys[0].value};EndpointSuffix=${storageEndpointSuffix}' +output AZURE_STORAGE_ACCOUNT string = storageAccount_var +output AZURE_STORAGE_ACCESS_KEY string = listKeys(storageAccountId, providers('Microsoft.Storage', 'storageAccounts').apiVersions[0]).keys[0].value \ No newline at end of file diff --git a/sdk/eventhub/azure-eventhub/stress/test-resources.json b/sdk/eventhub/azure-eventhub/stress/test-resources.json index 3566eb9745f9..3b46c8e656a7 100644 --- a/sdk/eventhub/azure-eventhub/stress/test-resources.json +++ b/sdk/eventhub/azure-eventhub/stress/test-resources.json @@ -9,38 +9,12 @@ "description": "The base resource name." } }, - "subscriptionId": { - "type": "string", - "defaultValue": "[subscription().subscriptionId]", - "metadata": { - "description": "The subscription ID to which the application and resources belong." - } - }, - "tenantId": { - "type": "string", - "defaultValue": "[subscription().tenantId]", - "metadata": { - "description": "The tenant ID to which the application and resources belong." - } - }, "testApplicationOid": { "type": "string", "metadata": { "description": "The client OID to grant access to test resources." } }, - "testApplicationId": { - "type": "string", - "metadata": { - "description": "The application client ID used to run tests." - } - }, - "testApplicationSecret": { - "type": "string", - "metadata": { - "description": "The application client secret used to run tests." - } - }, "location": { "type": "string", "defaultValue": "[resourceGroup().location]", @@ -54,13 +28,6 @@ "metadata": { "description": "The url suffix to use when creating storage connection strings." } - }, - "perTestExecutionLimitMinutes": { - "type": "string", - "defaultValue": "10", - "metadata": { - "description": "The maximum duration, in minutes, that a single test is permitted to run before it is considered at-risk for being hung." - } } }, "variables": { @@ -70,11 +37,11 @@ "eventHubsNamespace": "[concat('eh-', parameters('baseName'))]", "eventHubName": "[concat('eh-', parameters('baseName'), '-hub')]", "eventHubAuthRuleName": "[concat('eh-', parameters('baseName'), '-hub-auth-rule')]", - "storageAccount": "[concat('blb', parameters('baseName'))]", + "storageAccount": "[replace(concat('blb', parameters('baseName')), '-', '')]", "containerName": "your-blob-container-name", "defaultSASKeyName": "RootManageSharedAccessKey", "eventHubsAuthRuleResourceId": "[resourceId('Microsoft.EventHub/namespaces/authorizationRules', variables('eventHubsNamespace'), variables('defaultSASKeyName'))]", - "storageAccountId": "[resourceId('Microsoft.Storage/storageAccounts', variables('storageAccount'))]", + "storageAccountId": "[resourceId('Microsoft.Storage/storageAccounts', variables('storageAccount'))]" }, "resources": [ { @@ -96,8 +63,8 @@ "[resourceId('Microsoft.EventHub/namespaces', variables('eventHubsNamespace'))]" ], "properties": { - "messageRetentionInDays": 7, - "partitionCount": 1 + "messageRetentionInDays": 1, + "partitionCount": 32 }, "resources": [ { From 7aa269fae0024a0114afdf826174db0f4abb85d8 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Tue, 24 Aug 2021 17:00:16 -0700 Subject: [PATCH 05/10] run forever --- .../stress/scripts/azure_eventhub_consumer_stress_async.py | 2 +- .../stress/scripts/azure_eventhub_consumer_stress_sync.py | 2 +- .../stress/scripts/azure_eventhub_producer_stress.py | 2 +- sdk/eventhub/azure-eventhub/stress/templates/testjob.yml | 1 + 4 files changed, 4 insertions(+), 3 deletions(-) diff --git a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py index 63067036e3b3..eadf7fe3f7f6 100644 --- a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py +++ b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_async.py @@ -45,7 +45,7 @@ def parse_starting_position(args): parser = argparse.ArgumentParser() parser.add_argument("--link_credit", default=int(os.environ.get("LINK_CREDIT", 3000)), type=int) parser.add_argument("--output_interval", type=float, default=int(os.environ.get("OUTPUT_INTERVAL", 5000))) -parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 864000))) +parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 999999999))) parser.add_argument("--consumer_group", help="Consumer group name", default=os.environ.get("CONSUMER_GROUP", "$default")) parser.add_argument("--auth_timeout", help="Authorization Timeout", type=float, default=60) parser.add_argument("--starting_offset", help="Starting offset", type=str, default=os.environ.get("STARTING_OFFSET", "-1")) diff --git a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_sync.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_sync.py index 28f8bff99ca7..534c4d8996b0 100644 --- a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_sync.py +++ b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_consumer_stress_sync.py @@ -43,7 +43,7 @@ def parse_starting_position(args): parser = argparse.ArgumentParser() parser.add_argument("--link_credit", default=int(os.environ.get("LINK_CREDIT", 3000)), type=int) parser.add_argument("--output_interval", type=float, default=int(os.environ.get("OUTPUT_INTERVAL", 5000))) -parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 864000))) +parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 999999999))) parser.add_argument("--consumer_group", help="Consumer group name", default=os.environ.get("CONSUMER_GROUP", "$default")) parser.add_argument("--auth_timeout", help="Authorization Timeout", type=float, default=60) parser.add_argument("--starting_offset", help="Starting offset", type=str, default=os.environ.get("STARTING_OFFSET", "-1")) diff --git a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py index 49dee4387783..acd275a5a2f6 100644 --- a/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py +++ b/sdk/eventhub/azure-eventhub/stress/scripts/azure_eventhub_producer_stress.py @@ -94,7 +94,7 @@ def __init__(self, argument_parser): self.argument_parser = argument_parser self.argument_parser.add_argument("-m", "--method", default="stress_send_list_sync") self.argument_parser.add_argument("--output_interval", type=float, default=int(os.environ.get("OUTPUT_INTERVAL", 5000))) - self.argument_parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 864000))) + self.argument_parser.add_argument("--duration", help="Duration in seconds of the test", type=int, default=int(os.environ.get("DURATION", 999999999))) self.argument_parser.add_argument( "--partitions", help="Number of partitions. 0 means to get partitions from eventhubs", diff --git a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml index 2d8327c837de..c4a893299867 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml +++ b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml @@ -3,6 +3,7 @@ metadata: labels: testName: "deploy-python-eh-stress" + chaos: "true" spec: containers: - name: python-eh-stress From c645bed53b7e0af380b2b6916db578c56c46c451 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Tue, 24 Aug 2021 18:07:45 -0700 Subject: [PATCH 06/10] add chaos --- .../stress/templates/network_loss.yaml | 34 +++++++++++++++++++ .../stress/templates/testjob.yml | 1 + 2 files changed, 35 insertions(+) create mode 100644 sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml diff --git a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml new file mode 100644 index 000000000000..1a1d67f90595 --- /dev/null +++ b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml @@ -0,0 +1,34 @@ +{{- range (.Values.scenarios) }} +--- +apiVersion: chaos-mesh.org/v1alpha1 +kind: NetworkChaos +metadata: + name: '{{ lower . }}-{{ $.Release.Name }}-{{ $.Release.Revision }}' + namespace: {{ $.Release.Namespace }} + annotations: + experiment.chaos-mesh.org/pause: 'true' + labels: + scenario: '{{ . }}' + release: '{{ $.Release.Name }}' + revision: '{{ $.Release.Revision }}' +spec: + scheduler: + cron: '@every 30s' + duration: '10s' + action: loss + direction: to + externalTargets: + - 'eh-{{ .Scenario }}-{{ .Release.Name }}-{{ .Release.Revision}}.servicebus.windows.net' + mode: one + selector: + labelSelectors: + testInstance: 'deploy-python-eh-stress-instance' + chaos: 'true' + namespaces: + - {{ $.Release.Namespace }} + podPhaseSelectors: + - 'Running' + loss: + loss: '100' + correlation: '100' +{{- end }} \ No newline at end of file diff --git a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml index c4a893299867..681efd2855f2 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml +++ b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml @@ -3,6 +3,7 @@ metadata: labels: testName: "deploy-python-eh-stress" + testInstance: "deploy-python-eh-stress-instance" chaos: "true" spec: containers: From 7fc5dad9f59434afdc5ac3fb9bd1083d426d2a56 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Tue, 24 Aug 2021 20:09:42 -0700 Subject: [PATCH 07/10] update chaos jos --- .../azure-eventhub/stress/templates/network_loss.yaml | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml index 1a1d67f90595..650ddefc676d 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml +++ b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml @@ -1,14 +1,12 @@ -{{- range (.Values.scenarios) }} ---- apiVersion: chaos-mesh.org/v1alpha1 kind: NetworkChaos metadata: - name: '{{ lower . }}-{{ $.Release.Name }}-{{ $.Release.Revision }}' + name: '{{ $.Release.Name }}-{{ $.Release.Revision }}' namespace: {{ $.Release.Namespace }} annotations: experiment.chaos-mesh.org/pause: 'true' labels: - scenario: '{{ . }}' + scenario: 'stress' release: '{{ $.Release.Name }}' revision: '{{ $.Release.Revision }}' spec: @@ -18,7 +16,7 @@ spec: action: loss direction: to externalTargets: - - 'eh-{{ .Scenario }}-{{ .Release.Name }}-{{ .Release.Revision}}.servicebus.windows.net' + - 'eh-stress-{{ .Release.Name }}-{{ .Release.Revision}}.servicebus.windows.net' mode: one selector: labelSelectors: @@ -31,4 +29,3 @@ spec: loss: loss: '100' correlation: '100' -{{- end }} \ No newline at end of file From e045833bf0ca618909fca078436548e243f4c8c5 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Wed, 8 Sep 2021 00:18:42 -0700 Subject: [PATCH 08/10] Apply suggestions from code review Co-authored-by: Ben Broderick Phillips --- .../azure-eventhub/stress/templates/network_loss.yaml | 2 +- sdk/eventhub/azure-eventhub/stress/templates/testjob.yml | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml index 650ddefc676d..6f15e1014e8d 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml +++ b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml @@ -20,7 +20,7 @@ spec: mode: one selector: labelSelectors: - testInstance: 'deploy-python-eh-stress-instance' + testInstance: "eventhub-{{ .Release.Name }}-{{ .Release.Revision }}" chaos: 'true' namespaces: - {{ $.Release.Namespace }} diff --git a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml index 681efd2855f2..fde684783937 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml +++ b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml @@ -3,14 +3,14 @@ metadata: labels: testName: "deploy-python-eh-stress" - testInstance: "deploy-python-eh-stress-instance" + testInstance: "eventhub-{{ .Release.Name }}-{{ .Release.Revision }}" chaos: "true" spec: containers: - name: python-eh-stress - image: stresstestregistry.azurecr.io/yuling/py-eh-stress:v2 - {{- include "stress-test-addons.container-env" . | nindent 6 }} + image: {{ default "stresstestregistry.azurecr.io/python" .Values.repository }}/stress:{{ default "v2" .Values.tag }} command: ['bash', '-c', 'python3 azure_eventhub_producer_stress.py & python3 azure_eventhub_consumer_stress_sync.py'] + {{- include "stress-test-addons.container-env" . | nindent 6 }} # async test command # command: ['bash', '-c', 'python3 azure_eventhub_producer_stress.py -m stress_send_list_async & python3 azure_eventhub_consumer_stress_async.py'] {{- end -}} From 083b17df2f81d4fec6251cbaa0302042b28a9e2a Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Tue, 21 Sep 2021 17:59:34 -0700 Subject: [PATCH 09/10] minor fixes --- sdk/eventhub/azure-eventhub/stress/Chart.yaml | 4 ++-- .../stress/templates/network_loss.yaml | 14 +++++++------- .../stress/templates/{testjob.yml => testjob.yaml} | 0 3 files changed, 9 insertions(+), 9 deletions(-) rename sdk/eventhub/azure-eventhub/stress/templates/{testjob.yml => testjob.yaml} (100%) diff --git a/sdk/eventhub/azure-eventhub/stress/Chart.yaml b/sdk/eventhub/azure-eventhub/stress/Chart.yaml index 8a638170f88b..0f42b0429a4b 100644 --- a/sdk/eventhub/azure-eventhub/stress/Chart.yaml +++ b/sdk/eventhub/azure-eventhub/stress/Chart.yaml @@ -1,8 +1,8 @@ apiVersion: v2 name: python-eventhubs-stress-test description: python event hubs stress test. -version: 0.1.1 -appVersion: v0.1 +version: 0.1.2 +appVersion: v0.2 annotations: stressTest: 'true' namespace: python-eventhubs-stress-test-ns diff --git a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml index 6f15e1014e8d..958a3555e603 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml +++ b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml @@ -1,14 +1,14 @@ apiVersion: chaos-mesh.org/v1alpha1 kind: NetworkChaos metadata: - name: '{{ $.Release.Name }}-{{ $.Release.Revision }}' - namespace: {{ $.Release.Namespace }} + name: '{{ .Release.Name }}-{{ .Release.Revision }}' + namespace: {{ .Release.Namespace }} annotations: experiment.chaos-mesh.org/pause: 'true' labels: scenario: 'stress' - release: '{{ $.Release.Name }}' - revision: '{{ $.Release.Revision }}' + release: '{{ .Release.Name }}' + revision: '{{ .Release.Revision }}' spec: scheduler: cron: '@every 30s' @@ -16,14 +16,14 @@ spec: action: loss direction: to externalTargets: - - 'eh-stress-{{ .Release.Name }}-{{ .Release.Revision}}.servicebus.windows.net' + - 'servicebus.windows.net' mode: one selector: labelSelectors: - testInstance: "eventhub-{{ .Release.Name }}-{{ .Release.Revision }}" + testInstance: "eventhub-{{ .Release.Name }}-{{ .Release.Revision }}" chaos: 'true' namespaces: - - {{ $.Release.Namespace }} + - {{ .Release.Namespace }} podPhaseSelectors: - 'Running' loss: diff --git a/sdk/eventhub/azure-eventhub/stress/templates/testjob.yml b/sdk/eventhub/azure-eventhub/stress/templates/testjob.yaml similarity index 100% rename from sdk/eventhub/azure-eventhub/stress/templates/testjob.yml rename to sdk/eventhub/azure-eventhub/stress/templates/testjob.yaml From 8af4ce31635220b26f5d9aed911a9d09f4182350 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Wed, 22 Sep 2021 00:56:11 -0700 Subject: [PATCH 10/10] revert external targets --- sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml index 958a3555e603..4811c7a1b1a3 100644 --- a/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml +++ b/sdk/eventhub/azure-eventhub/stress/templates/network_loss.yaml @@ -16,7 +16,7 @@ spec: action: loss direction: to externalTargets: - - 'servicebus.windows.net' + - 'eh-stress-{{ .Release.Name }}-{{ .Release.Revision }}.servicebus.windows.net' mode: one selector: labelSelectors: