<div dir="auto">HI Alex.<div dir="auto"><br></div><div dir="auto">I think a reasonable clean approach would be to have a master thread (producer) that sends chunks of packages or file paths to worker threads (consumers) by putting into a global qieue, and they work on them by grabbing chunks of files names from the queueing. That should be reasonably salad load balancing. The processes can report things directly to studio, as it is line buffered and locked, so it should work.<div dir="auto"><div dir="auto"><br></div><div dir="auto">I am pretty sure library to do such worker queues are available for Perl.</div></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, 20 Jan 2021, 12:20 Axel Beckert, <<a href="mailto:abe@debian.org">abe@debian.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Control: severity -1 wishlist<br>
<br>
Hi Witold,<br>
<br>
Witold Baryluk wrote:<br>
> On my 32 core system, and a lot of packages installed (~7000), it takes<br>
> about one hour for the debsum to check all the files. Despite ability to<br>
> read all files from the storage in about 4 minutes.<br>
<br>
Oh, ok. I would have expected the I/O to be the bottleneck.<br>
<br>
> The issue is use of just one thread and most likely not optimized<br>
> md5sum implementation.<br>
<br>
It uses Perl's Digest::MD5 module. <br>
<br>
> I think it would be very useful to be able to specify number of parallel<br>
> threads to use when doing checking manually or from cron.<br>
<br>
Ack. I though don't see that as feature and not really as a bug. Hence<br>
setting the severity to wishlist.<br>
<br>
Also I'm currently not sure how to implement this properly. Splitting<br>
up the list of files or packages to check and then starting debsums<br>
for 1/n of these as a subprocess, gathering the output and merging it?<br>
<br>
Or trying to find a hashing tool which parallelises this for each<br>
package. But then again, this likely will generate extra overhead for<br>
the huge number of small packages and hence might outweight<br>
parallelisation.<br>
<br>
IO::AIO might be a potential solution. There's even an MD5 example in<br>
<a href="https://metacpan.org/pod/IO::AIO" rel="noreferrer noreferrer" target="_blank">https://metacpan.org/pod/IO::AIO</a>, but it focusses huge files to hash<br>
via mmapping and not really on parallelism (I guess).<br>
<br>
> I think it would even be good to enable it by default.<br>
<br>
Not sure about that as it takes a lot of factors more to choose the<br>
right value:<br>
<br>
* Current load of the system<br>
* Installation on what kind of medium? (Spinning disk, SATA SSD, NVMe<br>
SSD, RAID1, etc.)<br>
* Number of threads available in the CPU (of course, too :-)<br>
<br>
> (for the case of use from cron, usage of nice / schedtool and/or<br>
> ionice could mitigate any issues on server or laptops).<br>
<br>
The cron jobs already use ionice if it is installed. :-)<br>
<br>
Regards, Axel<br>
-- <br>
,''`. | Axel Beckert <<a href="mailto:abe@debian.org" target="_blank" rel="noreferrer">abe@debian.org</a>>, <a href="https://people.debian.org/~abe/" rel="noreferrer noreferrer" target="_blank">https://people.debian.org/~abe/</a><br>
: :' : | Debian Developer, <a href="http://ftp.ch.debian.org" rel="noreferrer noreferrer" target="_blank">ftp.ch.debian.org</a> Admin<br>
`. `' | 4096R: 2517 B724 C5F6 CA99 5329 6E61 2FF9 CD59 6126 16B5<br>
`- | 1024D: F067 EA27 26B9 C3FC 1486 202E C09E 1D89 9593 0EDE<br>
</blockquote></div>