Skip to content

msrexe/rhea

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

10 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

๐Ÿ”ฅ Rhea

  • A Server Load Testing Tool

Rhea is a powerful and easy-to-use command-line tool written in Rust for load testing servers. It allows you to simulate heavy concurrent traffic and analyze how your server responds under various loads. With Rhea, you can identify performance bottlenecks, test the scalability of your server, and ensure its stability even in high-traffic scenarios.

Features

  • Concurrent Requests: Rhea generates multiple concurrent requests to stress-test your server efficiently.

  • Customizable Load: You can define the number of concurrent users and the total number of requests to create different load scenarios.

  • HTTP Method Support: Perform load testing with various HTTP methods, including GET, POST, PUT, DELETE, and more.

  • Open Source: Rhea is open source, licensed under the MIT License. Feel free to contribute to its development!

Installation

To install Rhea, you need to have Rust installed. Once you have Rust set up, you can install Rhea via Cargo, the Rust package manager:

$ cargo install rhea

Quick Start

  1. Ensure your server is running and accessible.

  2. Open a terminal window and run the following command:

$ rhea --url http://your-server.com/api --concurrency 100 --requests 1000
  1. Sit back and relax while Rhea performs the load test.

  2. Once the load test is complete, Rhea will display detailed metrics and statistics.

Usage

rhea [OPTIONS] --url <URL> --requests <REQ_COUNT>

Flags:

  • --help: Displays help information about the load testing tool.

Options:

  • --url <URL>: The URL of the server you want to load test (required).

  • --concurrency <CONCURRENCY>: The number of concurrent users to simulate (default: 1, max:100).

  • --requests <REQUESTS>: The total number of requests to send during the test (default: 10).

  • --method <METHOD>: The HTTP method to use for the requests (default: GET).

  • --body <BODY>: The request body for POST or PUT requests.

  • --headers <HEADERS>: Custom headers to include in the requests.

Contributing

We welcome contributions to Rhea! To contribute, please follow the guidelines outlined in the CONTRIBUTING.md file.

License

Rhea is open-source software licensed under the MIT License. See the LICENSE file for more details.

Happy load testing!

About

Server load testing CLI tool ๐Ÿ‹๏ธ

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages