On 2021/04/16 14:10, Sitsofe Wheeler wrote:
Hey,
On Fri, 16 Apr 2021 at 04:49, Nakajima Akira
<nakajima.akira@xxxxxxxxxxxx> wrote:
On 2021/04/16 4:37, Sitsofe Wheeler wrote:
On Thu, 15 Apr 2021 at 03:49, Nakajima Akira
<nakajima.akira@xxxxxxxxxxxx <mailto:nakajima.akira@xxxxxxxxxxxx>> wrote:
Hi.
Sorry. Due to my company's email sender domain restrictions,
it could not be sent to gmail.
Above is the result on unencrypted ext4/xfs.
Similar results are obtained on encrypted ext4/xfs.
Since the memory is 24GB, I tried it with 72GB + α = 76GB.
# fio -filename=/testfile -direct=1 -ioengine=libaio -rw=write -bs=1m
-size=76G -runtime=60 -numjobs=1 -group_reporting -name=a
write: IOPS=195, BW=195MiB/s (205MB/s)(11.4GiB/60023msec)
# fio -filename=/testfile -direct=1 -ioengine=libaio -rw=write -bs=1m
-size=76G -runtime=60 -numjobs=10 -group_reporting -name=a
write: IOPS=1622, BW=1622MiB/s (1701MB/s)(95.1GiB/60042msec)
# fio -filename=/testfile -direct=1 -ioengine=libaio -rw=write -bs=1m
-size=76G -runtime=300 -numjobs=10 -group_reporting -name=a
write: IOPS=1879, BW=1880MiB/s (1971MB/s)(551GiB/300004msec)
Ah, that numjobs value is REALLY important for the type of job file
you have! Using numjobs on the same filename can lead to reuse of the
same area (think job 1 and job 2 writing the same blocks in lockstep)
which may in turn lead to not all I/Os being sent down to the disk if
they are close enough together. This may make a nonsense of your
benchmark...
Up to numjobs = about 10, it increases in proportion to the value of
numjobs.
--
Sitsofe
Hi.
Now I tried, but these had the same results.
(twice as much as numjobs=1)
-filename=/mnt/test1:/mnt/test2
-filename=/dev/sdb (after umount /mnt)
# fio -filename=xxx -direct=1 -ioengine=libaio -rw=write -bs=1m -size=8G
-runtime=60 -numjobs=2 -group_reporting -name=a
Using -directory instead of -filename is only way to get correct result?
That would work but it depends on what "correct" means :-) The problem
with your jobs above is that you have not eliminated the possibility
of two or more jobs still writing the same area at the same time (the
colon syntax in filename just tells fio it might have to pick a
different file to last time - see
https://fio.readthedocs.io/en/latest/fio_doc.html#cmdoption-arg-file-service-type
further info). If all jobs are switching files in lockstep on each I/O
what is stopping collisions?
I'll illustrate the original scenario but simplified a bit:
job1: | 0 | 1 | 2 | ...
job2: | 0 | 1 | 2 | ...
Time is flowing from left to right and the numbers represent the LBA
being written within a given period. In this case in the first
"instant" LBA 0 is being written twice, LBA 1 is being written twice
in the second instant and LBA 2 is being written twice in the third
instant. Sending a write for an LBA that still has an incomplete
in-flight write against it typically results in unspecified behaviour
- we just don't know what sort of "optimisations" might kick in
because we've created a scenario where we've told the system we can't
care about the result of every write...
Ideas for how to avoid getting into the above scenario with numjobs:
- Have each job work with a *different* file to any other job so they
can't collide. As you suggest you can use directory and let fio make
up the filename so each job is working on a seperate file (filename
must NOT be set!).
- Have each job work on a different part of the same "file" so they
can't collide. This requires some sort of partitioning and if you
choose to do this size
(https://fio.readthedocs.io/en/latest/fio_doc.html#cmdoption-arg-size
) and offset_increment
(https://fio.readthedocs.io/en/latest/fio_doc.html#cmdoption-arg-offset-increment
) may help. Obviously each "region" shouldn't be too small but you get
the idea.
I don't know your circumstances but a part of me wonders if it would
have been easier to just increase iodepth and stick a single job to
get increased simultaneous I/O.
--
Sitsofe
Hi.
Thank you very mush for the commentary.
By adding -offset_increment = x%, I got the same result with -filename
as with -directory.
> job1: | 0 | 1 | 2 | ...
> job2: | 0 | 1 | 2 | ...
> In this case in the first
> "instant" LBA 0 is being written twice, LBA 1 is being written twice
> in the second instant and LBA 2 is being written twice in the third
> instant.
Is this a bug of fio?
I don't understand the purpose of the above operation.
Is there anyone who expects this behavior and measures it?
(Despite -direct=1, Result is far exceeds the physical speed of the HDD)
Thanks.
Nakajima.