生成随机数的方法有7种
1.通过时间获取随机数
1)date +%s (随机生成10位数字)
用于获得时间戳。
如果用它做随机数,相同一秒的数据是一样的。在做循环处理,多线程里面基本不能满足要求了。
2)date +%N (随机生成9位数字)
获得当前时间的纳秒数据,精确到亿分之一秒。
这个在同一秒里面,也很难出现相同结果,不过不同时间里面还会有大量重复碰撞
额外扩展:date +%s%N (随机生成19位数字)
2.通过系统环境变量($RANDOM)
echo $RANDOM (随机生成5位数字)(范围0~32767)
echo “$RANDOM”|md5sum|cut -c 5-14(随机生成10个字符的字符串)
3.通过系统内部唯一数据生成随机数(/dev/urandom)
head /dev/urandom|cksum (9位,4位,如果用cat或more则虚拟机会自动打开打印机,cksum是用来解决乱码的)。
cksum 将读取文件内容,生成唯一的表示整型数据,只有文件内容不变,生成结果就不会变化,与php crc函数。
4.通过opensssl产生随机数
rand -base64 10(表示10位字符串)。
只有当位数为3的倍数时,后面才会没有等号。
5.通过UUID生成随机数
cat /proc/sys/kernel/random/uuid 或 uuidgen。
UUID码全称是通用唯一识别码(Universally Unique Identifier,UUID)它是一个软件建构的标准,亦为自由软件基金会的组织在分布式计算环境领域的一部分;
UUID的目的是让分布式系统中的所有元素都能有唯一的辨别信息,而不需要通过中央控制端来做辨别信息的指定,如此一来,每个人都可以创建不与其他人发生冲突的UUID,在这种情况下,就不需要考虑数据库创建时的名称重复问题了,它会让网络中任何一台计算机所生成的UUID码都是互联网整个服务器网路中唯一的编码。它的原信息会加入硬件、时间、机器当期那运行信息等。
指定长度:uuidgen|md5sum|cut -c 2-10(8位长的字符串)
6.mkpaswd
mkpasswd(默认产生9位的字符串,其中数字固定位2位,特殊字符固定位1位,其余都是字母)。
相关参数:
-l (length of password, default = 9) :指定密码长度;
-d (min # of digits, default = 2) :指定密码中数字的数量;
-c (min # of lowercase chars, default = 2) :指定密码中小写字母的数量;
-C (min # of uppercase chars, default = 2) :指定密码中大写字母的数量;
-s (min # of special chars, default = 1) :指定密码中特殊字符的数量;
-p prog (program to set password, default = /bin/passwd) :程序设置密码,默认是passwd;
7.mktemp
/tmp/tmp.**********(10位长的字符串)。
这是一个比较特殊的随机数,它有指定的目录/tmp。
如果在创建文件时引用此命令,那么它会自动在/tmp目录下产生文件。