我需要从一个shell脚本生成一个2000-65000之间的随机端口号。问题是$RANDOM是一个15位的数字,所以我被卡住了!

如果没有大小限制,PORT=$(($RANDOM%63000+2001))将很好地工作。

有没有人有一个例子,我可以这样做,也许从/dev/urandom提取一些东西,并得到它在一个范围内?


当前回答

这是一个用Python写的

randport=$(python -S -c "import random; print random.randrange(2000,63000)")

还有一个是awk

awk 'BEGIN{srand();print int(rand()*(63000-2000))+2000 }'

其他回答

根据bash手册页,$RANDOM分布在0到32767之间;也就是说,它是一个无符号的15位值。假设$RANDOM是均匀分布的,可以创建一个均匀分布的30位无符号整数,如下所示:

$(((RANDOM<<15)|RANDOM))

因为你的范围不是2的幂,一个简单的模运算几乎只能给你一个均匀的分布,但如果输入范围是30位,输出范围小于16位,就像你的例子一样,这应该足够接近了:

PORT=$(( ((RANDOM<<15)|RANDOM) % 63001 + 2000 ))

我能想到的最简单的方法是perl一行代码:

perl -e 'print int(rand(65000-2000)) + 2000'

你可以用两个数字:

PORT=$(($RANDOM + ($RANDOM % 2) * 32768))

你还是得在你的范围内。这不是一般的n位随机数方法,但它适用于您的情况,并且都在bash中。

如果你想非常可爱地阅读/dev/urandom,你可以这样做:

od -A n -N 2 -t u2 /dev/urandom

它会读取两个字节,并将它们作为unsigned int输出;你还是得剪。

如果您不是bash专家,并希望将此转换为基于linux的bash脚本中的变量,请尝试以下方法:

VAR=$(shuf -i 200-700 -n 1)

这样算上VAR,你的投资范围在200到700美元之间。

如果你需要大于15位的范围,不要使用慢的不安全的过时的15位RANDOM,使用快速安全的32位SRANDOM。

SRANDOM自2021年bash 5.1推出以来可用。

Bash 5.1中值得注意的一个有趣的添加是新的SRANDOM变量。SRANDOM变量提供来自系统熵引擎的随机数据,不能被重新播种。特别是,SRANDOM变量提供了一个32位随机数,它依赖于getrandom/getentropy——如果必要的话,还可以回退到/dev/urandom或arc4random,甚至在此之后的另一个回退。”

来源:https://www.phoronix.com/news/gnu - bash - 5.1

看看bash中的RANDOM和SRANDOM有什么不同:

Bash中RANDOM和SRANDOM的区别

请随意改进这个答案。

你可以通过urandom得到随机数

Head -200 /dev/urandom | cksum

输出:

3310670062 52870

检索上述数字的一部分。

Head -200 /dev/urandom | cksum | cut -f1 -d " "

那么输出是

3310670062

为了满足您的要求,

Head -200 /dev/urandom |cksum | cut -f1 -d " " | awk '{print $1%63000+2001}'