In this study, Akamas is tasked with the optimization of Linux1, a Linux-based system (Ubuntu). The study's goal is to maximize the throughput of the computations of the CPU benchmark.
Sysbench is a suite of benchmarks for CPU, file system, memory, threads, etc… typically used for testing the performance of databases.
System1 comes with a that collects system metrics that Akamas consumes through a . Concerning Sysbench metrics, The study uses the to make them available to Akamas.
The study uses Sysbench to execute a performance test against System1.
Telemetry
Setup a Prometheus and a Node Exporter to monitor the System
Install the Prometheus provider
Create a provider instance:
provider: "Prometheus"
config:
address: "linux1" # address of the Prometheus of system1
port: 9090 # port of the Prometheus of system1
component: "linux1-linux"
4. Install the CSV File provider.
5. Create a provider instance:
provider: "CSV"
config:
address: "linux1"
authType: "password"
username: "ubuntu"
auth: "[INSERT PASSWORD HERE]"
protocol: scp
remoteFilePattern: "/home/ubuntu/benchmark_log.csv" # the remote path of the csv with the metrics of the benchmark
componentColumn: "component" # which column of the csv should contain the name of the component
csvFormat: "horizontal"
metrics:
- metric: "throughput"
datasourceMetric: "events_per_second"
Workflow
The study uses a four-task workflow to test System1 with a new configuration:
The following YAML file represents the complete workflow definition: