One-liner
Eu criei um bom one-liner que atende rapidamente ao propósito, permitindo capturar um número arbitrário de portas em um intervalo arbitrário (aqui ele é dividido em 4 linhas para facilitar a leitura):
comm -23 \
<(seq "$FROM" "$TO") \
<(ss -tan | awk '{print $4}' | cut -d':' -f2 | grep '[0-9]\{1,5\}' | sort -n | uniq) \
| shuf | head -n "$HOWMANY"
Linha por linha
comm
é um utilitário que compara linhas classificadas em dois arquivos. Ele gera três colunas: linhas que aparecem apenas no primeiro arquivo, linhas que aparecem apenas no segundo e linhas comuns. Especificando -23
, suprimimos as últimas colunas e apenas mantemos a primeira. Podemos usar isso para obter a diferença de dois conjuntos, expressos como uma sequência de linhas de texto. Aprendi sobre comm
aqui .
O primeiro arquivo é o intervalo de portas que podemos selecionar. seq
produz uma sequência classificada de números de $FROM
a $TO
. O resultado é canalizado para comm
como o primeiro arquivo usando substituição de processo .
O segundo arquivo é a lista classificada de portas, que obtemos chamando o comando ss
(com -t
significando portas TCP, -a
significando todo - estabelecido e escutando - e -n
numérico - don ' t tente resolver, digamos, 22
to ssh
). Em seguida, escolhemos apenas a quarta coluna com awk
, que contém o endereço e a porta locais. Usamos cut
para dividir endereço e porta com o delimitador :
e manter apenas o último ( -f2
). ss
também gera um cabeçalho, pelo qual nos livramos de grep
ping para sequências não vazias de números que não são maiores do que 5. Então, cumprimos o requisito de comm
em sort
ing numericamente ( -n
) e se livrando de duplicatas com uniq
.
Agora, temos uma lista classificada de portas abertas, que podemos usar shuf
para, em seguida, pegar as primeiras "$HOWMANY"
com head -n
.
Exemplo
Pegue as três portas abertas aleatórias no intervalo privado (49152-65535)
comm -23 <(seq 49152 65535) <(ss -tan | awk '{print $4}' | cut -d':' -f2 | grep "[0-9]\{1,5\}" | sort | uniq) | shuf | head -n 3
poderia retornar por exemplo
54930
57937
51399
Notas
- altere
-t
com -u
em ss
para obter portas UDP gratuitas.
- solte
shuf
se você não estiver interessado em pegar uma porta aleatória