diff --git a/README.md b/README.md index 65a09b22..c56dbb81 100644 --- a/README.md +++ b/README.md @@ -1,96 +1,93 @@
- -Ddosify automatically generates Service Map of your K8s cluster without code instrumentation or sidecars. So you can easily find the bottlenecks in your system. Red lines indicate the high latency between services. + +Anteon automatically generates Service Map of your K8s cluster without code instrumentation or sidecars. So you can easily find the bottlenecks in your system. Red lines indicate the high latency between services.
- -Ddosify tracks and displays live data on your cluster instances CPU, memory, disk, and network usage. + +Anteon tracks and displays live data on your cluster instances CPU, memory, disk, and network usage.
### 🔨 Performance Testing -- **Multi-Location Based:** Generate load/performance tests from over 25 countries worldwide. Its available on [Ddosify Cloud](https://app.ddosify.com/). +- **Multi-Location Based:** Generate load/performance tests from over 25 countries worldwide. Its available on [Anteon Cloud](https://app.getanteon.com/). - **Easy Scenario Builder:** Create test scenarios easily without writing any code. - **Seamless Integration with Kubernetes Monitoring:** Performance testing is natively integrated with Kubernetes monitoring for a unified experience. - **Postman Integration:** Import tests directly from Postman, making it convenient for those already using Postman for API development and testing.- -Ddosify Performance Testing generates load from worldwide with no-code scenario builder. + +Anteon Performance Testing generates load from worldwide with no-code scenario builder.
-## Ddosify Stack +## Anteon Stack -Ddosify Stack consists of 4 parts: +Anteon Stack consists of 4 parts: -- [Ddosify Engine](#rocket-ddosify-engine) -- [Ddosify eBPF Agent (Alaz)](#-ddosify-ebpf-agent-alaz) -- [Ddosify Self-Hosted](#-ddosify-self-hosted) -- [Ddosify Cloud](#%EF%B8%8F-ddosify-cloud) +- [Anteon Engine](#anteon-engine) +- [Anteon eBPF Agent (Alaz)](#anteon-ebpf-agent-alaz) +- [Anteon Self-Hosted](#anteon-self-hosted) +- [Anteon Cloud](#anteon-cloud)- +
-### :rocket: Ddosify Engine +### Anteon Engine -[Ddosify Engine](https://github.com/ddosify/ddosify) is the load engine, written in Golang. It's a CLI load-testing tool. Ddosify Self-Hosted and Ddosify Cloud use it under the hood for load generation. It is fully open-source and can be used on the CLI as a standalone tool. It has ~8K Github Stars. Ddosify Engine is available via [Docker](https://hub.docker.com/r/ddosify/ddosify), [Docker Extension](https://hub.docker.com/extensions/ddosify/ddosify-docker-extension), [Homebrew Tap](https://github.com/ddosify/ddosify#homebrew-tap-macos-and-linux), and downloadable pre-compiled binaries from the [releases page](https://github.com/ddosify/ddosify/releases/latest) for macOS, Linux, and Windows. +[Anteon Engine](https://github.com/getanteon/anteon) is the load engine, written in Golang. It's a CLI load-testing tool. Anteon Self-Hosted and Anteon Cloud use it under the hood for load generation. It is fully open-source and can be used on the CLI as a standalone tool. It has ~8K Github Stars. Anteon Engine is available via [Docker](https://hub.docker.com/r/getanteon/anteon), [Docker Extension](https://hub.docker.com/extensions/getanteon/anteon-docker-extension), [Homebrew Tap](https://github.com/getanteon/anteon#homebrew-tap-macos-and-linux), and downloadable pre-compiled binaries from the [releases page](https://github.com/getanteon/anteon/releases/latest) for macOS, Linux, and Windows. -Check out the [Engine Docs](https://github.com/ddosify/ddosify/tree/master/engine_docs) page for more information and usage. +Check out the [Engine Docs](https://github.com/getanteon/anteon/tree/master/engine_docs) page for more information and usage. -### 🐝 Ddosify eBPF Agent (Alaz) -[Alaz](https://github.com/ddosify/alaz) is an open-source Ddosify eBPF agent that can inspect and collect Kubernetes (K8s) service traffic without the need for code instrumentation, sidecars, or service restarts. Alaz is deployed as a DaemonSet on your Kubernetes cluster. It collects metrics and sends them to Ddosify Cloud or Ddosify Self-Hosted. It is also Prometheus compatible, so that you can use it as a standalone tool. +### Anteon eBPF Agent (Alaz) +[Alaz](https://github.com/getanteon/alaz) is an open-source Anteon eBPF agent that can inspect and collect Kubernetes (K8s) service traffic without the need for code instrumentation, sidecars, or service restarts. Alaz is deployed as a DaemonSet on your Kubernetes cluster. It collects metrics and sends them to Anteon Cloud or Anteon Self-Hosted. It is also Prometheus compatible, so that you can use it as a standalone tool. -Check out the [Alaz](https://github.com/ddosify/alaz) repository for more information and usage. +Check out the [Alaz](https://github.com/getanteon/alaz) repository for more information and usage. -### 🏠 Ddosify Self-Hosted +### Anteon Self-Hosted -[Ddosify Self-Hosted](https://github.com/ddosify/ddosify/tree/master/selfhosted) features a web-based user interface, **Performance Testing**, and **Kubernetes Monitoring** capabilities. You can add your servers as Load Engines to the platform for distributed performance testing. While it shares many of the same functionalities as Ddosify Cloud, the Self-Hosted version is designed to be deployed within your infrastructure for enhanced control and customization. +[Anteon Self-Hosted](https://github.com/getanteon/anteon/tree/master/selfhosted) features a web-based user interface, **Performance Testing**, and **Kubernetes Monitoring** capabilities. You can add your servers as Load Engines to the platform for distributed performance testing. While it shares many of the same functionalities as Anteon Cloud, the Self-Hosted version is designed to be deployed within your infrastructure for enhanced control and customization. -It has two versions: Community Edition (CE) and Enterprise Edition (EE). You can see the differences in the below [comparison table](#comparison-of-ddosify-cloud-self-hosted-ee-self-hosted-ce). +It has two versions: Community Edition (CE) and Enterprise Edition (EE). You can see the differences in the below [comparison table](#comparison-of-anteon-cloud-self-hosted-ee-self-hosted-ce). -Check out our [Github Page](https://github.com/ddosify/ddosify/tree/master/selfhosted) for more information and usage. +Check out our [Github Page](https://github.com/getanteon/anteon/tree/master/selfhosted) for more information and usage. #### Quick Start @@ -98,27 +95,27 @@ Check out our [Github Page](https://github.com/ddosify/ddosify/tree/master/selfh (1) Deploy using Docker Compose: ```bash -curl -sSL https://raw.githubusercontent.com/ddosify/ddosify/master/selfhosted/install.sh | bash +curl -sSL https://raw.githubusercontent.com/getanteon/anteon/master/selfhosted/install.sh | bash ``` -(2) You can deploy Ddosify Self Hosted on Kubernetes using the [Helm chart](https://github.com/ddosify/ddosify-helm-charts). +(2) You can deploy Anteon Self Hosted on Kubernetes using the [Helm chart](https://github.com/getanteon/anteon-helm-charts). -### ☁️ Ddosify Cloud +### Anteon Cloud -[Ddosify Cloud](https://app.ddosify.com/) features a SaaS, web-based user interface, multi-location-based **Performance Testing**, and **Kubernetes Monitoring**. Anyone can test the performance of backend endpoints, monitor Kubernetes Clusters, and find the bottlenecks in the system. It has a simple/no code UI, insightful charts, service maps, and more features. +[Anteon Cloud](https://app.getanteon.com/) features a SaaS, web-based user interface, multi-location-based **Performance Testing**, and **Kubernetes Monitoring**. Anyone can test the performance of backend endpoints, monitor Kubernetes Clusters, and find the bottlenecks in the system. It has a simple/no code UI, insightful charts, service maps, and more features. -With Ddosify Cloud, you can generate traffic to your endpoints from 25+ countries without code or scripting. +With Anteon Cloud, you can generate traffic to your endpoints from 25+ countries without code or scripting. -With [Latency Testing](https://docs.ddosify.com/ddosify/latency-testing), you can test the latency of your endpoints from 60+ cities worldwide. +With [Latency Testing](https://getanteon.com/docs/latency-testing), you can test the latency of your endpoints from 60+ cities worldwide. -Check out [Ddosify Cloud](https://app.ddosify.com/) to find the performance issues on your system instantly. +Check out [Anteon Cloud](https://app.getanteon.com/) to find the performance issues on your system instantly. -### Comparison of Ddosify Cloud, Self-Hosted EE, Self-Hosted CE +### Comparison of Anteon Cloud, Self-Hosted EE, Self-Hosted CE- + *CE: Community Edition, EE: Enterprise Edition*
@@ -126,22 +123,22 @@ Check out [Ddosify Cloud](https://app.ddosify.com/) to find the performance issu ## Kubernetes Monitoring Features #### ✅ Service Map -Easily get insights about what is going on in your cluster. You do not have to change your code or add sidecars anymore. More → +Easily get insights about what is going on in your cluster. You do not have to change your code or add sidecars anymore. More →- +
#### ✅ Detailed Insights -Inspect incoming, outgoing traffic, SQL queries, golden signals, HTTP 5xx status codes, Top Latencies and RPS, and more. More → +Inspect incoming, outgoing traffic, SQL queries, golden signals, HTTP 5xx status codes, Top Latencies and RPS, and more. More →- +
#### ✅ Metrics Dashboard -The Metric Dashboard provides a straightforward way to observe Node Metrics. Ddosify observes CPU, Memory, Disk, and Network usage of your nodes. You can also create alerts on these metrics. More → +The Metric Dashboard provides a straightforward way to observe Node Metrics. Anteon observes CPU, Memory, Disk, and Network usage of your nodes. You can also create alerts on these metrics. More →- +
#### ✅ Find Bottlenecks @@ -149,71 +146,71 @@ Start a load test and monitor your system all within the same UI. You do not nee You will see the outgoing requests, response times and status codes on the load test **Summary** tab.- +
You will see the incoming requests to your K8s cluster, service-to-service traffic, RPS, latencies, SQL queries, and more on the **Monitoring** tab. So you can easily correlate the load test results with the monitoring data without switching between different tools.- +
#### ✅ Distributed Tracing -Ddosify automatically collects traces from your Kubernetes cluster and generates context propagation without changing a single line of code. More → +Anteon automatically collects traces from your Kubernetes cluster and generates context propagation without changing a single line of code. More → ## Performance Testing Features #### ✅ Parametrization -Use built-in random data generators. More → +Use built-in random data generators. More →- +
#### ✅ CSV Data Import -Import test data from CSV and use it in the scenario. More → +Import test data from CSV and use it in the scenario. More →- +
#### ✅ Environments -Store constant values as environment variables. More → +Store constant values as environment variables. More →- +
#### ✅ Correlation -Extract variables from earlier phases and pass them on to the following ones. More → +Extract variables from earlier phases and pass them on to the following ones. More →- +
#### ✅ Assertion -Verify that the response matches your expectations. More → +Verify that the response matches your expectations. More →- +
#### ✅ Debugging -Analyze request and response data before starting the load test. More → +Analyze request and response data before starting the load test. More →- +
#### ✅ Postman Import -Import Postman collections with ease and transform them into load testing scenarios. More → +Import Postman collections with ease and transform them into load testing scenarios. More →- +
## About This Repository -This repository includes the source code for the Ddosify Engine. You can access Docker Images for the Ddosify Engine and Self Hosted on Docker Hub. Since Ddosify is a Verified Publisher on Docker Hub, you do not have any pull limits. +This repository includes the source code for the Anteon Engine. You can access Docker Images for the Anteon Engine and Self Hosted on Docker Hub. Since Anteon is a Verified Publisher on Docker Hub, you do not have any pull limits. -The [Engine Docs](https://github.com/ddosify/ddosify/tree/master/engine_docs) folder provides information on the installation, usage, and features of the Ddosify Engine. The [Self-Hosted](https://github.com/ddosify/ddosify/tree/master/selfhosted) folder contains installation instructions for the Self-Hosted version. [Ddosify eBPF agent (Alaz)](https://github.com/ddosify/alaz) has its own repository. +The [Engine Docs](https://github.com/getanteon/anteon/tree/master/engine_docs) folder provides information on the installation, usage, and features of the Anteon Engine. The [Self-Hosted](https://github.com/getanteon/anteon/tree/master/selfhosted) folder contains installation instructions for the Self-Hosted version. [Anteon eBPF agent (Alaz)](https://github.com/getanteon/alaz) has its own repository. -To learn about the **Performance Testing** usage of both Self-Hosted and Cloud versions, please refer to the [this documentation](https://docs.ddosify.com/ddosify/performance-testing/test-suite). For the **Kubernetes Monitoring** usage, please refer to the [this documentation](https://docs.ddosify.com/ddosify/kubernetes-monitoring). +To learn about the **Performance Testing** usage of both Self-Hosted and Cloud versions, please refer to the [this documentation](https://getanteon.com/docs/performance-testing/test-suite). For the **Kubernetes Monitoring** usage, please refer to the [this documentation](https://getanteon.com/docs/kubernetes-monitoring). ## Communication @@ -221,7 +218,7 @@ You can join our [Discord Server](https://discord.gg/9KdnrSUZQg) for issues, fea ## Disclaimer -Ddosify is created for testing the performance of web applications. Users must be the owner of the target system. Using it for harmful purposes is extremely forbidden. Ddosify team & company is not responsible for its’ usages and consequences. +Anteon is created for testing the performance of web applications. Users must be the owner of the target system. Using it for harmful purposes is extremely forbidden. Anteon team & company is not responsible for its’ usages and consequences. ## License diff --git a/assets/anteon-logo-db.svg b/assets/anteon-logo-db.svg new file mode 100644 index 00000000..fa6a167f --- /dev/null +++ b/assets/anteon-logo-db.svg @@ -0,0 +1,36 @@ + + + diff --git a/assets/anteon-logo-wb.svg b/assets/anteon-logo-wb.svg new file mode 100644 index 00000000..e33baede --- /dev/null +++ b/assets/anteon-logo-wb.svg @@ -0,0 +1,36 @@ + + + diff --git a/assets/anteon_comparison.jpg b/assets/anteon_comparison.jpg new file mode 100644 index 00000000..c68bc7b9 Binary files /dev/null and b/assets/anteon_comparison.jpg differ diff --git a/assets/ddosify_load_test.png b/assets/anteon_load_test.png similarity index 100% rename from assets/ddosify_load_test.png rename to assets/anteon_load_test.png diff --git a/assets/ddosify_load_test_monitoring.png b/assets/anteon_load_test_monitoring.png similarity index 100% rename from assets/ddosify_load_test_monitoring.png rename to assets/anteon_load_test_monitoring.png diff --git a/assets/anteon_metrics.png b/assets/anteon_metrics.png new file mode 100644 index 00000000..258a1861 Binary files /dev/null and b/assets/anteon_metrics.png differ diff --git a/assets/ddosify_metrics_detailed.png b/assets/anteon_metrics_detailed.png similarity index 100% rename from assets/ddosify_metrics_detailed.png rename to assets/anteon_metrics_detailed.png diff --git a/assets/anteon_performance_testing.png b/assets/anteon_performance_testing.png new file mode 100644 index 00000000..268914d4 Binary files /dev/null and b/assets/anteon_performance_testing.png differ diff --git a/assets/anteon_service_map.png b/assets/anteon_service_map.png new file mode 100644 index 00000000..8d28e8f5 Binary files /dev/null and b/assets/anteon_service_map.png differ diff --git a/assets/ddosify_service_map_detail.png b/assets/anteon_service_map_detail.png similarity index 100% rename from assets/ddosify_service_map_detail.png rename to assets/anteon_service_map_detail.png diff --git a/assets/anteon_service_map_filtered.png b/assets/anteon_service_map_filtered.png new file mode 100644 index 00000000..b9eccc9b Binary files /dev/null and b/assets/anteon_service_map_filtered.png differ diff --git a/assets/ddosify_service_summary.png b/assets/anteon_service_summary.png similarity index 100% rename from assets/ddosify_service_summary.png rename to assets/anteon_service_summary.png diff --git a/assets/anteon_stack.jpg b/assets/anteon_stack.jpg new file mode 100644 index 00000000..9ff12ebe Binary files /dev/null and b/assets/anteon_stack.jpg differ diff --git a/assets/ddosify-logo-db.svg b/assets/ddosify-logo-db.svg deleted file mode 100644 index 92ea779a..00000000 --- a/assets/ddosify-logo-db.svg +++ /dev/null @@ -1,5119 +0,0 @@ - - - - - - - - - - -]> - diff --git a/assets/ddosify-logo-wb.svg b/assets/ddosify-logo-wb.svg deleted file mode 100644 index cca92df2..00000000 --- a/assets/ddosify-logo-wb.svg +++ /dev/null @@ -1,5120 +0,0 @@ - - - - - - - - - - -]> - diff --git a/assets/ddosify.profile b/assets/ddosify.profile index f23684b4..fe876de1 100644 --- a/assets/ddosify.profile +++ b/assets/ddosify.profile @@ -11,4 +11,4 @@ cat<- +
@@ -45,12 +44,12 @@ ## Installation -`ddosify` is available via [Docker](https://hub.docker.com/r/ddosify/ddosify), [Docker Extension](https://hub.docker.com/extensions/ddosify/ddosify-docker-extension), [Homebrew Tap](#homebrew-tap-macos-and-linux), and downloadable pre-compiled binaries from the [releases page](https://github.com/ddosify/ddosify/releases/latest) for macOS, Linux and Windows. For auto-completion, see: [Ddosify Completions](https://github.com/ddosify/ddosify/blob/master/completions/README.md). +`ddosify` is available via [Docker](https://hub.docker.com/r/anteon/ddosify), [Docker Extension](https://hub.docker.com/extensions/ddosify/ddosify-docker-extension), [Homebrew Tap](#homebrew-tap-macos-and-linux), and downloadable pre-compiled binaries from the [releases page](https://github.com/getanteon/anteon/releases/latest) for macOS, Linux and Windows. For auto-completion, see: [Ddosify Completions](https://github.com/getanteon/anteon/blob/master/completions/README.md). ### Docker ```bash -docker run -it --rm ddosify/ddosify +docker run -it --rm anteon/ddosify ``` ### Docker Extension @@ -97,19 +96,19 @@ pkg install ddosify - Run ddosify: ```bash -.\ddosify.exe -t http://target_site.com +.\ddosify.exe -t https://getanteon.com ``` ### Using the convenience script (macOS and Linux) - The script requires root or sudo privileges to move ddosify binary to `/usr/local/bin`. -- The script attempts to detect your operating system (macOS or Linux) and architecture (arm64, x86, amd64) to download the appropriate binary from the [releases page](https://github.com/ddosify/ddosify/releases/latest). +- The script attempts to detect your operating system (macOS or Linux) and architecture (arm64, x86, amd64) to download the appropriate binary from the [releases page](https://github.com/getanteon/anteon/releases/latest). - By default, the script installs the latest version of `ddosify`. - If you have problems, check [common issues](#common-issues) - Required packages: `curl` and `sudo` ```bash -curl -sSfL https://raw.githubusercontent.com/ddosify/ddosify/master/scripts/install.sh | sh +curl -sSfL https://raw.githubusercontent.com/getanteon/anteon/master/scripts/install.sh | sh ``` ### Go install from source (macOS, FreeBSD, Linux, Windows) @@ -124,42 +123,45 @@ go install -v go.ddosify.com/ddosify@latest This section aims to show you how to use Ddosify without deep dive into its details easily. 1. ### Simple load test - - ddosify -t http://target_site.com + `ddosify -t https://getanteon.com` The above command runs a load test with the default value that is 100 requests in 10 seconds. 2. ### Using some of the features - ddosify -t http://target_site.com -n 1000 -d 20 -m PUT -T 7 -P http://proxy_server.com:80 + `ddosify -t https://getanteon.com -n 1000 -d 20 -m PUT -T 7 -P http://proxy_server.com:80` - Ddosify sends a total of *1000* *PUT* requests to *https://target_site.com* over proxy *http://proxy_server.com:80* in *20* seconds with a timeout of *7* seconds per request. + Ddosify sends a total of *1000* *PUT* requests to *https://getanteon.com* over proxy *http://proxy_server.com:80* in *20* seconds with a timeout of *7* seconds per request. 3. ### Usage for CI/CD pipelines (JSON output) - ddosify -t http://target_site.com -o stdout-json | jq .avg_duration + `ddosify -t https://getanteon.com -o stdout-json | jq .avg_duration` Ddosify outputs the result in JSON format. Then `jq` (or any other command-line JSON processor) fetches the `avg_duration`. The rest depends on your CI/CD flow logic. 4. ### Scenario based load test - ddosify -config config_examples/config.json - Ddosify first sends *HTTP/2 POST* request to *https://test_site1.com/endpoint_1* using basic auth credentials *test_user:12345* over proxy *http://proxy_host.com:proxy_port* and with a timeout of *3* seconds. Once the response is received, HTTPS GET request will be sent to *https://test_site1.com/endpoint_2* along with the payload included in *config_examples/payload.txt* file with a timeout of 2 seconds. This flow will be repeated *20* times in *5* seconds and response will be written to *stdout*. + `ddosify -config config_examples/config.json` + + Ddosify first sends *HTTP/2 POST* request to *https://getanteon.com/endpoint_1* using basic auth credentials *test_user:12345* over proxy *http://proxy_host.com:proxy_port* and with a timeout of *3* seconds. Once the response is received, HTTPS GET request will be sent to *https://getanteon.com/endpoint_2* along with the payload included in *config_examples/payload.txt* file with a timeout of 2 seconds. This flow will be repeated *20* times in *5* seconds and response will be written to *stdout*. 5. ### Load test with Dynamic Variables (Parameterization) - ddosify -t http://target_site.com/{{_randomInt}} -d 10 -n 100 -h 'User-Agent: {{_randomUserAgent}}' -b '{"city": "{{_randomCity}}"}' - Ddosify sends a total of *100* *GET* requests to *https://target_site.com/{{_randomInt}}* in *10* seconds. `{{_randomInt}}` path generates random integers between 1 and 1000 in every request. Dynamic variables can be used in *URL*, *headers*, *payload (body)* and *basic authentication*. In this example, Ddosify generates a random user agent in the header and a random city in the body. The full list of the dynamic variables can be found in the [docs](https://docs.ddosify.com/extra/dynamic-variables-parameterization). + `ddosify -t https://getanteon.com/{{_randomInt}} -d 10 -n 100 -h 'User-Agent: {{_randomUserAgent}}' -b '{"city": "{{_randomCity}}"}'` + + Ddosify sends a total of *100* *GET* requests to *https://getanteon.com/{{_randomInt}}* in *10* seconds. `{{_randomInt}}` path generates random integers between 1 and 1000 in every request. Dynamic variables can be used in *URL*, *headers*, *payload (body)* and *basic authentication*. In this example, Ddosify generates a random user agent in the header and a random city in the body. The full list of the dynamic variables can be found in the [docs](https://getanteon.com/docs/performance-testing/dynamic-variables-parametrization). 6. ### Correlation (Captured Variables) - ddosify -config ddosify_config_correlation.json - Ddosify allows you to specify variables at the global level and use them throughout the scenario, as well as extract variables from previous steps and inject them to the next steps in each iteration individually. You can inject those variables in requests *url*, *headers* and *payload(body)*. The example config can be found in [correlation-config-example](#Correlation). + `ddosify -config ddosify_config_correlation.json` + + Ddosify allows you to specify variables at the global level and use them throughout the scenario, as well as extract variables from previous steps and inject them to the next steps in each iteration individually. You can inject those variables in requests *url*, *headers* and *payload(body)*. The example config can be found in [correlation-config-example](#Correlation). 7. ### Test Data - ddosify -config ddosify_data_csv.json - Ddosify allows you to load test data from a file, tag specific columns for later use. You can inject those variables in requests *url*, *headers* and *payload(body)*. The example config can be found in [test-data-example](#test-data-set). + `ddosify -config ddosify_data_csv.json` + + Ddosify allows you to load test data from a file, tag specific columns for later use. You can inject those variables in requests *url*, *headers* and *payload(body)*. The example config can be found in [test-data-example](#test-data-set). ## Details You can configure your load test by the CLI options or a config file. Config file supports more features than the CLI. For example, you can't create a scenario-based load test with CLI options. @@ -171,7 +173,7 @@ ddosify [FLAG] | Flag | Description | Type | Default | Required? | | ------ | -------------------------------------------------------- | ------ | ------- | --------- | -| `-t` | Target website URL. Example: https://ddosify.com | `string` | - | Yes | +| `-t` | Target website URL. Example: https://getanteon.com | `string` | - | Yes | | `-n` | Total iteration count | `int` | `100` | No | | `-d` | Test duration in seconds. | `int` | `10` | No | | `-m` | Request method. Available methods for HTTP(s) are *GET, POST, PUT, DELETE, HEAD, PATCH, OPTIONS* | `string` | `GET` | No | @@ -193,35 +195,35 @@ ddosify [FLAG] #### Linear ```bash -ddosify -t http://target_site.com -l linear +ddosify -t https://getanteon.com -l linear ``` Result: -![linear load](https://raw.githubusercontent.com/ddosify/ddosify/master/assets/linear.gif) +![linear load](https://raw.githubusercontent.com/getanteon/anteon/master/assets/linear.gif) *Note:* If the iteration count is too low for the given duration, the test might be finished earlier than you expect. #### Incremental ```bash -ddosify -t http://target_site.com -l incremental +ddosify -t https://getanteon.com -l incremental ``` Result: -![incremental load](https://raw.githubusercontent.com/ddosify/ddosify/master/assets/incremental.gif) +![incremental load](https://raw.githubusercontent.com/getanteon/anteon/master/assets/incremental.gif) #### Waved ```bash -ddosify -t http://target_site.com -l waved +ddosify -t https://getanteon.com -l waved ``` Result: -![waved load](https://raw.githubusercontent.com/ddosify/ddosify/master/assets/waved.gif) +![waved load](https://raw.githubusercontent.com/getanteon/anteon/master/assets/waved.gif) ### Config File @@ -297,7 +299,7 @@ There is an example config file at [config_examples/config.json](/config_example - `data` *optional* Config for loading test data from a CSV file. - [CSV data](https://github.com/ddosify/ddosify/tree/master/config/config_testdata/test.csv) used in below config. + [CSV data](https://github.com/getanteon/anteon/tree/master/config/config_testdata/test.csv) used in below config. ```json "data":{ "info": { @@ -453,7 +455,7 @@ There is an example config file at [config_examples/config.json](/config_example }, { "name": "[field-name]", - "value": "http://test.com/test.png", + "value": "http://getanteon.com/test.png", "type": "file", "src": "remote" } @@ -474,7 +476,7 @@ There is an example config file at [config_examples/config.json](/config_example "steps": [ { "id": 1, - "url": "http://target.com/endpoint1", + "url": "http://getanteon.com/endpoint1", "capture_env": { "NUM" :{"from":"body","json_path":"num"}, } @@ -489,7 +491,7 @@ There is an example config file at [config_examples/config.json](/config_example "steps": [ { "id": 1, - "url": "http://target.com/endpoint1", + "url": "http://getanteon.com/endpoint1", "assertion": [ "equals(status_code,200)", "in(headers.content-length,[2000,3000])" @@ -507,12 +509,12 @@ There is an example config file at [config_examples/config.json](/config_example "steps": [ { "id": 1, - "url": "http://target.com/endpoint1", + "url": "http://getanteon.com/endpoint1", "sleep": "1000" }, { "id": 2, - "url": "http://target.com/endpoint2", + "url": "http://getanteon.com/endpoint2", } ] ``` @@ -522,12 +524,12 @@ There is an example config file at [config_examples/config.json](/config_example "steps": [ { "id": 1, - "url": "http://target.com/endpoint1", + "url": "http://getanteon.com/endpoint1", "sleep": "300-500" }, { "id": 2, - "url": "http://target.com/endpoint2", + "url": "http://getanteon.com/endpoint2", } ] ``` @@ -557,14 +559,14 @@ There is an example config file at [config_examples/config.json](/config_example Just like the Postman, Ddosify supports parameterization (dynamic variables) on *URL*, *headers*, *payload (body)* and *basic authentication*. Actually, we support all the random methods Postman supports. If you use `{{$randomVariable}}` on Postman you can use it as `{{_randomVariable}}` on Ddosify. Just change `$` to `_` and you will be fine. To simulate a realistic load test on your system, Ddosify can send every request with dynamic variables. -The full list of dynamic variables can be found in the [Ddosify Docs](https://docs.ddosify.com/extra/dynamic-variables-parameterization). +The full list of dynamic variables can be found in the [Ddosify Docs](https://getanteon.com/docs/performance-testing/dynamic-variables-parametrization). ### Parameterization on URL Ddosify sends *100* GET requests in *10* seconds with random string `key` parameter. This approach can be also used in cache bypass. ```bash -ddosify -t http://target_site.com/?key={{_randomString}} -d 10 -n 100 +ddosify -t https://getanteon.com/?key={{_randomString}} -d 10 -n 100 ``` ### Parameterization on Headers @@ -572,7 +574,7 @@ ddosify -t http://target_site.com/?key={{_randomString}} -d 10 -n 100 Ddosify sends *100* GET requests in *10* seconds with random `Transaction-Type` and `Country` headers. ```bash -ddosify -t http://target_site.com -d 10 -n 100 -h 'Transaction-Type: {{_randomTransactionType}}' -h 'Country: {{_randomCountry}}' +ddosify -t https://getanteon.com -d 10 -n 100 -h 'Transaction-Type: {{_randomTransactionType}}' -h 'Country: {{_randomCountry}}' ``` ### Parameterization on Payload (Body) @@ -580,7 +582,7 @@ ddosify -t http://target_site.com -d 10 -n 100 -h 'Transaction-Type: {{_randomTr Ddosify sends *100* GET requests in *10* seconds with random `latitude` and `longitude` values in body. ```bash -ddosify -t http://target_site.com -d 10 -n 100 -b '{"latitude": "{{_randomLatitude}}", "longitude": "{{_randomLongitude}}"}' +ddosify -t https://getanteon.com -d 10 -n 100 -b '{"latitude": "{{_randomLatitude}}", "longitude": "{{_randomLongitude}}"}' ``` ### Parameterization on Basic Authentication @@ -588,7 +590,7 @@ ddosify -t http://target_site.com -d 10 -n 100 -b '{"latitude": "{{_randomLatitu Ddosify sends *100* GET requests in *10* seconds with random `username` and `password` with basic authentication. ```bash -ddosify -t http://target_site.com -d 10 -n 100 -a '{{_randomUserName}}:{{_randomPassword}}' +ddosify -t https://getanteon.com -d 10 -n 100 -a '{{_randomUserName}}:{{_randomPassword}}' ``` ### Parameterization on Config File @@ -607,7 +609,7 @@ ddosify -config ddosify_config_dynamic.json "steps": [ { "id": 1, - "url": "https://test_site1.com/?key={{_randomString}}", + "url": "https://getanteon.com/?key={{_randomString}}", "method": "POST", "headers": { "User-Key": "{{_randomInt}}" @@ -622,7 +624,7 @@ ddosify -config ddosify_config_dynamic.json In addition, you can also use operating system environment variables. To access these variables, simply add the `$` prefix followed by the variable name wrapped in double curly braces. The syntax for this is `{{$OS_ENV_VARIABLE}}` within the **config file**. For instance, to use the `USER` environment variable from your operating system, simply input `{{$USER}}`. You can use operating system environment variables in `URL`, `Headers`, `Body (Payload)`, and `Basic Authentication`. Here is an example of using operating system environment variables in the config file. `TARGET_SITE` operating system environment variable is used in `URL` and `USER` environment variable is used in `Headers`. ```bash -export TARGET_SITE="https://test_site1.com" +export TARGET_SITE="https://getanteon.com" ddosify -config ddosify_config_os_env.json ``` @@ -648,7 +650,7 @@ ddosify -config ddosify_config_os_env.json At default, Ddosify marks the step result as successful if it sends the request and receives the response without any network error happening. Status code or body type (or content) does not have any effect on success/failure criteria. But this may not be a good test result for your use case and you may want to create your success/fail logic. That's where you can use Assertions. -Ddosify supports assertion on `status code`, `response body`, `response size`, `response time`, `headers`, and `variables`. You can use the `assertion` parameter on the config file to check if the response matches the given condition per step. If the condition is not met, Ddosify will fail the step. Check the [example config](https://github.com/ddosify/ddosify/blob/master/config_examples/config.json) to see how it looks. +Ddosify supports assertion on `status code`, `response body`, `response size`, `response time`, `headers`, and `variables`. You can use the `assertion` parameter on the config file to check if the response matches the given condition per step. If the condition is not met, Ddosify will fail the step. Check the [example config](https://github.com/getanteon/anteon/blob/master/ddosify_engine/config_examples/config.json) to see how it looks. As shown in the related table the first 5 keywords store different data related to the response. The last keyword `variables` stores the current state of environment variables for the Step. You can use [Functions](#functions) or [Operators](#operators) to build conditional expressions based on these keywords. @@ -723,11 +725,11 @@ If Ddosify can't receive the response for a request, that step is marked as Fail Ddosify supports success criteria, allowing users to verify the success of their load tests based on response times and failure counts of iterations. With this feature, users can assert the percentile of response times and the failure counts of all the iterations in a test. -Users can specify the required percentile of response times and failure counts in the configuration file, and the engine will compare the actual response times and failure counts to these values throughout the test continuously. According to users configuration test can be aborted or continue running until end. Check the [example config](https://github.com/ddosify/ddosify/blob/master/config_examples/config.json) to see how it looks the `success_criterias` keyword. +Users can specify the required percentile of response times and failure counts in the configuration file, and the engine will compare the actual response times and failure counts to these values throughout the test continuously. According to users configuration test can be aborted or continue running until end. Check the [example config](https://github.com/getanteon/anteon/blob/master/config_examples/config.json) to see how it looks the `success_criterias` keyword. Note that the functions and operators mentioned in the [Step Assertion](#assertion) section can also be utilized for the Success Criteria keywords listed below. -You can see an success criteria example in [EXAMPLES](https://github.com/ddosify/ddosify/blob/master/engine_docs/EXAMPLES.md#example-2-success-criteria) file. +You can see an success criteria example in [EXAMPLES](https://github.com/getanteon/anteon/blob/master/engine_docs/EXAMPLES.md#example-2-success-criteria) file. ## Difference Between Success Criteria and Step Assertions @@ -936,7 +938,7 @@ On array-like captured variables or environment vars, the **rand( )** function c ## Test Data Set Ddosify enables you to load test data from **CSV** files. Later, in your scenario, you can inject variables that you tagged. -We are using this [CSV data](https://github.com/ddosify/ddosify/tree/master/config/config_testdata/test.csv) in below config. +We are using this [CSV data](https://github.com/getanteon/anteon/tree/master/config/config_testdata/test.csv) in below config. ```json @@ -980,18 +982,18 @@ In `repeated-user` mode Ddosify uses the same cookie jar for all iterations exec In `distinct-user` mode Ddosify uses a different cookie jar for each iteration, cookies passed through steps in one iteration only. -You can see an cookie example in [EXAMPLES](https://github.com/ddosify/ddosify/blob/master/engine_docs/EXAMPLES.md#example-1-cookie-support) file. +You can see an cookie example in [EXAMPLES](https://github.com/getanteon/anteon/blob/master/engine_docs/EXAMPLES.md#example-1-cookie-support) file. ### Initial / Custom Cookies -You can set initial/custom cookies for your test scenario using `cookie_jar` field in the config file. You can enable/disable custom cookies with `enabled` key. Check the [example config](https://github.com/ddosify/ddosify/tree/master/config/config_testdata/config_init_cookies.json). +You can set initial/custom cookies for your test scenario using `cookie_jar` field in the config file. You can enable/disable custom cookies with `enabled` key. Check the [example config](https://github.com/getanteon/anteon/tree/master/config/config_testdata/config_init_cookies.json). | Key | Description | Example | |-----------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------| | `name` | The name of the cookie. This field is used to identify the cookie. | `platform` | | `value` | The value of the cookie. This field contains the data that the cookie stores. | `web` | -| `domain` | Domain or subdomain that can access the cookie. | `httpbin.ddosify.com` | +| `domain` | Domain or subdomain that can access the cookie. | `app.getanteon.com` | | `path` | Path within the domain that can access the cookie. | `/` | | `expires` | When the cookie should expire. The date format should be rfc2616. | `Thu, 16 Mar 2023 09:24:02 GMT` | | `max_age` | Number of seconds until the cookie expires. | `5` | @@ -1041,8 +1043,8 @@ Following fields are available for cookie assertion: ## Tutorials / Blog Posts -* [Testing the Performance of User Authentication Flow](https://ddosify.com/blog/testing-the-performance-of-user-authentication-flow#introduction) -* [Load Testing a Fintech API with CSV Test Data Import](https://ddosify.com/blog/load-testing-a-fintech-exchange-api-with-csv-test-data-import) +* [Testing the Performance of User Authentication Flow](https://getanteon.com/blog/testing-the-performance-of-user-authentication-flow) +* [Load Testing a Fintech API with CSV Test Data Import](https://getanteon.com/blog/load-testing-a-fintech-exchange-api-with-csv-test-data-import) ## Common Issues @@ -1063,8 +1065,8 @@ If you create large load tests, you may encounter the following errors: ``` Server Error Distribution (Count:Reason): - 199 :Get "https://example.ddosify.com": dial tcp 188.114.96.3:443: socket: too many open files - 159 :Get "https://example.ddosify.com": dial tcp 188.114.97.3:443: socket: too many open files + 199 :Get "https://getanteon.com": dial tcp 188.114.96.3:443: socket: too many open files + 159 :Get "https://getanteon.com": dial tcp 188.114.97.3:443: socket: too many open files ``` This is because the OS limits the number of open files. You can check the current limit by running `ulimit -n` command. You can increase this limit to 50000 by running the following command on both Linux and macOS. @@ -1089,7 +1091,7 @@ You can join our [Discord Server](https://discord.gg/9KdnrSUZQg) for issues, fea ## More -This repository includes the single-node version of the Ddosify Loader. For distributed and Geo-targeted Load Testing you can use [Ddosify Cloud](https://ddosify.com) +This repository includes the single-node version of the Ddosify Loader. For distributed and Geo-targeted Load Testing you can use [Anteon Cloud](https://getanteon.com) ## Disclaimer diff --git a/completions/README.md b/ddosify_engine/completions/README.md similarity index 100% rename from completions/README.md rename to ddosify_engine/completions/README.md diff --git a/completions/_ddosify b/ddosify_engine/completions/_ddosify similarity index 100% rename from completions/_ddosify rename to ddosify_engine/completions/_ddosify diff --git a/config/base.go b/ddosify_engine/config/base.go similarity index 100% rename from config/base.go rename to ddosify_engine/config/base.go diff --git a/config/base_test.go b/ddosify_engine/config/base_test.go similarity index 100% rename from config/base_test.go rename to ddosify_engine/config/base_test.go diff --git a/config/config_testdata/benchmark/config_correlation_load_1.json b/ddosify_engine/config/config_testdata/benchmark/config_correlation_load_1.json similarity index 100% rename from config/config_testdata/benchmark/config_correlation_load_1.json rename to ddosify_engine/config/config_testdata/benchmark/config_correlation_load_1.json diff --git a/config/config_testdata/benchmark/config_correlation_load_2.json b/ddosify_engine/config/config_testdata/benchmark/config_correlation_load_2.json similarity index 100% rename from config/config_testdata/benchmark/config_correlation_load_2.json rename to ddosify_engine/config/config_testdata/benchmark/config_correlation_load_2.json diff --git a/config/config_testdata/benchmark/config_correlation_load_3.json b/ddosify_engine/config/config_testdata/benchmark/config_correlation_load_3.json similarity index 100% rename from config/config_testdata/benchmark/config_correlation_load_3.json rename to ddosify_engine/config/config_testdata/benchmark/config_correlation_load_3.json diff --git a/config/config_testdata/benchmark/config_correlation_load_4.json b/ddosify_engine/config/config_testdata/benchmark/config_correlation_load_4.json similarity index 100% rename from config/config_testdata/benchmark/config_correlation_load_4.json rename to ddosify_engine/config/config_testdata/benchmark/config_correlation_load_4.json diff --git a/config/config_testdata/benchmark/config_correlation_load_5.json b/ddosify_engine/config/config_testdata/benchmark/config_correlation_load_5.json similarity index 100% rename from config/config_testdata/benchmark/config_correlation_load_5.json rename to ddosify_engine/config/config_testdata/benchmark/config_correlation_load_5.json diff --git a/config/config_testdata/benchmark/config_distinct_user.json b/ddosify_engine/config/config_testdata/benchmark/config_distinct_user.json similarity index 100% rename from config/config_testdata/benchmark/config_distinct_user.json rename to ddosify_engine/config/config_testdata/benchmark/config_distinct_user.json diff --git a/config/config_testdata/benchmark/config_multipart_inject_100rps.json b/ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_100rps.json similarity index 100% rename from config/config_testdata/benchmark/config_multipart_inject_100rps.json rename to ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_100rps.json diff --git a/config/config_testdata/benchmark/config_multipart_inject_10rps.json b/ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_10rps.json similarity index 100% rename from config/config_testdata/benchmark/config_multipart_inject_10rps.json rename to ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_10rps.json diff --git a/config/config_testdata/benchmark/config_multipart_inject_1krps.json b/ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_1krps.json similarity index 100% rename from config/config_testdata/benchmark/config_multipart_inject_1krps.json rename to ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_1krps.json diff --git a/config/config_testdata/benchmark/config_multipart_inject_200rps.json b/ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_200rps.json similarity index 100% rename from config/config_testdata/benchmark/config_multipart_inject_200rps.json rename to ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_200rps.json diff --git a/config/config_testdata/benchmark/config_multipart_inject_2krps.json b/ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_2krps.json similarity index 100% rename from config/config_testdata/benchmark/config_multipart_inject_2krps.json rename to ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_2krps.json diff --git a/config/config_testdata/benchmark/config_multipart_inject_500rps.json b/ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_500rps.json similarity index 100% rename from config/config_testdata/benchmark/config_multipart_inject_500rps.json rename to ddosify_engine/config/config_testdata/benchmark/config_multipart_inject_500rps.json diff --git a/config/config_testdata/benchmark/config_repeated_user.json b/ddosify_engine/config/config_testdata/benchmark/config_repeated_user.json similarity index 100% rename from config/config_testdata/benchmark/config_repeated_user.json rename to ddosify_engine/config/config_testdata/benchmark/config_repeated_user.json diff --git a/config/config_testdata/benchmark/json_payload.json b/ddosify_engine/config/config_testdata/benchmark/json_payload.json similarity index 100% rename from config/config_testdata/benchmark/json_payload.json rename to ddosify_engine/config/config_testdata/benchmark/json_payload.json diff --git a/config/config_testdata/config.json b/ddosify_engine/config/config_testdata/config.json similarity index 100% rename from config/config_testdata/config.json rename to ddosify_engine/config/config_testdata/config.json diff --git a/config/config_testdata/config_auth.json b/ddosify_engine/config/config_testdata/config_auth.json similarity index 100% rename from config/config_testdata/config_auth.json rename to ddosify_engine/config/config_testdata/config_auth.json diff --git a/config/config_testdata/config_capture_environment.json b/ddosify_engine/config/config_testdata/config_capture_environment.json similarity index 100% rename from config/config_testdata/config_capture_environment.json rename to ddosify_engine/config/config_testdata/config_capture_environment.json diff --git a/config/config_testdata/config_data_csv.json b/ddosify_engine/config/config_testdata/config_data_csv.json similarity index 100% rename from config/config_testdata/config_data_csv.json rename to ddosify_engine/config/config_testdata/config_data_csv.json diff --git a/config/config_testdata/config_debug_false.json b/ddosify_engine/config/config_testdata/config_debug_false.json similarity index 100% rename from config/config_testdata/config_debug_false.json rename to ddosify_engine/config/config_testdata/config_debug_false.json diff --git a/config/config_testdata/config_debug_mode.json b/ddosify_engine/config/config_testdata/config_debug_mode.json similarity index 100% rename from config/config_testdata/config_debug_mode.json rename to ddosify_engine/config/config_testdata/config_debug_mode.json diff --git a/config/config_testdata/config_empty.json b/ddosify_engine/config/config_testdata/config_empty.json similarity index 100% rename from config/config_testdata/config_empty.json rename to ddosify_engine/config/config_testdata/config_empty.json diff --git a/config/config_testdata/config_global_envs.json b/ddosify_engine/config/config_testdata/config_global_envs.json similarity index 100% rename from config/config_testdata/config_global_envs.json rename to ddosify_engine/config/config_testdata/config_global_envs.json diff --git a/config/config_testdata/config_incorrect.json b/ddosify_engine/config/config_testdata/config_incorrect.json similarity index 100% rename from config/config_testdata/config_incorrect.json rename to ddosify_engine/config/config_testdata/config_incorrect.json diff --git a/config/config_testdata/config_init_cookies.json b/ddosify_engine/config/config_testdata/config_init_cookies.json similarity index 100% rename from config/config_testdata/config_init_cookies.json rename to ddosify_engine/config/config_testdata/config_init_cookies.json diff --git a/config/config_testdata/config_inject_json.json b/ddosify_engine/config/config_testdata/config_inject_json.json similarity index 100% rename from config/config_testdata/config_inject_json.json rename to ddosify_engine/config/config_testdata/config_inject_json.json diff --git a/config/config_testdata/config_inject_json_dynamic.json b/ddosify_engine/config/config_testdata/config_inject_json_dynamic.json similarity index 100% rename from config/config_testdata/config_inject_json_dynamic.json rename to ddosify_engine/config/config_testdata/config_inject_json_dynamic.json diff --git a/config/config_testdata/config_inject_xml.json b/ddosify_engine/config/config_testdata/config_inject_xml.json similarity index 100% rename from config/config_testdata/config_inject_xml.json rename to ddosify_engine/config/config_testdata/config_inject_xml.json diff --git a/config/config_testdata/config_invalid_capture_env.json b/ddosify_engine/config/config_testdata/config_invalid_capture_env.json similarity index 100% rename from config/config_testdata/config_invalid_capture_env.json rename to ddosify_engine/config/config_testdata/config_invalid_capture_env.json diff --git a/config/config_testdata/config_invalid_target.json b/ddosify_engine/config/config_testdata/config_invalid_target.json similarity index 100% rename from config/config_testdata/config_invalid_target.json rename to ddosify_engine/config/config_testdata/config_invalid_target.json diff --git a/config/config_testdata/config_invalid_user_mode_for_cookies.json b/ddosify_engine/config/config_testdata/config_invalid_user_mode_for_cookies.json similarity index 100% rename from config/config_testdata/config_invalid_user_mode_for_cookies.json rename to ddosify_engine/config/config_testdata/config_invalid_user_mode_for_cookies.json diff --git a/config/config_testdata/config_iteration_count.json b/ddosify_engine/config/config_testdata/config_iteration_count.json similarity index 100% rename from config/config_testdata/config_iteration_count.json rename to ddosify_engine/config/config_testdata/config_iteration_count.json diff --git a/config/config_testdata/config_iteration_count_over_req_count.json b/ddosify_engine/config/config_testdata/config_iteration_count_over_req_count.json similarity index 100% rename from config/config_testdata/config_iteration_count_over_req_count.json rename to ddosify_engine/config/config_testdata/config_iteration_count_over_req_count.json diff --git a/config/config_testdata/config_manual_load.json b/ddosify_engine/config/config_testdata/config_manual_load.json similarity index 100% rename from config/config_testdata/config_manual_load.json rename to ddosify_engine/config/config_testdata/config_manual_load.json diff --git a/config/config_testdata/config_manual_load_override.json b/ddosify_engine/config/config_testdata/config_manual_load_override.json similarity index 100% rename from config/config_testdata/config_manual_load_override.json rename to ddosify_engine/config/config_testdata/config_manual_load_override.json diff --git a/config/config_testdata/config_multipart_err.json b/ddosify_engine/config/config_testdata/config_multipart_err.json similarity index 100% rename from config/config_testdata/config_multipart_err.json rename to ddosify_engine/config/config_testdata/config_multipart_err.json diff --git a/config/config_testdata/config_multipart_payload.json b/ddosify_engine/config/config_testdata/config_multipart_payload.json similarity index 100% rename from config/config_testdata/config_multipart_payload.json rename to ddosify_engine/config/config_testdata/config_multipart_payload.json diff --git a/config/config_testdata/config_payload.json b/ddosify_engine/config/config_testdata/config_payload.json similarity index 100% rename from config/config_testdata/config_payload.json rename to ddosify_engine/config/config_testdata/config_payload.json diff --git a/config/config_testdata/config_protocol.json b/ddosify_engine/config/config_testdata/config_protocol.json similarity index 100% rename from config/config_testdata/config_protocol.json rename to ddosify_engine/config/config_testdata/config_protocol.json diff --git a/config/config_testdata/config_test_assertion_fail.json b/ddosify_engine/config/config_testdata/config_test_assertion_fail.json similarity index 100% rename from config/config_testdata/config_test_assertion_fail.json rename to ddosify_engine/config/config_testdata/config_test_assertion_fail.json diff --git a/config/config_testdata/data_json_payload.json b/ddosify_engine/config/config_testdata/data_json_payload.json similarity index 100% rename from config/config_testdata/data_json_payload.json rename to ddosify_engine/config/config_testdata/data_json_payload.json diff --git a/config/config_testdata/json_payload.json b/ddosify_engine/config/config_testdata/json_payload.json similarity index 100% rename from config/config_testdata/json_payload.json rename to ddosify_engine/config/config_testdata/json_payload.json diff --git a/config/config_testdata/json_payload_dynamic.json b/ddosify_engine/config/config_testdata/json_payload_dynamic.json similarity index 100% rename from config/config_testdata/json_payload_dynamic.json rename to ddosify_engine/config/config_testdata/json_payload_dynamic.json diff --git a/config/config_testdata/payload.txt b/ddosify_engine/config/config_testdata/payload.txt similarity index 100% rename from config/config_testdata/payload.txt rename to ddosify_engine/config/config_testdata/payload.txt diff --git a/config/config_testdata/race_configs/capture_envs.json b/ddosify_engine/config/config_testdata/race_configs/capture_envs.json similarity index 100% rename from config/config_testdata/race_configs/capture_envs.json rename to ddosify_engine/config/config_testdata/race_configs/capture_envs.json diff --git a/config/config_testdata/race_configs/global_envs.json b/ddosify_engine/config/config_testdata/race_configs/global_envs.json similarity index 100% rename from config/config_testdata/race_configs/global_envs.json rename to ddosify_engine/config/config_testdata/race_configs/global_envs.json diff --git a/config/config_testdata/race_configs/step_assertions_stdout.json b/ddosify_engine/config/config_testdata/race_configs/step_assertions_stdout.json similarity index 100% rename from config/config_testdata/race_configs/step_assertions_stdout.json rename to ddosify_engine/config/config_testdata/race_configs/step_assertions_stdout.json diff --git a/config/config_testdata/race_configs/step_assertions_stdout_json.json b/ddosify_engine/config/config_testdata/race_configs/step_assertions_stdout_json.json similarity index 100% rename from config/config_testdata/race_configs/step_assertions_stdout_json.json rename to ddosify_engine/config/config_testdata/race_configs/step_assertions_stdout_json.json diff --git a/config/config_testdata/test.csv b/ddosify_engine/config/config_testdata/test.csv similarity index 100% rename from config/config_testdata/test.csv rename to ddosify_engine/config/config_testdata/test.csv diff --git a/config/config_testdata/test_img.svg b/ddosify_engine/config/config_testdata/test_img.svg similarity index 100% rename from config/config_testdata/test_img.svg rename to ddosify_engine/config/config_testdata/test_img.svg diff --git a/config/config_testdata/xml_payload.xml b/ddosify_engine/config/config_testdata/xml_payload.xml similarity index 100% rename from config/config_testdata/xml_payload.xml rename to ddosify_engine/config/config_testdata/xml_payload.xml diff --git a/config/json.go b/ddosify_engine/config/json.go similarity index 100% rename from config/json.go rename to ddosify_engine/config/json.go diff --git a/config/json_test.go b/ddosify_engine/config/json_test.go similarity index 100% rename from config/json_test.go rename to ddosify_engine/config/json_test.go diff --git a/config_examples/assertion/expected_body.json b/ddosify_engine/config_examples/assertion/expected_body.json similarity index 100% rename from config_examples/assertion/expected_body.json rename to ddosify_engine/config_examples/assertion/expected_body.json diff --git a/config_examples/config.json b/ddosify_engine/config_examples/config.json similarity index 97% rename from config_examples/config.json rename to ddosify_engine/config_examples/config.json index e7ce59c5..59a1bc2d 100644 --- a/config_examples/config.json +++ b/ddosify_engine/config_examples/config.json @@ -57,7 +57,7 @@ "steps": [ { "id": 1, - "url": "https://test_site1.com/endpoint_1", + "url": "https://getanteon.com/endpoint_1", "method": "POST", "headers": { "Content-Type": "application/xml", @@ -102,7 +102,7 @@ }, { "id": 3, - "url": "https://test_site1.com/endpoint_3", + "url": "https://getanteon.com/endpoint_3", "method": "POST", "payload_multipart": [ { diff --git a/config_examples/payload.txt b/ddosify_engine/config_examples/payload.txt similarity index 100% rename from config_examples/payload.txt rename to ddosify_engine/config_examples/payload.txt diff --git a/core/assertion/base.go b/ddosify_engine/core/assertion/base.go similarity index 100% rename from core/assertion/base.go rename to ddosify_engine/core/assertion/base.go diff --git a/core/assertion/service.go b/ddosify_engine/core/assertion/service.go similarity index 100% rename from core/assertion/service.go rename to ddosify_engine/core/assertion/service.go diff --git a/core/assertion/service_test.go b/ddosify_engine/core/assertion/service_test.go similarity index 100% rename from core/assertion/service_test.go rename to ddosify_engine/core/assertion/service_test.go diff --git a/core/engine.go b/ddosify_engine/core/engine.go similarity index 100% rename from core/engine.go rename to ddosify_engine/core/engine.go diff --git a/core/engine_test.go b/ddosify_engine/core/engine_test.go similarity index 100% rename from core/engine_test.go rename to ddosify_engine/core/engine_test.go diff --git a/core/proxy/base.go b/ddosify_engine/core/proxy/base.go similarity index 100% rename from core/proxy/base.go rename to ddosify_engine/core/proxy/base.go diff --git a/core/proxy/base_test.go b/ddosify_engine/core/proxy/base_test.go similarity index 100% rename from core/proxy/base_test.go rename to ddosify_engine/core/proxy/base_test.go diff --git a/core/proxy/single.go b/ddosify_engine/core/proxy/single.go similarity index 100% rename from core/proxy/single.go rename to ddosify_engine/core/proxy/single.go diff --git a/core/report/aggregator.go b/ddosify_engine/core/report/aggregator.go similarity index 100% rename from core/report/aggregator.go rename to ddosify_engine/core/report/aggregator.go diff --git a/core/report/aggregator_test.go b/ddosify_engine/core/report/aggregator_test.go similarity index 100% rename from core/report/aggregator_test.go rename to ddosify_engine/core/report/aggregator_test.go diff --git a/core/report/base.go b/ddosify_engine/core/report/base.go similarity index 100% rename from core/report/base.go rename to ddosify_engine/core/report/base.go diff --git a/core/report/base_test.go b/ddosify_engine/core/report/base_test.go similarity index 100% rename from core/report/base_test.go rename to ddosify_engine/core/report/base_test.go diff --git a/core/report/debug.go b/ddosify_engine/core/report/debug.go similarity index 100% rename from core/report/debug.go rename to ddosify_engine/core/report/debug.go diff --git a/core/report/debug_test.go b/ddosify_engine/core/report/debug_test.go similarity index 100% rename from core/report/debug_test.go rename to ddosify_engine/core/report/debug_test.go diff --git a/core/report/stdout.go b/ddosify_engine/core/report/stdout.go similarity index 100% rename from core/report/stdout.go rename to ddosify_engine/core/report/stdout.go diff --git a/core/report/stdoutJson.go b/ddosify_engine/core/report/stdoutJson.go similarity index 100% rename from core/report/stdoutJson.go rename to ddosify_engine/core/report/stdoutJson.go diff --git a/core/report/stdoutJson_test.go b/ddosify_engine/core/report/stdoutJson_test.go similarity index 100% rename from core/report/stdoutJson_test.go rename to ddosify_engine/core/report/stdoutJson_test.go diff --git a/core/report/stdout_test.go b/ddosify_engine/core/report/stdout_test.go similarity index 100% rename from core/report/stdout_test.go rename to ddosify_engine/core/report/stdout_test.go diff --git a/core/scenario/client_pool.go b/ddosify_engine/core/scenario/client_pool.go similarity index 100% rename from core/scenario/client_pool.go rename to ddosify_engine/core/scenario/client_pool.go diff --git a/core/scenario/client_pool_cookie_test.go b/ddosify_engine/core/scenario/client_pool_cookie_test.go similarity index 100% rename from core/scenario/client_pool_cookie_test.go rename to ddosify_engine/core/scenario/client_pool_cookie_test.go diff --git a/core/scenario/data/csv.go b/ddosify_engine/core/scenario/data/csv.go similarity index 100% rename from core/scenario/data/csv.go rename to ddosify_engine/core/scenario/data/csv.go diff --git a/core/scenario/data/csv_test.go b/ddosify_engine/core/scenario/data/csv_test.go similarity index 100% rename from core/scenario/data/csv_test.go rename to ddosify_engine/core/scenario/data/csv_test.go diff --git a/core/scenario/requester/base.go b/ddosify_engine/core/scenario/requester/base.go similarity index 100% rename from core/scenario/requester/base.go rename to ddosify_engine/core/scenario/requester/base.go diff --git a/core/scenario/requester/base_test.go b/ddosify_engine/core/scenario/requester/base_test.go similarity index 100% rename from core/scenario/requester/base_test.go rename to ddosify_engine/core/scenario/requester/base_test.go diff --git a/core/scenario/requester/http.go b/ddosify_engine/core/scenario/requester/http.go similarity index 100% rename from core/scenario/requester/http.go rename to ddosify_engine/core/scenario/requester/http.go diff --git a/core/scenario/requester/http_test.go b/ddosify_engine/core/scenario/requester/http_test.go similarity index 100% rename from core/scenario/requester/http_test.go rename to ddosify_engine/core/scenario/requester/http_test.go diff --git a/core/scenario/scripting/assertion/assert.go b/ddosify_engine/core/scenario/scripting/assertion/assert.go similarity index 100% rename from core/scenario/scripting/assertion/assert.go rename to ddosify_engine/core/scenario/scripting/assertion/assert.go diff --git a/core/scenario/scripting/assertion/assert_test.go b/ddosify_engine/core/scenario/scripting/assertion/assert_test.go similarity index 100% rename from core/scenario/scripting/assertion/assert_test.go rename to ddosify_engine/core/scenario/scripting/assertion/assert_test.go diff --git a/core/scenario/scripting/assertion/ast/ast.go b/ddosify_engine/core/scenario/scripting/assertion/ast/ast.go similarity index 100% rename from core/scenario/scripting/assertion/ast/ast.go rename to ddosify_engine/core/scenario/scripting/assertion/ast/ast.go diff --git a/core/scenario/scripting/assertion/evaluator/env.go b/ddosify_engine/core/scenario/scripting/assertion/evaluator/env.go similarity index 100% rename from core/scenario/scripting/assertion/evaluator/env.go rename to ddosify_engine/core/scenario/scripting/assertion/evaluator/env.go diff --git a/core/scenario/scripting/assertion/evaluator/evaluator.go b/ddosify_engine/core/scenario/scripting/assertion/evaluator/evaluator.go similarity index 100% rename from core/scenario/scripting/assertion/evaluator/evaluator.go rename to ddosify_engine/core/scenario/scripting/assertion/evaluator/evaluator.go diff --git a/core/scenario/scripting/assertion/evaluator/function.go b/ddosify_engine/core/scenario/scripting/assertion/evaluator/function.go similarity index 100% rename from core/scenario/scripting/assertion/evaluator/function.go rename to ddosify_engine/core/scenario/scripting/assertion/evaluator/function.go diff --git a/core/scenario/scripting/assertion/evaluator/function_test.go b/ddosify_engine/core/scenario/scripting/assertion/evaluator/function_test.go similarity index 100% rename from core/scenario/scripting/assertion/evaluator/function_test.go rename to ddosify_engine/core/scenario/scripting/assertion/evaluator/function_test.go diff --git a/core/scenario/scripting/assertion/lexer/lexer.go b/ddosify_engine/core/scenario/scripting/assertion/lexer/lexer.go similarity index 100% rename from core/scenario/scripting/assertion/lexer/lexer.go rename to ddosify_engine/core/scenario/scripting/assertion/lexer/lexer.go diff --git a/core/scenario/scripting/assertion/lexer/lexer_test.go b/ddosify_engine/core/scenario/scripting/assertion/lexer/lexer_test.go similarity index 100% rename from core/scenario/scripting/assertion/lexer/lexer_test.go rename to ddosify_engine/core/scenario/scripting/assertion/lexer/lexer_test.go diff --git a/core/scenario/scripting/assertion/parser/parser.go b/ddosify_engine/core/scenario/scripting/assertion/parser/parser.go similarity index 100% rename from core/scenario/scripting/assertion/parser/parser.go rename to ddosify_engine/core/scenario/scripting/assertion/parser/parser.go diff --git a/core/scenario/scripting/assertion/parser/parser_test.go b/ddosify_engine/core/scenario/scripting/assertion/parser/parser_test.go similarity index 100% rename from core/scenario/scripting/assertion/parser/parser_test.go rename to ddosify_engine/core/scenario/scripting/assertion/parser/parser_test.go diff --git a/core/scenario/scripting/assertion/test_files/a.txt b/ddosify_engine/core/scenario/scripting/assertion/test_files/a.txt similarity index 100% rename from core/scenario/scripting/assertion/test_files/a.txt rename to ddosify_engine/core/scenario/scripting/assertion/test_files/a.txt diff --git a/core/scenario/scripting/assertion/test_files/currencies.json b/ddosify_engine/core/scenario/scripting/assertion/test_files/currencies.json similarity index 100% rename from core/scenario/scripting/assertion/test_files/currencies.json rename to ddosify_engine/core/scenario/scripting/assertion/test_files/currencies.json diff --git a/core/scenario/scripting/assertion/test_files/jsonArray.json b/ddosify_engine/core/scenario/scripting/assertion/test_files/jsonArray.json similarity index 100% rename from core/scenario/scripting/assertion/test_files/jsonArray.json rename to ddosify_engine/core/scenario/scripting/assertion/test_files/jsonArray.json diff --git a/core/scenario/scripting/assertion/test_files/jsonMap.json b/ddosify_engine/core/scenario/scripting/assertion/test_files/jsonMap.json similarity index 100% rename from core/scenario/scripting/assertion/test_files/jsonMap.json rename to ddosify_engine/core/scenario/scripting/assertion/test_files/jsonMap.json diff --git a/core/scenario/scripting/assertion/test_files/number.json b/ddosify_engine/core/scenario/scripting/assertion/test_files/number.json similarity index 100% rename from core/scenario/scripting/assertion/test_files/number.json rename to ddosify_engine/core/scenario/scripting/assertion/test_files/number.json diff --git a/core/scenario/scripting/assertion/token/token.go b/ddosify_engine/core/scenario/scripting/assertion/token/token.go similarity index 100% rename from core/scenario/scripting/assertion/token/token.go rename to ddosify_engine/core/scenario/scripting/assertion/token/token.go diff --git a/core/scenario/scripting/extraction/base.go b/ddosify_engine/core/scenario/scripting/extraction/base.go similarity index 100% rename from core/scenario/scripting/extraction/base.go rename to ddosify_engine/core/scenario/scripting/extraction/base.go diff --git a/core/scenario/scripting/extraction/base_test.go b/ddosify_engine/core/scenario/scripting/extraction/base_test.go similarity index 100% rename from core/scenario/scripting/extraction/base_test.go rename to ddosify_engine/core/scenario/scripting/extraction/base_test.go diff --git a/core/scenario/scripting/extraction/html.go b/ddosify_engine/core/scenario/scripting/extraction/html.go similarity index 100% rename from core/scenario/scripting/extraction/html.go rename to ddosify_engine/core/scenario/scripting/extraction/html.go diff --git a/core/scenario/scripting/extraction/html_test.go b/ddosify_engine/core/scenario/scripting/extraction/html_test.go similarity index 100% rename from core/scenario/scripting/extraction/html_test.go rename to ddosify_engine/core/scenario/scripting/extraction/html_test.go diff --git a/core/scenario/scripting/extraction/json.go b/ddosify_engine/core/scenario/scripting/extraction/json.go similarity index 100% rename from core/scenario/scripting/extraction/json.go rename to ddosify_engine/core/scenario/scripting/extraction/json.go diff --git a/core/scenario/scripting/extraction/json_test.go b/ddosify_engine/core/scenario/scripting/extraction/json_test.go similarity index 100% rename from core/scenario/scripting/extraction/json_test.go rename to ddosify_engine/core/scenario/scripting/extraction/json_test.go diff --git a/core/scenario/scripting/extraction/regex.go b/ddosify_engine/core/scenario/scripting/extraction/regex.go similarity index 100% rename from core/scenario/scripting/extraction/regex.go rename to ddosify_engine/core/scenario/scripting/extraction/regex.go diff --git a/core/scenario/scripting/extraction/regex_test.go b/ddosify_engine/core/scenario/scripting/extraction/regex_test.go similarity index 100% rename from core/scenario/scripting/extraction/regex_test.go rename to ddosify_engine/core/scenario/scripting/extraction/regex_test.go diff --git a/core/scenario/scripting/extraction/xml.go b/ddosify_engine/core/scenario/scripting/extraction/xml.go similarity index 100% rename from core/scenario/scripting/extraction/xml.go rename to ddosify_engine/core/scenario/scripting/extraction/xml.go diff --git a/core/scenario/scripting/extraction/xml_test.go b/ddosify_engine/core/scenario/scripting/extraction/xml_test.go similarity index 100% rename from core/scenario/scripting/extraction/xml_test.go rename to ddosify_engine/core/scenario/scripting/extraction/xml_test.go diff --git a/core/scenario/scripting/injection/dynamic_test.go b/ddosify_engine/core/scenario/scripting/injection/dynamic_test.go similarity index 100% rename from core/scenario/scripting/injection/dynamic_test.go rename to ddosify_engine/core/scenario/scripting/injection/dynamic_test.go diff --git a/core/scenario/scripting/injection/environment.go b/ddosify_engine/core/scenario/scripting/injection/environment.go similarity index 100% rename from core/scenario/scripting/injection/environment.go rename to ddosify_engine/core/scenario/scripting/injection/environment.go diff --git a/core/scenario/scripting/injection/environment_dynamic.go b/ddosify_engine/core/scenario/scripting/injection/environment_dynamic.go similarity index 100% rename from core/scenario/scripting/injection/environment_dynamic.go rename to ddosify_engine/core/scenario/scripting/injection/environment_dynamic.go diff --git a/core/scenario/scripting/injection/environment_test.go b/ddosify_engine/core/scenario/scripting/injection/environment_test.go similarity index 100% rename from core/scenario/scripting/injection/environment_test.go rename to ddosify_engine/core/scenario/scripting/injection/environment_test.go diff --git a/core/scenario/scripting/injection/init.go b/ddosify_engine/core/scenario/scripting/injection/init.go similarity index 100% rename from core/scenario/scripting/injection/init.go rename to ddosify_engine/core/scenario/scripting/injection/init.go diff --git a/core/scenario/service.go b/ddosify_engine/core/scenario/service.go similarity index 100% rename from core/scenario/service.go rename to ddosify_engine/core/scenario/service.go diff --git a/core/scenario/service_test.go b/ddosify_engine/core/scenario/service_test.go similarity index 100% rename from core/scenario/service_test.go rename to ddosify_engine/core/scenario/service_test.go diff --git a/core/types/error.go b/ddosify_engine/core/types/error.go similarity index 100% rename from core/types/error.go rename to ddosify_engine/core/types/error.go diff --git a/core/types/hammer.go b/ddosify_engine/core/types/hammer.go similarity index 100% rename from core/types/hammer.go rename to ddosify_engine/core/types/hammer.go diff --git a/core/types/hammer_test.go b/ddosify_engine/core/types/hammer_test.go similarity index 100% rename from core/types/hammer_test.go rename to ddosify_engine/core/types/hammer_test.go diff --git a/core/types/regex/regex.go b/ddosify_engine/core/types/regex/regex.go similarity index 100% rename from core/types/regex/regex.go rename to ddosify_engine/core/types/regex/regex.go diff --git a/core/types/regex/regex_test.go b/ddosify_engine/core/types/regex/regex_test.go similarity index 100% rename from core/types/regex/regex_test.go rename to ddosify_engine/core/types/regex/regex_test.go diff --git a/core/types/response.go b/ddosify_engine/core/types/response.go similarity index 100% rename from core/types/response.go rename to ddosify_engine/core/types/response.go diff --git a/core/types/scenario.go b/ddosify_engine/core/types/scenario.go similarity index 100% rename from core/types/scenario.go rename to ddosify_engine/core/types/scenario.go diff --git a/core/types/scenario_test.go b/ddosify_engine/core/types/scenario_test.go similarity index 100% rename from core/types/scenario_test.go rename to ddosify_engine/core/types/scenario_test.go diff --git a/core/util/buffer_pool.go b/ddosify_engine/core/util/buffer_pool.go similarity index 100% rename from core/util/buffer_pool.go rename to ddosify_engine/core/util/buffer_pool.go diff --git a/core/util/helper.go b/ddosify_engine/core/util/helper.go similarity index 100% rename from core/util/helper.go rename to ddosify_engine/core/util/helper.go diff --git a/core/util/pool.go b/ddosify_engine/core/util/pool.go similarity index 100% rename from core/util/pool.go rename to ddosify_engine/core/util/pool.go diff --git a/go.mod b/ddosify_engine/go.mod similarity index 100% rename from go.mod rename to ddosify_engine/go.mod diff --git a/go.sum b/ddosify_engine/go.sum similarity index 100% rename from go.sum rename to ddosify_engine/go.sum diff --git a/main.go b/ddosify_engine/main.go similarity index 100% rename from main.go rename to ddosify_engine/main.go diff --git a/main_benchmark_test.go b/ddosify_engine/main_benchmark_test.go similarity index 100% rename from main_benchmark_test.go rename to ddosify_engine/main_benchmark_test.go diff --git a/main_exit_test.go b/ddosify_engine/main_exit_test.go similarity index 100% rename from main_exit_test.go rename to ddosify_engine/main_exit_test.go diff --git a/main_test.go b/ddosify_engine/main_test.go similarity index 100% rename from main_test.go rename to ddosify_engine/main_test.go diff --git a/scripts/install.sh b/ddosify_engine/scripts/install.sh similarity index 100% rename from scripts/install.sh rename to ddosify_engine/scripts/install.sh diff --git a/scripts/testing/benchstat.sh b/ddosify_engine/scripts/testing/benchstat.sh similarity index 100% rename from scripts/testing/benchstat.sh rename to ddosify_engine/scripts/testing/benchstat.sh diff --git a/selfhosted/README.md b/selfhosted/README.md index b96d8716..32365d49 100644 --- a/selfhosted/README.md +++ b/selfhosted/README.md @@ -1,18 +1,18 @@- -Ddosify detects high latency service calls on your K8s cluster. So you can easily find the root service causing the problem. + +Anteon (formerly Ddosify) detects high latency service calls on your K8s cluster. So you can easily find the root service causing the problem.
-This README provides instructions for installing and an overview of the system requirements for Ddosify Self-Hosted. For further information on its features, please refer to the ["What is Ddosify"](https://github.com/ddosify/ddosify/#what-is-ddosify) section in the main README, or consult the complete [documentation](https://docs.ddosify.com/concepts/test-suite). +This README provides instructions for installing and an overview of the system requirements for Anteon Self-Hosted. For further information on its features, please refer to the ["What is Anteon"](https://github.com/getanteon/anteon/#what-is-anteon) section in the main README, or consult the complete [documentation](https://getanteon.com/docs/performance-testing/test-suite/). - + ## Effortless Installation @@ -20,13 +20,13 @@ This README provides instructions for installing and an overview of the system r ✅ **Dockerized**: Containerized solution simplifies deployment and reduces dependency management overhead. -✅ **Helm Chart**: [Helm chart](https://github.com/ddosify/ddosify-helm-charts) for Kubernetes deployments. +✅ **Helm Chart**: [Helm chart](https://github.com/getanteon/anteon-helm-charts) for Kubernetes deployments. ✅ **Easy to Deploy**: Automated setup processes using Docker Compose and Helm Charts. ✅ **AWS Marketplace**: [AWS Marketplace](https://aws.amazon.com/marketplace/pp/prodview-mwvnujtgjedjy) listing for easy deployment on AWS (Amazon Web Services). -✅ **Kubernetes Monitoring**: With the help of [Ddosify eBPF Agent (Alaz)](https://github.com/ddosify/alaz) you can monitor your Kubernetes Cluster, create Service Map and get metrics from your Kubernetes nodes. +✅ **Kubernetes Monitoring**: With the help of [Anteon eBPF Agent (Alaz)](https://github.com/getanteon/alaz) you can monitor your Kubernetes Cluster, create Service Map and get metrics from your Kubernetes nodes. ## 🛠 Prerequisites @@ -43,27 +43,27 @@ This README provides instructions for installing and an overview of the system r ## ⚡️ Quick Start (docker compose) -You can quickly deploy Ddosify Self Hosted by running the following command. This script clones the Ddosify repository to your `$HOME/.ddosify` directory, and deploys the services using Docker Compose. Please check the [install.sh](./install.sh) file to see what it does. You can also run the commands manually by following the [Manual Installation](#-manual-installation) section. +You can quickly deploy Anteon Self Hosted by running the following command. This script clones the Anteon repository to your `$HOME/.anteon` directory, and deploys the services using Docker Compose. Please check the [install.sh](./install.sh) file to see what it does. You can also run the commands manually by following the [Manual Installation](#-manual-installation) section. Only Linux and MacOS are supported at the moment. Windows is not supported. -Ddosify Self Hosted starts in the background. You can access the dashboard at [http://localhost:8014](http://localhost:8014). The system is started always on boot if Docker is started. You can stop the system in the [Stop/Start the Services](#-stopstart-the-services) section. +Anteon Self Hosted starts in the background. You can access the dashboard at [http://localhost:8014](http://localhost:8014). The system is started always on boot if Docker is started. You can stop the system in the [Stop/Start the Services](#-stopstart-the-services) section. ```bash -curl -sSL https://raw.githubusercontent.com/ddosify/ddosify/master/selfhosted/install.sh | bash +curl -sSL https://raw.githubusercontent.com/getanteon/anteon/master/selfhosted/install.sh | bash ``` ## 🚀 Deploy on Kubernetes -You can deploy Ddosify Self Hosted on Kubernetes using the [Helm chart](https://github.com/ddosify/ddosify-helm-charts). +You can deploy Anteon Self Hosted on Kubernetes using the [Helm chart](https://github.com/getanteon/anteon-helm-charts). ## 📖 Manual Installation ### 1. Clone the repository ```bash -git clone https://github.com/ddosify/ddosify.git -cd ddosify/selfhosted +git clone https://github.com/getanteon/anteon.git +cd anteon/selfhosted ``` ### 2. Update the environment variables (optional) @@ -92,15 +92,15 @@ docker-compose logs ## 🔧 Add New Engine -The [Ddosify Engine](https://github.com/ddosify/ddosify) is responsible for generating load to the target URL. You can add multiple engines to scale your load testing capabilities. +The [Anteon Engine](https://github.com/getanteon/anteon) is responsible for generating load to the target URL. You can add multiple engines to scale your load testing capabilities. -The Ddosify Self Hosted includes a default engine out of the box. To integrate additional engines, simply run a Docker container for each new engine. These engine containers will automatically register with the service and become available for use. Before adding new engines, ensure that you have enabled the distributed mode by clicking the `Unlock the Distributed Mode` button in the dashboard. +The Anteon Self Hosted includes a default engine out of the box. To integrate additional engines, simply run a Docker container for each new engine. These engine containers will automatically register with the service and become available for use. Before adding new engines, ensure that you have enabled the distributed mode by clicking the `Unlock the Distributed Mode` button in the dashboard. In case you have modified the default values like InfluxDB password in the `.env` file, utilize the `--env` flag in the docker run command to establish the necessary environment variables. -Make sure the new engine server can access the service server. Use the `DDOSIFY_SERVICE_ADDRESS` environment variable to specify the service server address where the [install.sh](install.sh) script was executed. +Make sure the new engine server can access the service server. Use the `SERVICE_ADDRESS` environment variable to specify the service server address where the [install.sh](install.sh) script was executed. -The engine server must connect to the following ports on the `DDOSIFY_SERVICE_ADDRESS`: +The engine server must connect to the following ports on the `SERVICE_ADDRESS`: - `9901`: Hammer Manager service. The service server utilizes this port to register the engine. - `6672`: RabbitMQ server. The engine server connects to this port to send and receive messages to and from the service server. @@ -112,71 +112,71 @@ The `NAME` environment variable is used to specify the name of the engine contai ### **Example 1**: Adding the engine to the same server ```bash -NAME=ddosify_hammer_1 +NAME=anteon_hammer_1 docker run --name $NAME -dit \ - --network selfhosted_ddosify \ + --network anteon \ --restart always \ - ddosify/selfhosted_hammer:1.4.2 + anteon/selfhosted_hammer:1.4.3 ``` ### **Example 2**: Adding the engine to a different server -Set `DDOSIFY_SERVICE_ADDRESS` to the IP address of the service server. Set `IP_ADDRESS` to the IP address of the engine server. +Set `SERVICE_ADDRESS` to the IP address of the service server. Set `IP_ADDRESS` to the IP address of the engine server. ```bash # Make sure to set the following environment variables -DDOSIFY_SERVICE_ADDRESS=SERVICE_IP +SERVICE_ADDRESS=SERVICE_IP IP_ADDRESS=ENGINE_IP -NAME=ddosify_hammer_1 +NAME=anteon_hammer_1 docker run --name $NAME -dit \ - --env DDOSIFY_SERVICE_ADDRESS=$DDOSIFY_SERVICE_ADDRESS \ + --env SERVICE_ADDRESS=$SERVICE_ADDRESS \ --env IP_ADDRESS=$IP_ADDRESS \ --restart always \ - ddosify/selfhosted_hammer:1.4.2 + anteon/selfhosted_hammer:1.4.3 ``` You should see `mq_waiting_new_job` log in the engine container logs. This means that the engine is waiting for a job from the service server. After the engine is added, you can see it in the Engines page in the dashboard. ### **Example 3**: Adding the engine to Kubernetes -You can deploy the engine on Kubernetes using the Helm chart. Please check the [Ddosify Helm chart](https://github.com/ddosify/ddosify-helm-charts#add-new-engine-optional) repository for more information. +You can deploy the engine on Kubernetes using the Helm chart. Please check the [Anteon Helm chart](https://github.com/getanteon/anteon-helm-charts#add-new-engine-optional) repository for more information. ## 🧹 Remove New Engine -If you added new engines, you can remove them by running the following command. Change the docker container name `ddosify_hammer_1` to the name of the engine you added. +If you added new engines, you can remove them by running the following command. Change the docker container name `anteon_hammer_1` to the name of the engine you added. ```bash -docker rm -f ddosify_hammer_1 +docker rm -f anteon_hammer_1 ``` ## 🛑 Stop/Start the Services -If you installed the project using the [install.sh](./install.sh) script, you must first change the directory to the `$HOME/.ddosify` directory before running the commands below. +If you installed the project using the [install.sh](./install.sh) script, you must first change the directory to the `$HOME/.anteon` directory before running the commands below. ```bash -cd $HOME/.ddosify/selfhosted +cd $HOME/.anteon/selfhosted docker compose down ``` -If you want to remove the complete data like databases in docker volumes, you can run the following command. ⚠️ Warning: This will remove all the data for Ddosify Self Hosted. +If you want to remove the complete data like databases in docker volumes, you can run the following command. ⚠️ Warning: This will remove all the data for Anteon Self Hosted. ```bash -cd $HOME/.ddosify/selfhosted +cd $HOME/.anteon/selfhosted docker compose down --volumes ``` -You may encounter the following error when running the `docker compose down` command if you did not [remove the engine](#-remove-new-engine) containers. This is completely fine. The network `selfhosted_ddosify` is not removed from docker. If you do not want to see this error, you can [remove the engine](#-remove-new-engine) containers first then run the `docker compose down` command again. +You may encounter the following error when running the `docker compose down` command if you did not [remove the engine](#-remove-new-engine) containers. This is completely fine. The network `anteon` is not removed from docker. If you do not want to see this error, you can [remove the engine](#-remove-new-engine) containers first then run the `docker compose down` command again. ```text -failed to remove network selfhosted_ddosify: Error response from... +failed to remove network anteon: Error response from... ``` If you want to start the project again, run the script in the [Quick Start](#%EF%B8%8F-quick-start-recommended) section again. ## Enable Kubernetes Monitoring -To monitor your Kubernetes Cluster, you need to run the [Ddosify eBPF Agent (Alaz)](https://github.com/ddosify/alaz) as a DaemonSet. Refer to the [Alaz](https://github.com/ddosify/alaz) repository for more information. +To monitor your Kubernetes Cluster, you need to run the [Anteon eBPF Agent (Alaz)](https://github.com/getanteon/alaz) as a DaemonSet. Refer to the [Alaz](https://github.com/getanteon/alaz) repository for more information. ## 🧩 Services Overview @@ -195,7 +195,7 @@ To monitor your Kubernetes Cluster, you need to run the [Ddosify eBPF Agent (Ala ## Telemetry Data -Ddosify Self Hosted collects anonymous usage data to help us improve the product. You can disable this feature by setting the `ANONYMOUS_TELEMETRY_ENABLED` environment variable to `False` of the `backend` service in the [docker-compose.yml](./docker-compose.yml) file. +Anteon Self Hosted collects anonymous usage data to help us improve the product. You can disable this feature by setting the `ANONYMOUS_TELEMETRY_ENABLED` environment variable to `False` of the `backend` service in the [docker-compose.yml](./docker-compose.yml) file. ```yaml backend: @@ -252,4 +252,4 @@ backend: ## 📝 License -Ddosify Self Hosted is licensed under the AGPLv3: https://www.gnu.org/licenses/agpl-3.0.html +Anteon Self Hosted is licensed under the AGPLv3: https://www.gnu.org/licenses/agpl-3.0.html diff --git a/selfhosted/docker-compose.yml b/selfhosted/docker-compose.yml index 94aa1de4..6c58affe 100644 --- a/selfhosted/docker-compose.yml +++ b/selfhosted/docker-compose.yml @@ -12,19 +12,19 @@ services: - backend restart: always networks: - - ddosify + - anteon frontend: - image: ddosify/selfhosted_frontend:2.7.4 + image: anteon/selfhosted_frontend:2.7.4 depends_on: - backend restart: always pull_policy: always networks: - - ddosify + - anteon backend: - image: ddosify/selfhosted_backend:2.6.11 + image: anteon/selfhosted_backend:2.6.11 depends_on: - postgres - influxdb @@ -33,13 +33,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_app_onprem.sh backend-celery-worker: - image: ddosify/selfhosted_backend:2.6.11 + image: anteon/selfhosted_backend:2.6.11 depends_on: - postgres - influxdb @@ -50,13 +50,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_worker.sh backend-celery-beat: - image: ddosify/selfhosted_backend:2.6.11 + image: anteon/selfhosted_backend:2.6.11 depends_on: - postgres - influxdb @@ -67,13 +67,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_beat.sh alaz-backend: - image: ddosify/selfhosted_alaz_backend:1.0.6 + image: anteon/selfhosted_alaz_backend:1.0.6 depends_on: - postgres - influxdb @@ -82,13 +82,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_app_onprem.sh alaz-backend-celery-worker-1: - image: ddosify/selfhosted_alaz_backend:1.0.6 + image: anteon/selfhosted_alaz_backend:1.0.6 depends_on: - postgres - influxdb @@ -99,13 +99,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_worker.sh alaz-backend-celery-worker-2: - image: ddosify/selfhosted_alaz_backend:1.0.6 + image: anteon/selfhosted_alaz_backend:1.0.6 depends_on: - postgres - influxdb @@ -116,13 +116,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_worker.sh alaz-backend-celery-beat: - image: ddosify/selfhosted_alaz_backend:1.0.6 + image: anteon/selfhosted_alaz_backend:1.0.6 depends_on: - postgres - influxdb @@ -133,7 +133,7 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_beat.sh @@ -141,7 +141,7 @@ services: hammermanager: ports: - "9901:8001" - image: ddosify/selfhosted_hammermanager:1.2.4 + image: anteon/selfhosted_hammermanager:1.2.4 depends_on: - postgres - rabbitmq-job @@ -149,13 +149,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_app.sh hammermanager-celery-worker: - image: ddosify/selfhosted_hammermanager:1.2.4 + image: anteon/selfhosted_hammermanager:1.2.4 depends_on: - postgres - rabbitmq-job @@ -164,13 +164,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_worker.sh hammermanager-celery-beat: - image: ddosify/selfhosted_hammermanager:1.2.4 + image: anteon/selfhosted_hammermanager:1.2.4 depends_on: - postgres - rabbitmq-job @@ -179,13 +179,13 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always command: /workspace/start_scripts/start_celery_beat.sh hammer: - image: ddosify/selfhosted_hammer:1.4.2 + image: anteon/selfhosted_hammer:1.4.3 volumes: - hammer_id:/root/uuid depends_on: @@ -196,12 +196,12 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always pull_policy: always hammerdebug: - image: ddosify/selfhosted_hammer:1.4.2 + image: anteon/selfhosted_hammer:1.4.3 volumes: - hammerdebug_id:/root/uuid depends_on: @@ -213,7 +213,7 @@ services: environment: - IS_DEBUG=true networks: - - ddosify + - anteon restart: always pull_policy: always @@ -225,25 +225,25 @@ services: env_file: - .env networks: - - ddosify + - anteon restart: always rabbitmq-celery: image: "rabbitmq:3.13.0-alpine" networks: - - ddosify + - anteon restart: always rabbitmq-celery-backend: image: "rabbitmq:3.13.0-alpine" networks: - - ddosify + - anteon restart: always rabbitmq-celery-alaz-backend: image: "rabbitmq:3.13.0-alpine" networks: - - ddosify + - anteon restart: always rabbitmq-job: @@ -251,7 +251,7 @@ services: - "6672:5672" image: "rabbitmq:3.13.0-alpine" networks: - - ddosify + - anteon restart: always influxdb: @@ -263,12 +263,12 @@ services: - ./init_scripts/influxdb:/docker-entrypoint-initdb.d environment: - DOCKER_INFLUXDB_INIT_MODE=setup - - DOCKER_INFLUXDB_INIT_ORG=ddosify + - DOCKER_INFLUXDB_INIT_ORG=anteon - DOCKER_INFLUXDB_INIT_BUCKET=hammerBucket env_file: - .env networks: - - ddosify + - anteon restart: always redis-backend: @@ -276,7 +276,7 @@ services: volumes: - redis_backend_data:/data networks: - - ddosify + - anteon restart: always redis-alaz-backend: @@ -284,7 +284,7 @@ services: volumes: - redis_alaz_backend_data:/data networks: - - ddosify + - anteon restart: always seaweedfs: @@ -293,7 +293,7 @@ services: - "8333:8333" command: 'server -s3 -dir="/data"' networks: - - ddosify + - anteon restart: always volumes: - seaweedfs_data:/data @@ -307,7 +307,7 @@ services: - ./init_scripts/prometheus/prometheus.yml:/prometheus/prometheus.yml - prometheus_data:/prometheus networks: - - ddosify + - anteon restart: always volumes: @@ -321,4 +321,4 @@ volumes: prometheus_data: networks: - ddosify: + anteon: diff --git a/selfhosted/install.sh b/selfhosted/install.sh index b7b38b2b..e65a5e5f 100755 --- a/selfhosted/install.sh +++ b/selfhosted/install.sh @@ -2,7 +2,7 @@ set -e -echo "⚡ Installing Ddosify Self Hosted..." +echo "⚡ Installing Anteon Self Hosted..." echo "🔍 Checking prerequisites..." @@ -53,9 +53,9 @@ if ! docker info >/dev/null 2>&1; then exit 1 fi -echo "🚀 Starting installation of Ddosify Self Hosted..." +echo "🚀 Starting installation of Anteon Self Hosted..." -REPO_DIR="$HOME/.ddosify" +REPO_DIR="$HOME/.anteon" # Check if repository already exists if [ -d "$REPO_DIR" ]; then @@ -75,7 +75,7 @@ if [ -d "$REPO_DIR" ]; then else # Clone the repository echo "📦 Cloning repository to $REPO_DIR directory..." - git clone https://github.com/ddosify/ddosify.git "$REPO_DIR" >/dev/null 2>&1 + git clone https://github.com/getanteon/anteon.git "$REPO_DIR" >/dev/null 2>&1 cd "$REPO_DIR" git checkout master >/dev/null 2>&1 cd "$REPO_DIR/selfhosted" @@ -87,16 +87,14 @@ if command -v docker >/dev/null 2>&1 && docker compose version >/dev/null 2>&1; COMPOSE_COMMAND="docker compose" fi -echo "🚀 Deploying Ddosify Self Hosted..." +echo "🚀 Deploying Anteon Self Hosted..." $COMPOSE_COMMAND -f "$REPO_DIR/selfhosted/docker-compose.yml" up -d docker pull busybox:1.34.1 >/dev/null 2>&1 echo "" echo "⏳ Waiting for services to be ready..." -docker run --rm --network selfhosted_ddosify busybox:1.34.1 /bin/sh -c "until nc -z nginx 80 && nc -z backend 8008 && nc -z hammermanager 8001 && nc -z rabbitmq-celery 5672 && nc -z rabbitmq-job 5672 && nc -z postgres 5432 && nc -z influxdb 8086 && nc -z seaweedfs 8333; do sleep 5; done" -echo "✅ Ddosify Self Hosted installation complete!" +docker run --rm --network anteon busybox:1.34.1 /bin/sh -c "until nc -z nginx 80 && nc -z backend 8008 && nc -z hammermanager 8001 && nc -z rabbitmq-celery 5672 && nc -z rabbitmq-job 5672 && nc -z postgres 5432 && nc -z influxdb 8086 && nc -z seaweedfs 8333; do sleep 5; done" +echo "✅ Anteon Self Hosted installation complete!" echo "📁 Installation directory: $REPO_DIR/selfhosted" -echo "🔥 To remove Ddosify Self Hosted, run: $COMPOSE_COMMAND down" +echo "🔥 To remove Anteon Self Hosted, run: cd $REPO_DIR/selfhosted && $COMPOSE_COMMAND down" echo "" echo "🌐 Open http://localhost:8014 in your browser to access the application." - -