我需要从一个shell脚本生成一个2000-65000之间的随机端口号。问题是$RANDOM是一个15位的数字,所以我被卡住了!
如果没有大小限制,PORT=$(($RANDOM%63000+2001))将很好地工作。
有没有人有一个例子,我可以这样做,也许从/dev/urandom提取一些东西,并得到它在一个范围内?
我需要从一个shell脚本生成一个2000-65000之间的随机端口号。问题是$RANDOM是一个15位的数字,所以我被卡住了!
如果没有大小限制,PORT=$(($RANDOM%63000+2001))将很好地工作。
有没有人有一个例子,我可以这样做,也许从/dev/urandom提取一些东西,并得到它在一个范围内?
当前回答
shuf -i 2000-65000 -n 1
享受吧!
编辑:范围是包括在内的。
其他回答
或在OS-X以下工作为我:
$ gsort --random-sort
这就是我通常生成随机数的方法。然后我使用“NUM_1”作为我使用的端口号的变量。下面是一个简短的示例脚本。
#!/bin/bash
clear
echo 'Choose how many digits you want for port# (1-5)'
read PORT
NUM_1="$(tr -dc '0-9' </dev/urandom | head -c $PORT)"
echo "$NUM_1"
if [ "$PORT" -gt "5" ]
then
clear
echo -e "\x1b[31m Choose a number between 1 and 5! \x1b[0m"
sleep 3
clear
exit 0
fi
生成范围为[$floor,$ceil]的随机数,不依赖:
$(((RANDOM % $(($ceil- $floor))) + $floor))
在2000到65000之间生成100个数字:
for i in $(seq 100); do echo $(((RANDOM % $((65000 - 2000))) + 2000));done
如果您不是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的区别
请随意改进这个答案。