On Fri, Jan 18 2013, Jens Axboe wrote: > On Fri, Jan 18 2013, brian arb wrote: > > adding the option --verify_backlog=1024 resolved my issue. > > On a side note how would one determine what the optimum number is for this > > option? > > It's easier if you know the internals... The version you are running > will store some metadata for each block written, for verification > purposes. Standard install is 80 bytes per block. So if you have a 2TB > disk and use 4K IO sizes, the memory required runs into the gigabytes. > Quite unfortunate, really, will be fixed up shortly. > > In any case, with a backlog of just 1024, you wont use more than 80KB > memory for verifies. So you could easily size it larger. I'd improve the > option documentation, but I think it's better to just improve fio to not > require the stored meta data to be able to verify. It will be in the > 2.0.14 release. Current -git has it implemented. If you do your normal verify workload but add --experimental_verify=1 to the options, it wont track meta data needed for verify, but rather just re-wind the various attributes to replay the workload for read and verify instead. Just tested it on one box here, bringing the needed memory down for a job from 25G to 1M. The worst part about the verify memory consumption was the slowly growing job, meaning that it could have the OOM consequences that you described for long running jobs. No allocations are taking place for IO when experimental_verify is set now. Side note, this doesn't work for mixed write/trim workloads for now. We need a bit of extra tracking for that. -- 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