linux系统产生随机数的6种方法

linux系统产生随机数的6种方法linux


方法一:经过系统环境变量($RANDOM)实现:

[root@test ~]# echo $RANDOM git

11595 数据库

[root@test ~]# echo $RANDOM 安全

21625 服务器

RANDOM的随机数范围为0~32767,所以,加密性不是很好,能够经过在随机数后增长加密字符串(就是和密码生成有关的字符串)的方式解决,最后再一块儿执行md5sum操做并截取结果的后n位,这样一来,就没法根据随机范围0~32767猜出具体结果了。
示例: 网络

[root@test ~]# echo "$RANDOM"|md5sum|cut -c 5-15 dom

4eaf70019cc 分布式

 

方法二:经过openssl产生随机数,示例:

[root@test ~]# openssl rand -base64 8 ui

yB0maNWRoQw= 编码

令数字与大小写字符相结合,并带上特殊字符,能够达到很长的位数,这样的随机数很安全。

 

方法三:经过时间(date)获取随机数,示例:

[root@test ~]# date +%s%N

1523402619479946400

[root@test ~]# date +%s%N

1523402622015235600


方法四:经过/dev/urandom配合chksum生成随机数:

[root@test ~]# head /dev/urandom|cksum

2866845253 2890

[root@test ~]# head /dev/urandom|cksum

2131526544 2440

/dev/random设备存储着系统当前运行环境的实时数据。它能够看做系统在某个时候的惟一值,所以能够用做随机元数据。咱们能够经过文件读取的方式,读到里面的数据。/dev/urandom这个设备的数据与random里的同样。只是,它是非阻塞的随机数发生器,读取操做不会产生阻塞。

 

方法五:经过UUID生成随机数,示例:

[root@test ~]# cat /proc/sys/kernel/random/uuid

c984eb24-9524-4b07-af80-8b18b5a1b530

[root@test ~]# cat /proc/sys/kernel/random/uuid

28274c2f-c03b-4c6a-9bd2-d20b594972a4

UUID码全称是通用惟一识别码(Universally Unique Identifier,UUID)它是一个软件建构的标准,亦为自由软件基金会的组织在分布式计算环境领域的一部分;
UUID的目的是让分布式系统中的全部元素都能有惟一的辨别信息,而不须要经过中央控制端来作辨别信息的指定,如此一来,每一个人均可以建立不与其余人发生冲突的UUID,在这种状况下,就不须要考虑数据库建立时的名称重复问题了,它会让网络中任何一台计算机所生成的UUID码都是互联网整个服务器网路中惟一的编码。它的原信息会加入硬件、时间、机器当期那运行信息等。

 

方法六:使用expect附带的mkpasswd生成随机数;mkpasswd命令依赖于数据包expect,所以必须经过"yum install expect -y"命令先安装该数据包。示例:

[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -s 1

VxqE}t56o

[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -s 1

W99syAyf;

[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -s 1

snll4LX6<

相关参数说明以下:

    -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;


上面的随机数长短不一,可使用md5sum统一格式:

[root@test ~]# mkpasswd -l 9 -d 2 -c 3 -C 3 -s 1|md5sum|cut -c 2-10

8bbff4c99

[root@test ~]# cat /proc/sys/kernel/random/uuid|md5sum|cut -c 2-10

140edad51

[root@test ~]# head /dev/urandom|cksum|md5sum|cut -c 2-10

6c637bba0

[root@test ~]# date +%s%N|md5sum|cut -c 2-10

9da12f186

[root@test ~]# openssl rand -base64 80|md5sum|cut -c 2-10

d165ada49

[root@test ~]# echo "test$RANDOM"|md5sum|cut -c 2-10

145c845ee

[root@test ~]#

相关文章
相关标签/搜索