Teste de desempenho com números primos em BASH
Publicado por Andre Miguel (última atualização em 06/01/2010)
[ Hits: 8.170 ]
Certo dia me deparei com um bottom brincalhão que dizia: "Digite qualquer número primo de 11 dígitos para continuar". Fiquei com vontade de saber se havia tal número.
Então fiz um shellzinho para testar. Primeiros 10, beleza; primeiros 100, beleza, primeiros 1000, já não estava mais tão rápido. Percebi a oportunidade de utilizar este script como benchmark de desempenho entre servidores, sejam de mesmo hardware ou não.
Quando você executar, pode demorar a aparecer alguma coisa na tela, mas ele está rodando. Pode verificar com strace ou truss (Solaris).
Após você testar e tiver a coragem de descomentar a linha do 10000000000, me poste aqui os números primos que você achou!
Dica: para temporizar a execução, utilize a linha abaixo:
$ bash primo.sh 2>&1 |egrep 'Primo|real' |awk '{if ($2 ~ /s/){split($2,minsplit,"m");min+=minsplit[1];seg+=substr($2,3,5);}else{print min,seg; print $0; min=seg=0; }}'
Você deverá ter uma saída como esta:
0 0.1
Primo: 11
0 0.248
Primo: 13
0 0.587
Primo: 17
#for (( i=10000000000; i<= 999999999999; i++)); do for (( i=10; i<= 999; i++)); do j=$i; primo=0; time cat <<-EOF $(for (( j=$i; j>=1; j--)); do if [ `echo $((i%j))` -eq 0 ]; then ((primo++)); if [ $primo -gt 2 ]; then j=1; else if [ $primo -eq 2 ] && [ $j -eq 1 ]; then echo "Primo: $i"; fi fi fi; done;) EOF done
package maker para o slackware
Script gera uma chave md5 de todos os arquivos que forem especificados
Instalador do emulador de joystick Xbox para joystick generico para PC, PS2, PS3 (Debian e Derivados
Aplicando layer7 sem digitar uma linha de código sequer
Servidor de Backup com Ubuntu Server 24.04 LTS, RAID e Duplicati (Dell PowerEdge T420)
Visualizar câmeras IP ONVIF no Linux sem necessidade de instalar aplicativos
Atualizar Debian Online de uma Versão para outra
Dica para encontrar diversos jogos Indies criativos
Instalando Discord no Debian 13
Instalar driver Nvidia no Debian 13
Redimensionando, espelhando, convertendo e rotacionando imagens com script
Falha add cluster Proxmox (2 nós) (2)
Software livre - será que eu estou tão errado assim? (18)
O que você está ouvindo agora? [2] (218)
Dificuldade com Ocs 2.12.3 no Debian 13 com Apache2 - Can't load ... (4)