Here's an attempt to create yet another damn Linux server benchmarking script.
Logo design by Dian Pratama
This script isn't an attempt to be a golden standard. It's just yet another bench script to add to your arsenal. Included are several tests that I think are most beneficial for the end-user. If there's features that you would like to see added, feel free to submit an issue describing your feature request or fork the project!
View YABS usage stats here.
What's New With YABS?
- 27 Feb 2023 - Newly released Geekbench 6 is added as the default Geekbench test.
- 26 Feb 2023 - Network information added to YABS output using ip-api.
- 15 Aug 2022 - Added JSON output/upload support to export or auto-upload of YABS results for sharing.
How to Run
curl -sL yabs.sh | bash
wget -qO- yabs.sh | bash
This script has been tested on the following Linux distributions: CentOS 6+, Debian 8+, Fedora 30, and Ubuntu 16.04+. It is designed to not require any external dependencies to be installed nor elevated privileges to run.
Local fio/iperf3 Packages: If the tested system has fio and/or iperf3 already installed, the local package will take precedence over the precompiled binary.
Experimental ARM Compatibility: Initial ARM compatibility has been introduced, however, is not considered entirely stable due to limited testing on distinct ARM devices. Report any errors or issues.
High Bandwidth Usage Notice: By default, this script will perform many iperf network tests, which will try to max out the network port for ~20s per location (10s in each direction). Low-bandwidth servers (such as a NAT VPS) should consider running this script with the
-r flag (for reduced iperf locations) or the
-i flag (to disable network tests entirely).
Flags (Skipping Tests, Reducing iperf Locations, Geekbench 4/5/6, etc.)
By default, the script runs all three tests described in the next section below. In the event that you wish to skip one or more of the tests, use the commands below:
curl -sL yabs.sh | bash -s -- -flags
|-b||Forces use of pre-compiled binaries from repo over local packages|
|-f/-d||Disables the fio (disk performance) test|
|-i||Disables the iperf (network performance) test|
|-g||Disables the Geekbench (system performance) test|
|-n||Skips the network information lookup and print out|
|-h||Prints the help message with usage, flags detected, and local package (fio/iperf) status|
|-r||Reduces the number of iperf locations (Scaleway/Clouvider LON+NYC) to lessen bandwidth usage|
|-4||Runs a Geekbench 4 test and disables the Geekbench 6 test|
|-5||Runs a Geekbench 5 test and disables the Geekbench 6 test|
|-9||Runs both the Geekbench 4 and 5 tests instead of the Geekbench 6 test|
|-6||Re-enables the Geekbench 6 test if any of the following were used: -4, -5, or -9 (-6 flag must be last to not be overridden)|
|-j||Prints a JSON representation of the results to the screen|
|-w <filename>||Writes the JSON results to a file using the file name provided|
|-s <url>||Sends a JSON representation of the results to the designated URL(s) (see section below)|
Options can be grouped together to skip multiple tests, i.e.
-fg to skip the disk and system performance tests (effectively only testing network performance).
Geekbench License Key: A Geekbench license key can be utilized during the Geekbench test to unlock all features. Simply put the email and key for the license in a file called geekbench.license.
echo "email@example.com ABCDE-12345-FGHIJ-57890" > geekbench.license
Submitting JSON Results
Results from running this script can be sent to your benchmark results website of choice in JSON format. Invoke the
-s flag and pass the URL to where the results should be submitted to:
curl -sL yabs.sh | bash -s -- -s "https://example.com/yabs/post"
JSON results can be sent to multiple endpoints by entering each site joined by a comma (e.g. "https://example.com/yabs/post,http://example.com/yabs2/post").
A list of websites supporting acceptance of YABS JSON results will be posted here (when available). Example JSON output: example.json.
- fio - the most comprehensive I/O testing software available, fio grants the ability to evaluate disk performance in a variety of methods with a variety of options. Four random read and write fio disk tests are conducted as part of this script with 4k, 64k, 512k, and 1m block sizes. The tests are designed to evaluate disk throughput in near-real world (using random) scenarios with a 50/50 split (50% reads and 50% writes per test).
- iperf3 - the industry standard for testing download and upload speeds to various locations. This script utilizes iperf3 with 8 parallel threads and tests both download and upload speeds. If an iperf server is busy after 5 tries, the speed test for that location/direction is skipped.
- Geekbench - Geekbench is a benchmarking program that measures system performance, which is widely used in the tech community. The web URL is displayed to be able to see complete test and individual benchmark results and allow comparison to other geekbench'd systems. The claim URL to add the Geekbench result to your Geekbench profile is written to a file in the directory that this script is executed from. By default, Geekbench 6 is the only Geekbench test performed, however, Geekbench 4 and/or 5 can also be toggled on by passing the appropriate flag.
This script relies on external binaries in order to complete the performance tests. The network (iperf3) and disk (fio) tests use binaries that are compiled by myself utilizing a Holy Build Box compilation environment to ensure binary portability. The reasons for doing this include ensuring standardized (parsable) output, allowing support of both 32-bit and 64-bit architectures, bypassing the need for prerequisites to be compiled and/or installed, among other reasons. For the system test, a Geekbench tarball is downloaded, extracted, and the resulting binary is run. Use this script at your own risk as you would with any script publicly available on the net. Additional information regarding the binaries, including compilation notes and steps, can be found in the bin directory's README page.
# ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## # # Yet-Another-Bench-Script # # v2023-02-27 # # https://github.com/masonr/yet-another-bench-script # # ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## # Mon 27 Feb 2023 11:03:22 PM EST Basic System Information: --------------------------------- Uptime : 288 days, 4 hours, 57 minutes Processor : Intel(R) Xeon(R) E-2276G CPU @ 3.80GHz CPU cores : 12 @ 4430.782 MHz AES-NI : ✔ Enabled VM-x/AMD-V : ✔ Enabled RAM : 15.5 GiB Swap : 14.9 GiB Disk : 864.5 GiB Distro : Ubuntu 20.04.5 LTS Kernel : 5.4.0-110-generic VM Type : NONE Basic Network Information: --------------------------------- Protocol : IPv4 ISP : Clouvider Limited ASN : AS62240 Clouvider Host : Clouvider HB Location : New York, New York (NY) Country : United States fio Disk Speed Tests (Mixed R/W 50/50): --------------------------------- Block Size | 4k (IOPS) | 64k (IOPS) ------ | --- ---- | ---- ---- Read | 416.79 MB/s (104.1k) | 415.00 MB/s (6.4k) Write | 417.89 MB/s (104.4k) | 417.19 MB/s (6.5k) Total | 834.68 MB/s (208.6k) | 832.20 MB/s (13.0k) | | Block Size | 512k (IOPS) | 1m (IOPS) ------ | --- ---- | ---- ---- Read | 403.89 MB/s (788) | 421.15 MB/s (411) Write | 425.35 MB/s (830) | 449.20 MB/s (438) Total | 829.24 MB/s (1.6k) | 870.36 MB/s (849) iperf3 Network Speed Tests (IPv4): --------------------------------- Provider | Location (Link) | Send Speed | Recv Speed | Ping ----- | ----- | ---- | ---- | ---- Clouvider | London, UK (10G) | 1.80 Gbits/sec | 2.40 Gbits/sec | 76.8 ms Scaleway | Paris, FR (10G) | 2.61 Gbits/sec | 2.39 Gbits/sec | 75.5 ms NovoServe | North Holland, NL (40G) | 2.33 Gbits/sec | 2.14 Gbits/sec | 78.4 ms Uztelecom | Tashkent, UZ (10G) | 1.21 Gbits/sec | 1.09 Gbits/sec | 158 ms Clouvider | NYC, NY, US (10G) | 8.94 Gbits/sec | 7.88 Gbits/sec | 0.109 ms Clouvider | Dallas, TX, US (10G) | 4.99 Gbits/sec | 5.54 Gbits/sec | 34.0 ms Clouvider | Los Angeles, CA, US (10G) | 2.80 Gbits/sec | 2.69 Gbits/sec | 55.9 ms iperf3 Network Speed Tests (IPv6): --------------------------------- Provider | Location (Link) | Send Speed | Recv Speed | Ping ----- | ----- | ---- | ---- | ---- Clouvider | London, UK (10G) | 2.25 Gbits/sec | 2.40 Gbits/sec | 76.7 ms Scaleway | Paris, FR (10G) | busy | 2.38 Gbits/sec | 75.5 ms NovoServe | North Holland, NL (40G) | 2.24 Gbits/sec | 2.29 Gbits/sec | 78.4 ms Uztelecom | Tashkent, UZ (10G) | 1.16 Gbits/sec | 1.12 Gbits/sec | 158 ms Clouvider | NYC, NY, US (10G) | 9.16 Gbits/sec | 8.27 Gbits/sec | 0.077 ms Clouvider | Dallas, TX, US (10G) | 4.52 Gbits/sec | 5.57 Gbits/sec | 33.9 ms Clouvider | Los Angeles, CA, US (10G) | 2.53 Gbits/sec | 2.78 Gbits/sec | 56.0 ms Geekbench 4 Benchmark Test: --------------------------------- Test | Value | Single Core | 5976 Multi Core | 22084 Full Test | https://browser.geekbench.com/v4/cpu/16721228 Geekbench 5 Benchmark Test: --------------------------------- Test | Value | Single Core | 1077 Multi Core | 4773 Full Test | https://browser.geekbench.com/v5/cpu/20772711 Geekbench 6 Benchmark Test: --------------------------------- Test | Value | Single Core | 1524 Multi Core | 4847 Full Test | https://browser.geekbench.com/v6/cpu/343254 YABS completed in 16 min 34 sec
This script was inspired by several great benchmarking scripts out there, including, but not limited to, bench.sh, nench.sh, ServerBench, among others. Members of the HostedTalk, LowEndSpirit, and LowEndTalk hosting-related communities play a pivotal role in testing, evaluating, and shaping this script as it matures.
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE Version 2, December 2004 Copyright (C) 2019 Mason Rowe <firstname.lastname@example.org> Everyone is permitted to copy and distribute verbatim or modified copies of this license document, and changing it is allowed as long as the name is changed. DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 0. You just DO WHAT THE FUCK YOU WANT TO.