Skip to content
This repository has been archived by the owner on Nov 30, 2023. It is now read-only.
/ fastrandom Public archive

A shell tool to generate random bytes extremely fast e.g. for SSD scrubbing.

Notifications You must be signed in to change notification settings

Tronic/fastrandom

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 

Repository files navigation

ARCHIVED

There is a new similar tool RandQuik that performs even faster and that produces repeatable streams as well. Please use that instead.

FastRandom

A shell tool to generate random bytes extremely fast. Uses multiple CPU cores and both AES-NI and ChaCha20 to facilitate even higher utilisation of processing capacity. The output may be used for scrubbing disks, even the fastest NVME SSDs, or for any other purpose where large amounts of irreproducible random bytes are needed.

Prefer redirection > instead of pipes and dd for maximal speed. This works with both files and block devices.

pip install fastrandom
fastrandom -p > /tmp/file.dat    # -p for progress indication
[fastrandom]     15,451 MiB generated at 3.48 GB/s
[Errno 28] No space left on device

This tool is about 30 % faster than the best contender that I am aware of, openssl enc -aes-256-ctr -in /dev/zero, many times faster than any popular random number generator (like PCG64) and about 50 times faster than /dev/urandom. Generating to /dev/null I can reach 11 GB/s on a six-core CPU but any actual devices that I have access to, including NVME 4.0 SSDs and even ramdisks, are slower. Please drop a Github issue if you find something faster.

About

A shell tool to generate random bytes extremely fast e.g. for SSD scrubbing.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages