Respostas:
O método de preenchimento zero (modificado aqui para evitar possíveis gargalos de memória ) levou 17 segundos para criar um arquivo de 10 GB em um SSD e fez com que a interface gráfica do Ubuntu não respondesse.
$ time sh -c 'dd if=/dev/zero iflag=count_bytes count=10G bs=1M of=large; sync'
10240+0 records in
10240+0 records out
10737418240 bytes (11 GB, 10 GiB) copied, 17.2003 s, 624 MB/s
real 0m17.642s
user 0m0.008s
sys 0m9.404s
$ du -B 1 --apparent-size large
10737418240 large
$ du -B 1 large
10737422336 large
fallocate cria arquivos grandes instantaneamente, manipulando diretamente o espaço em disco alocado do arquivo:
$ time sh -c 'fallocate -l 10G large; sync'
real 0m0.038s
user 0m0.000s
sys 0m0.016s
$ du -B 1 --apparent-size large
10737418240 large
$ du -B 1 large
10737422336 large
O truncado também funciona instantaneamente e cria arquivos esparsos que não consomem espaço em disco real até que os dados sejam gravados posteriormente:
$ time sh -c 'truncate -s 10G large; sync'
real 0m0.014s
user 0m0.000s
sys 0m0.004s
$ du -B 1 --apparent-size large
10737418240 large
$ du -B 1 large
0 large
Uma maneira fácil seria usar o dd
comando para escrever um arquivo cheio de zeros.
dd if=/dev/zero of=outputFile bs=2G count=1
Use G no argumento de tamanho se desejar gigabytes de computador (1024 * 1024 * 1024) ou GB se desejar gigabytes humanos (1000 * 1000 * 1000).
/dev/urandom
nesse caso (é sem bloqueio, mas não é garantido que tenha o mesmo nível de aleatoriedade). Desenhar 2 GB de qualquer um deles quase certamente esgotará completamente a entropia do sistema, portanto, não faça nada criptográfico por um tempo depois.
ftp://ftp.fsf.hu/testfiles/maketestfiles.sh
ou Procurar é o tamanho do arquivo que você deseja em bytes - 1.
dd if=/dev/zero of=filename.big bs=1 count=1 seek=1048575 # 1 MByte
dd if=/dev/zero of=filename.big bs=1 count=1 seek=10485759 # 10 MByte
dd if=/dev/zero of=filename.big bs=1 count=1 seek=104857599 # 100 MByte
dd if=/dev/zero of=filename.big bs=1 count=1 seek=1073741823 # 1024 MByte
dd if=/dev/zero of=filename.big bs=1 count=1 seek=42949672959 # 40960 MByte
dd ... bs=2G count=1
lê 2 GB na memória (em umaread(2)
chamada). Se você tem pressão de memória, provavelmente não é esse o caminho. Mais, blocos menores podem ser mais rápidos se isso significa menos paginação.