You're copying a lot of stuff in same time and computer performance just dies. Try for example to copy 10+ ISO images same time.
There's QoS in networking, affinities and priorities in CPUs, but is there anything for hard drives to throttle I/O queues? Virtual filesystems? OS drivers?
Of course you can go around with this with for example
- Making list of files to copy and running script which copies files one by one
- Using software like TeraCopy
Windows and GNU/Linux solutions are welcome.
For Linux there's ionice, Windows has IO priorities since quite some time, but at least since Vista it's also fully available in a sane implementation for Workstations.
At a lower level, Linux (and I assume Windows, and *BSD, and everything else in serious use) has an IO scheduler that tries to balance the best overall utilization of each device with providing good service to each process. Linux's current default scheduler is known as Completely Fair Queueing, with the current generally available alternatives being called Anticipatory and Deadline.
On a somewhat related note, the program iotop is useful for monitoring and examining what's going on in a system under heavy IO load.
ionice only works with the CFQ scheduler, which is usually the default. If you are using another scheduler or if ionice isn't doing the job for you, you might want to periodically pause execution to let your io buffers flush. Here is a script we use for that:
Interestingly, there's been recent talk about implementing QoS for block devices on LKML.
There's a nice write up on the ever excellent LWN.net: Block device bio throttling support [V3]
on Linux ionice let's you prioritize IO, but falls somewhat short. there's dm-ioband which should be a lot more powerful; but i still don't feel comfortable with the docs....