Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Getting rid of the static ioping binary #5

Open
n-st opened this issue Mar 1, 2019 · 1 comment
Open

Getting rid of the static ioping binary #5

n-st opened this issue Mar 1, 2019 · 1 comment

Comments

@n-st
Copy link
Owner

n-st commented Mar 1, 2019

The static binary was originally added for three reasons:

  • Less effort and system clutter:
    Among nench's software requirements, ioping is arguably the most uncommon
    and least likely to be present by default.
    Providing the static binary avoids additional installations, at least on
    binary-compatible systems (Linux amd64 in this case).

  • Consistent output format:
    ioping's output format changed between version 0.9 and 1.0, but 1.0 still
    reports the old version:

    % apt-cache policy ioping
    ioping:
      Installed: 1.0-2
      Candidate: 1.0-2
      Version table:
     *** 1.0-2 500
            500 http://httpredir.debian.org/debian stretch/main amd64 Packages
            100 /var/lib/dpkg/status
    % ioping -v
    ioping 0.9
    

    The same happens with the static binary, but there I can be certain which
    version it is (and parse the output appropriately).

  • Consistent test scope:
    ioping 1.0 added a second summary line (marked with > below) that reports
    iops and throughput for the full deadline period (-w) requested on the
    commandline, rather than the old summary that excludes data from some of the
    probes (such as the "warmup" at the beginning):

    % ioping -DRL -w 5 . # ioping 0.9
    
    --- . ( ) ioping statistics ---
    301 requests completed in 5.11 s, 58 iops, 14.7 MiB/s
    min/avg/max/mdev = 778 us / 17.0 ms / 236.0 ms / 31.4 ms
    
    % ioping -DRL -w 5 . # ioping 1.0
    
    --- . ( ) ioping statistics ---
    1.65 k requests completed in 4.99 s, 413.5 MiB read, 331 iops, 82.9 MiB/s
    > generated 1.66 k requests in 5.00 s, 413.8 MiB, 330 iops, 82.7 MiB/s
    min/avg/max/mdev = 2.75 ms / 3.01 ms / 66.0 ms / 2.10 ms
    

Long story short, the static binary could be made superfluous by switching to
the "opportunistic" summary line (which is present in both old and new
versions) and selecting it by its content rather than its position in the
output.

It would also be possible to use the -B option (which I wasn't aware of when
I created nench, but which is present even in older versions) and parse the
"raw" output it produces. It may be possible to re-use the Bps_to_MiBps
formatter that's already used for the dd and curl output.

The primary disadvantages would be potentially breaking comparability between
old and new nench results, and requiring the installation of ioping just
for the test.
Perhaps offer the static binary for manual installation (then documented in
the README) and use only the system-installed version if the user doesn't
request otherwise?

@n-st n-st changed the title Get rid of the static ioping binary Getting rid of the static ioping binary Mar 1, 2019
@n-st n-st pinned this issue Apr 14, 2019
@gtxaspec
Copy link

gtxaspec commented Jul 7, 2021

+1, to enable this to work on ARM platforms (like ampere altra)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants