Este conteúdo não está disponível no idioma selecionado.
Chapter 3. Benchmarking Data Grid on OpenShift
For Data Grid clusters running on OpenShift, Red Hat recommends using Hyperfoil to measure performance. Hyperfoil is a benchmarking framework that provides accurate performance results for distributed services.
3.1. Benchmarking Data Grid Copiar o linkLink copiado para a área de transferência!
After you set up and configure your deployment, start benchmarking your Data Grid cluster to analyze and measure performance. Benchmarking shows you where limits exist so you can adjust your environment and tune your Data Grid configuration to get the best performance, which means achieving the lowest latency and highest throughput possible.
It is worth noting that optimal performance is a continual process, not an ultimate goal. When your benchmark tests show that your Data Grid deployment has reached a desired level of performance, you cannot expect those results to be fixed or always valid.
3.2. Installing Hyperfoil Copiar o linkLink copiado para a área de transferência!
Set up Hyperfoil on Red Hat OpenShift by creating an operator subscription and downloading the Hyperfoil distribution that includes the command line interface (CLI).
Procedure
Create a Hyperfoil Operator subscription through the OperatorHub in the OpenShift Web Console.
NoteHyperfoil Operator is available as a Community Operator.
Red Hat does not certify the Hyperfoil Operator and does not provide support for it in combination with Data Grid. When you install the Hyperfoil Operator you are prompted to acknowledge a warning about the community version before you can continue.
- Download the latest Hyperfoil version from the Hyperfoil release page.
3.3. Creating a Hyperfoil Controller Copiar o linkLink copiado para a área de transferência!
Instantiate a Hyperfoil Controller on Red Hat OpenShift so you can upload and run benchmark tests with the Hyperfoil Command Line Interface (CLI).
Prerequisites
- Create a Hyperfoil Operator subscription.
Procedure
Define
hyperfoil-controller.yaml
.Copy to Clipboard Copied! Toggle word wrap Toggle overflow Apply the Hyperfoil Controller.
oc apply -f hyperfoil-controller.yaml
$ oc apply -f hyperfoil-controller.yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Retrieve the route that connects you to the Hyperfoil CLI.
oc get routes
$ oc get routes NAME HOST/PORT hyperfoil hyperfoil-benchmark.apps.example.net
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
3.4. Running Hyperfoil benchmarks Copiar o linkLink copiado para a área de transferência!
Run benchmark tests with Hyperfoil to collect performance data for Data Grid clusters.
Prerequisites
- Create a Hyperfoil Operator subscription.
- Instantiate a Hyperfoil Controller on Red Hat OpenShift.
Procedure
Create a benchmark test.
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Open the route in any browser to access the Hyperfoil CLI.
Upload the benchmark test.
Run the
upload
command.upload
[hyperfoil]$ upload
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Click Select benchmark file and then navigate to the benchmark test on your file system and upload it.
Run the benchmark test.
run hotrod-benchmark
[hyperfoil]$ run hotrod-benchmark
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Get results of the benchmark test.
stats
[hyperfoil]$ stats
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
3.5. Hyperfoil benchmark results Copiar o linkLink copiado para a área de transferência!
Hyperfoil prints results of the benchmarking run in table format with the stats
command.
stats
[hyperfoil]$ stats
Total stats from run <run_id>
PHASE METRIC THROUGHPUT REQUESTS MEAN p50 p90 p99 p99.9 p99.99 TIMEOUTS ERRORS BLOCKED
Column | Description | Value |
---|---|---|
PHASE |
For each run, Hyperfoil makes |
Either |
METRIC |
During both phases of the run, Hyperfoil collects metrics for each |
Either |
THROUGHPUT | Captures the total number of requests per second. | Number |
REQUESTS | Captures the total number of operations during each phase of the run. | Number |
MEAN |
Captures the average time for |
Time in milliseconds ( |
p50 | Records the amount of time that it takes for 50 percent of requests to complete. |
Time in milliseconds ( |
p90 | Records the amount of time that it takes for 90 percent of requests to complete. |
Time in milliseconds ( |
p99 | Records the amount of time that it takes for 99 percent of requests to complete. |
Time in milliseconds ( |
p99.9 | Records the amount of time that it takes for 99.9 percent of requests to complete. |
Time in milliseconds ( |
p99.99 | Records the amount of time that it takes for 99.99 percent of requests to complete. |
Time in milliseconds ( |
TIMEOUTS | Captures the total number of timeouts that occurred for operations during each phase of the run. | Number |
ERRORS | Captures the total number of errors that occurred during each phase of the run. | Number |
BLOCKED | Captures the total number of operations that were blocked or could not complete. | Number |