On 03/04/2016 05:47 PM, Vladislav Bolkhovitin wrote:
Jens Axboe wrote on 03/04/2016 07:33 AM:
On 03/03/2016 09:37 PM, Vladislav Bolkhovitin wrote:
Jens Axboe wrote on 03/03/2016 08:20 AM:
On Thu, Mar 03 2016, Sitsofe Wheeler wrote:
On 3 March 2016 at 03:03, Vladislav Bolkhovitin <vst@xxxxxxxx> wrote:
For those who asked about perf profiling, it remained the same as before with the CPU
consumption is all about timekeeping and memset:
- 55.74% fio fio [.] clock_thread_fn
clock_thread_fn
Perhaps this is what is already included above but could you use the
-g option on perf to collect it into a call-graph and post the top
results?
The above looks like a side effect of using gtod_cpu, it'll burn one
core. For the original poster - did you verify whether using gtod_cpu
was faster than using the CPU clock source in each CPU?
Yes, I had verified it and mentioned in one of my reports. It slightly decreased the
IOPS. I guess, it's a locking contention somewhere.
For clocksource=cpu there is no internal fio contention, nor can there be any kernel/OS
contention. Getting the clock is serializing, so that might slow things down a bit.
Yes. Also, there might be a cache contention here, with one thread writing to a memory
location and multiple threads reading from it. The same type of contention why queue
spinlocks are faster, than ticket spinlocks.
But cacheline contention for the clock part would be bigger with
gtod_cpu, since you have one CPU continually dirtying that cachline and
the CPUs with jobs running on them reading it. With clocksource=cpu,
that part would not share data.
I've seen you bring up this contention idea before.
Yes, it was when I forgot to short circuit lseek calls in the sync engine. Usually, if
you see performance dropping from certain number of threads, it is safe to guess there
is a lock contention somewhere.
That is true, the lseek() part is not in fio though, that's a kernel
issue. But for this case, avoiding lseek through one of the sync
variants with offset is the best solution. Might actually makes sense to
make that the default.
Is that pure guesswork on your end, or have you profiled any contention?
Pure guesswork. I'm looking at fio in details only few days, so it is still pretty much
a black box for me. Generally, if you see performance drop with another thread, it must
be either locks contention, or communication overhead. Nowadays the former is more
common, hence the guess.
Right, but that contention can be anywhere from the application to the
driver. So some more details would be great, when you have them.
One thing I've seen for higher IOPS cases is that the bdev inode inc/dec
for every IO, that hurts scalability. That was fixed here:
http://git.kernel.dk/cgit/linux-block/commit/?id=fe0f07d08ee35
but you might already be running a kernel with that included (what are
you running?). Another one is the io stats collected, that tends to
cause poorer scaling than you would expect, you can turn that off
through sysfs (/sys/block/<dev>/queue/iostats).
--
Jens Axboe
--
To unsubscribe from this list: send the line "unsubscribe fio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html