1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
# 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)
|