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 ~]#

相關文章
相關標籤/搜索