120 lines
3.7 KiB
Python
120 lines
3.7 KiB
Python
|
# python3
|
||
|
# Copyright 2019 Google LLC
|
||
|
#
|
||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
# you may not use this file except in compliance with the License.
|
||
|
# You may obtain a copy of the License at
|
||
|
#
|
||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||
|
# Unless required by applicable law or agreed to in writing, software
|
||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
# See the License for the specific language governing permissions and
|
||
|
# limitations under the License.
|
||
|
"""Sysbench-based benchmarks."""
|
||
|
|
||
|
from benchmarks import suites
|
||
|
from benchmarks.harness import machine
|
||
|
from benchmarks.workloads import sysbench
|
||
|
|
||
|
|
||
|
def run_sysbench(target: machine.Machine,
|
||
|
test: str = "cpu",
|
||
|
threads: int = 8,
|
||
|
time: int = 5,
|
||
|
options: str = "",
|
||
|
**kwargs) -> str:
|
||
|
"""Run sysbench container with arguments.
|
||
|
|
||
|
Args:
|
||
|
target: A machine object.
|
||
|
test: Relevant sysbench test to run (e.g. cpu, memory).
|
||
|
threads: The number of threads to use for tests.
|
||
|
time: The time to run tests.
|
||
|
options: Additional sysbench options.
|
||
|
**kwargs: Additional container options.
|
||
|
|
||
|
Returns:
|
||
|
The output of the command as a string.
|
||
|
"""
|
||
|
image = target.pull("sysbench")
|
||
|
return target.container(image, **kwargs).run(
|
||
|
test=test, threads=threads, time=time, options=options)
|
||
|
|
||
|
|
||
|
@suites.benchmark(metrics=[sysbench.cpu_events_per_second], machines=1)
|
||
|
def cpu(target: machine.Machine, max_prime: int = 5000, **kwargs) -> str:
|
||
|
"""Run sysbench CPU test.
|
||
|
|
||
|
Additional arguments can be provided for sysbench.
|
||
|
|
||
|
Args:
|
||
|
target: A machine object.
|
||
|
max_prime: The maximum prime number to search.
|
||
|
**kwargs:
|
||
|
- threads: The number of threads to use for tests.
|
||
|
- time: The time to run tests.
|
||
|
- options: Additional sysbench options. See sysbench tool:
|
||
|
https://github.com/akopytov/sysbench
|
||
|
|
||
|
Returns:
|
||
|
Sysbench output.
|
||
|
"""
|
||
|
options = kwargs.pop("options", "")
|
||
|
options += " --cpu-max-prime={}".format(max_prime)
|
||
|
return run_sysbench(target, test="cpu", options=options, **kwargs)
|
||
|
|
||
|
|
||
|
@suites.benchmark(metrics=[sysbench.memory_ops_per_second], machines=1)
|
||
|
def memory(target: machine.Machine, **kwargs) -> str:
|
||
|
"""Run sysbench memory test.
|
||
|
|
||
|
Additional arguments can be provided per sysbench.
|
||
|
|
||
|
Args:
|
||
|
target: A machine object.
|
||
|
**kwargs:
|
||
|
- threads: The number of threads to use for tests.
|
||
|
- time: The time to run tests.
|
||
|
- options: Additional sysbench options. See sysbench tool:
|
||
|
https://github.com/akopytov/sysbench
|
||
|
|
||
|
Returns:
|
||
|
Sysbench output.
|
||
|
"""
|
||
|
return run_sysbench(target, test="memory", **kwargs)
|
||
|
|
||
|
|
||
|
@suites.benchmark(
|
||
|
metrics=[
|
||
|
sysbench.mutex_time, sysbench.mutex_latency, sysbench.mutex_deviation
|
||
|
],
|
||
|
machines=1)
|
||
|
def mutex(target: machine.Machine,
|
||
|
locks: int = 4,
|
||
|
count: int = 10000000,
|
||
|
threads: int = 8,
|
||
|
**kwargs) -> str:
|
||
|
"""Run sysbench mutex test.
|
||
|
|
||
|
Additional arguments can be provided per sysbench.
|
||
|
|
||
|
Args:
|
||
|
target: A machine object.
|
||
|
locks: The number of locks to use.
|
||
|
count: The number of mutexes.
|
||
|
threads: The number of threads to use for tests.
|
||
|
**kwargs:
|
||
|
- time: The time to run tests.
|
||
|
- options: Additional sysbench options. See sysbench tool:
|
||
|
https://github.com/akopytov/sysbench
|
||
|
|
||
|
Returns:
|
||
|
Sysbench output.
|
||
|
"""
|
||
|
options = kwargs.pop("options", "")
|
||
|
options += " --mutex-loops=1 --mutex-locks={} --mutex-num={}".format(
|
||
|
count, locks)
|
||
|
return run_sysbench(
|
||
|
target, test="mutex", options=options, threads=threads, **kwargs)
|