shell 生成随机数与随机字符串

一、生成随机数

1、使用系统的 $RANDOM 变量

<br />
[root@361way ~]# echo $RANDOM
14436

2、增加整数实现范围

<span style="color:#E53333;">$RANDOM 的范围是 [0, 32767]</span> ,如需要生成超过32767的随机数,可以用以下方法实现。



<span style="line-height:1.5;">生成40000~50000的随机数</span>



<br />
#!/bin/bash
function rand(){
    min=1
    max=((2-min+1))
    num=((RANDOM+1000000000)) #增加一个10位的数再求余
    echo ((num%max+min))
}
rnd=(rand 40000 50000)
echornd
exit 0

3、使用date +%s%N

<br />
#!/bin/bash
function rand(){
    min=1
    max=((2-min+1))
    num=(date +%s%N)
    echo((num%max+min))
}
rnd=(rand 1 50)
echo $rnd
exit 0
上面的代码执行后会生成1~50的随机数。

4、使用/dev/random 和 /dev/urandom

<span style="color:#E53333;">/dev/random </span>存储着系统当前运行环境的实时数据,是阻塞的随机数发生器,读取有时需要等待。<span style="color:#E53333;">/dev/urandom</span> 非阻塞随机数发生器,读取操作不会产生阻塞。例:使用/dev/urandom生成100~500的随机数,使用urandom避免阻塞。



<br />
#!/bin/bash
function rand(){
    min=1
    max=((2-min+1))
    num=(cat /dev/urandom | head -n 10 | cksum | awk -F ' ' '{print1}')
    echo ((num%max+min))
}
rnd=(rand 100 500)
echornd
exit 0

5、使用date指令生成随机数

<br />
#获得时间戳,当前到:1970-01-01 00:00:00 相隔的秒数
#如果用它做随机数,相同一秒的数据是一样的。在做循环处理,多线程里面基本不能满足要求了。
[root@361way ~]# date +%s
1436453424
#获得当前时间的纳秒数据,精确到亿分之一秒。
#这个相当精确了,就算在多cpu,大量循环里面,同一秒里面,也很难出现相同结果,不过不同时间里面还会有大量重复碰撞
[root@361way ~]# date +%N
825151407
#完美了,加入了时间戳,又加上了纳秒,不过感觉位数太长了些
[root@361way ~]# date +%s%N
1436453442886993284

二、随机字符串的生成

1、使用linux uuid

uuid 全称是通用唯一识别码,格式包含32个16进制数字,以'-'连接号分为5段。形式为8-4-4-4-12 的32个字符。



<br />
[root@361way ~]# cat /proc/sys/kernel/random/uuid
cd4b704d-9937-453b-9a69-12294eba45cc
使用linux uuid 生成100~500随机数:



<br />
#!/bin/bash
function rand(){
    min=1
    max=((2-min+1))
    num=(cat /proc/sys/kernel/random/uuid | cksum | awk -F ' ' '{print1}')
    echo ((num%max+min))
}
rnd=(rand 100 500)
echornd
exit 0

2、date与urandom生成随机串

<br />
#使用date 生成随机字符串
date +%s%N | md5sum | head -c 10
#使用 /dev/urandom 生成随机字符串
cat /dev/urandom | head -n 10 | md5sum | head -c 10
<br />

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注