婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Linux Shell 生成隨機數和隨機字符串的方法示例

Linux Shell 生成隨機數和隨機字符串的方法示例

熱門標簽:同花順電話機器人微信 外呼系統的合法性 北京電銷機器人對市場的影響 輝縣市地圖標注 湖北孝感如何辦理 房產證地圖標注的兩個面積 威海電銷外呼系統好用嗎 地圖標注x是啥意思 武漢語音電銷機器人加盟

日常生活中,會經常用到隨機數,使用場景非常廣泛,例如買彩票、丟骰子、抽簽、年會抽獎等。

Shell 下如何生成隨機數呢,米撲博客特意寫了本文,總結 Linux Shell 產生隨機數的多種方法。

計算機產生的的只是“偽隨機數”,不會產生絕對的隨機數(是一種理想隨機數)。實際上,偽隨機數和理想隨機數也是相對的概念,例如偽隨機數在1萬萬億億億年內也無法重復,算是理想隨機數么?

偽隨機數在大量重現時也并不一定保持唯一,但一個好的偽隨機產生算法將可以產生一個非常長的不重復的序列,例如 UUID(通用唯一識別碼)在100億年內才可用完。

 1. 使用系統的 $RANDOM 變量(CentOS、Ubuntu、MacOS 都支持,但只有5位數隨機)

mimvp@ubuntu:~$ echo $RANDOM
17617

$RANDOM 的范圍是 [0, 32767]

示例:使用 for 循環來驗證:

#!/bin/bash
# mimvp.com 2016.05.10

function print_random() {
  for i in {1..10};
  do
    echo -e "$i \t $RANDOM"
  done
}

print_random

運行結果:

# sh mimvp_shell_rand.sh
1        20191
2        16817
3        25971
4        1489
5        34
6        25183
7        920
8        315
9        18845
10       29519

如需要生成超過32767的隨機數,可以用以下方法實現(有缺陷

例:生成 40,000,000~50,000,000 的隨機數,但最后末尾五位數在隨機變化,實現原理有缺陷

#!/bin/bash
# mimvp.com 2016.05.10

## Linux 系統隨機數 + 范圍上限值后, 再取余
function mimvp_random_bignum() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(($RANDOM+$max))    # 隨機數+范圍上限, 然后取余
  randnum=$(($num%$mid+$min)) # 隨機數包含上下限邊界數值
  echo $randnum
}

function print_random_bignum() {
  for i in {1..10};
  do
    bignum=$(mimvp_random_bignum 40000000 50000000)
    echo -e "$i \t $bignum"
  done
}

print_random_bignum

運行結果:

# sh mimvp_shell_rand.sh 
1        40022422
2        40014261
3        40022712
4        40016695
5        40026575
6        40032198
7        40026667
8        40016024
9        40012010
10       40016143 

這里,還可以通過 awk 產生隨機數,最大為6位隨機數,其跟時間有關,系統時間一致則隨機數都相同,沒有 $RANDOM 隨機性好

# awk 'BEGIN{srand(); print rand()}'    
0.739505
# awk 'BEGIN{srand(); print rand()*1000000}'
855767

2. 使用date +%s%N(CentOS、Ubuntu支持,MacOS不支持納秒 +%N)

通過 Linux / Unix 的時間戳來獲取隨機數

# date +%S  # 獲取秒數, 2位數
43
# date +%s  # 獲取時間戳, 10位數, 從 1970-01-01 00:00:00 到當前的間隔的秒數
1548739004
# date +%N  # 獲取納秒值, 9位數, CentOS、Ubuntu支持, 但 MacOS 不支持
468529240

說明:

如果用時間戳 date +%s 做隨機數,相同一秒的數據是一樣的。在做循環處理多線程時,基本不能滿足要求

如果用納秒值 date +%N 做隨機數,精度達到了億分之一,相當精確了,在多cpu高并發的循環里,同一秒里也很難出現相同結果,不過也會有重復碰撞的可能性

如果用時間戳+納秒值 date +%N%s 做組合隨機數(10+9=19位數),則比較完美了,重復的概率大大降低,但注意: MacOS 系統不支持納秒值,不算通用 

示例:生成 40,000,000~50,000,000 的隨機數

#!/bin/bash
# mimvp.com 2016.05.10

## Linux 時間戳隨機數
function mimvp_randnum_date() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(date +%s%N | cut -c1-17)   # 19位數, 截取第1-17位數, 下標從1開始
  randnum=$(($num%$mid+$min))     # 隨機數包含上下限邊界數值
  echo $randnum
}

function print_randnum_date() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_date 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}

print_randnum_date

運行結果:

# sh mimvp_shell_rand.sh 
1        42153680
2        42199904
3        42243885
4        42283556
5        42332691
6        42376578
7        42422048
8        42462640
9        42505483
10       42550221

說明:

上面的結果可以看到,當取大數值范圍時,高位可能都是相同的,原因是 date +%N%s 是按照 秒數+納秒 獲取的,時間高位具有順序位,可能相同

那么,有的同學問題,能不能把 date +%s%N 的秒數和納秒互換下,答案是不可以的,原因是納秒的第一位可能為0,從第一位截取可能為 09641524615487432 ,shell 會提示錯誤: value too great for base (error token is "09641524615487432")

改進的辦法1:互調 date +%N%s (仍然不行):

既然第一位不能為0,那么從納秒的第2位、第3位.... 截取不行嗎,答案也是不可以的,因為納秒的每一位都有可能是0,畢竟納秒是9位數(毫秒3位數、微秒6位數、納秒9位數)納秒本身就在秒數之后,所以納秒的9位數的每一位都可以為0  另外,納秒在高位,秒數在低位,截取大數值可能導致高位不相同,但低位數值相同的情況,原因是秒數的值變化非常慢。結論,互換的辦法是行不通的,還可能導致新的問題,因此,老老實實的用  date +%s%N 格式吧

改進的方法2:直接用 date +%s%N 的19位數(可行

不要截取 date +%s%N | cut -c1-17 ,充分利用納秒的快速變化后再取余

3. 使用 /dev/random 和 /dev/urandom 隨機文件(CentOS、Ubuntu、MacOS 都支持,推薦)

/dev/random 是阻塞的隨機數發生器,讀取有時需要等待。存儲著系統當前運行環境的實時數據,如 CPU、內存、電壓、物理信號等

/dev/urandom 是非阻塞隨機數發生器,讀取操作不會產生阻塞。

說明:

/dev/random 和 /dev/urandom 存儲的都是亂碼,實際上它們是通過二進制數據保存實時數據的

打開 /dev/random 和 /dev/urandom 文件,推薦用 head,不推薦 cat 命令,因為文件非常大且是亂碼,只需要獲取前幾行文件內容就變了

用到了 cksum 命令,其讀取文件內容,生成唯一的整型數據,只有文件內容沒變,生成結果就不會變化,與php crc函數類似,一般校驗文件是否篡改

其生成隨機數的原理是:截取文件的一部分內容,做內容的計算,取第一個數值

# head -20 /dev/urandom | cksum
3535024891 50260
# head -20 /dev/urandom | cksum | cut -f1 -d " "
1713554848

示例:使用/dev/urandom生成 40,000,000~50,000,000 之間的隨機數,使用 /dev/urandom 避免阻塞。

#!/bin/bash
# mimvp.com 2016.05.10

## Linux 隨機文件
function mimvp_randnum_file() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(head -n 20 /dev/urandom | cksum | cut -f1 -d ' ')
#  num=$(head -n 20 /dev/urandom | cksum | cut -d ' ' -f1)       # ok
#  num=$(head -n 20 /dev/urandom | cksum | awk '{print $1}')      # ok
#  num=$(head -n 20 /dev/urandom | cksum | awk -F " " '{print $1}')  # ok
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_file() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_file 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}

print_randnum_file

運行結果:

# sh mimvp_shell_rand.sh 
1      48894638
2      43078483
3      41678948
4      48987680
5      46095205
6      49650777
7      47144679
8      49003259
9      44562068
10     42014734

由此可見,用隨機文件生成的隨機數,基本是全隨機的,且通用于 CentOS、Ubuntu、MacOS

4. 使用 linux uuid (CentOS、Ubuntu支持,MacOS不支持)

UUID(Universally Unique Identifier,通用唯一識別碼),格式包含32個16進制數字,以'-'連接號分為5段。

格式為 8-4-4-4-12 的32個字符,例如: 07e73165-1196-4194-98bb-a3bf7c96e34a

# cat /proc/sys/kernel/random/uuid
07e73165-1196-4194-98bb-a3bf7c96e34a

UUID 數量,理論上的總數為216 x 8=2128,約等于3.4 x 1038。 也就是說若每奈秒產生1兆個UUID,要花100億年才會將所有UUID用完。

UUID 目的,是讓分布式系統中的所有元素,都能有唯一的辨識信息,而不需要通過中央控制端來做辨識信息的指定。如此一來,每個人都可以創建不與其它人沖突的 UUID。在這樣的情況下,就不需考慮數據庫創建時的名稱重復問題。它會讓網絡任何一臺計算機所生成的uuid碼,都是互聯網整個服務器網絡中唯一的。它的原信息會加入硬件,時間,機器當前運行信息等等。

UUID 格式:包含32個16進位數字,以“-”連接號分為五段,形式為8-4-4-4-12的32個字符。范例;550e8400-e29b-41d4-a716-446655440000  ,所以:

與 uuid類似的還有一個guid(全局唯一標識符)碼,它由微軟支持,它們由操作系統內核產生。

示例:使用 linux uuid 生成 40,000,000~50,000,000 之間的隨機數

#!/bin/bash
# mimvp.com 2016.05.10

## Linux uuid
function mimvp_randnum_uuid() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(head -n 20 /proc/sys/kernel/random/uuid | cksum | cut -f1 -d ' ')
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_uuid() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_uuid 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}

print_randnum_uuid

運行結果:

# sh mimvp_shell_rand.sh 
1      44736535
2      43538760
3      40133914
4      41016814
5      49148972
6      40179476
7      48147712
8      45665645
9      40522150
10     44361996

5. 使用 openssl rand (CentOS、Ubuntu支持、MacOS 都支持,需安裝 openssl,推薦)

openssl rand 用于產生指定長度個bytes的隨機字符

# openssl rand --help
Usage: rand [options] num
where options are
-out file       - write to file
-engine e       - use engine e, possibly a hardware device.
-rand file:file:... - seed PRNG from files
-base64        - base64 encode output
-hex         - hex encode output

其中,參數 -base64 或 -hex 對隨機字符串進行base64編碼或用hex格式顯示

結合 cksum 產生整數、md5sum 產生字符串,可以產生隨機的整數或字符串(僅含小寫字母和數字)

例如:

# openssl rand -base64 8   # 第一次執行
Vt4MNFIfzCU=
# openssl rand -base64 8   # 第二次執行, 隨機數不同
uwnovaLKhek=
# openssl rand -base64 8 | cksum  # 生成隨機整數
3663376449 13
# openssl rand -base64 8 | md5sum   # 生成隨機字符串
1f36cf340e0a90ccb0d504925c3d7ada -
# openssl rand -base64 8 | cksum | cut -c1-8 # 截取數字
15997092
# openssl rand -base64 8 | md5sum | cut -c1-8 # 截取字符串
f1a972ce

# openssl rand -hex 8   # 第一次執行
c5bc62152bddadfb
# openssl rand -hex 8   # 第二次執行, 隨機數不同
156642181b22306a
# openssl rand -hex 8 | cksum  # 生成隨機整數
3663376449 13
# openssl rand -hex 8 | md5sum   # 生成隨機字符串
1f36cf340e0a90ccb0d504925c3d7ada -
# openssl rand -hex 8 | cksum | cut -c1-8 # 截取數字
15997092
# openssl rand -hex 8 | md5sum | cut -c1-8 # 截取字符串
f1a972ce

示例:使用 openssl rand 生成 40,000,000~50,000,000 之間的隨機數

#!/bin/bash
# mimvp.com 2016.05.10

## 5. Linux openssl
function mimvp_randnum_openssl() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(openssl rand -base64 8 | cksum | cut -f1 -d ' ')   # -base64
#  num=$(openssl rand -hex 8 | cksum | cut -f1 -d ' ')    # -hex
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_openssl() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_openssl 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}

print_randnum_openssl

運行結果:

# sh mimvp_shell_rand.sh
1      43422505
2      40756492
3      45087076
4      43882168
5      47105153
6      45505018
7      41411938
8      48662626
9      47508094
10     41362566

6. 自定義數組生成隨機數

自定義一個數組,用于生成一段特定長度(整數最長為18位)的有數字和字母組成的字符串,字符串中元素取自自定義的池子。

array=(0 1 2 3 4 5 6 7 8 9) # 自定義一個數字數組

num=${#array[*]} # 獲取數組的長度(元素個數)

randnum=${array[$((RANDOM%num))]}  # 利用Linux系統默認的 $RANDOM 隨機數,隨機從數組選擇一個元素,構成新的長度數組

示例:自定義數組生成 40,000,000~50,000,000 之間的隨機數(注釋有點不好看,但非常有助于理解代碼哈)

#!/bin/bash
# mimvp.com 2016.05.10

## 6. custom array, 可以生成整數, 字符串
function mimvp_randnum_array() {
  NUM_LENGTH=18    # 整數的位數, 依據取值范圍設定, 默認最長為18位整數(取決于正整數的范圍)
  STR_ARRAY=(0 1 2 3 4 5 6 7 8 9 a b c d e f g h i j k l m n o p q r s t u v w x y z A B C D E F G H I J K L M N O P Q R S T U V W X Y Z)   # 生成字符串
  STR_ARRAY=(0 1 2 3 4 5 6 7 8 9)   # 生成整數

  str_array_count=${#STR_ARRAY[@]}  # 字符串數組的元素個數, 62 = 10 + 26 + 26
#  echo "str_array_count: ${str_array_count}"

  i=1
  while [ "$i" -le "${NUM_LENGTH}" ];
  do
    randnum_array[$i]=${STR_ARRAY[$((RANDOM%str_array_count))]}
    let "i=i+1"
  done
  randnum_array_count=${#randnum_array[@]}
#  echo "randnum_array_count: ${randnum_array_count}" # NUM_LENGTH 的長度: 18
#  echo "randnum_array: ${randnum_array[@]}"      # 打印出全部數組元素, 如 B 2 y t z K c Z s N l 9 T b V w j 6

  num='1'       # 整數首位不能是0, 因此直接固定為1, 防止整數時首位為0的異常錯誤
  for item in ${randnum_array[@]};
  do
    num="${num}${item}"
  done
#  echo "num: $num"  # 1B2ytzKcZsNl9TbVwj6 

  min=$1
  max=$2
  mid=$(($max-$min+1))
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_array() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_array 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}

print_randnum_array

運行結果:

# sh mimvp_shell_rand.sh 
1      48952205
2      43220726
3      45241774
4      45758327
5      43147638
6      44319391
7      46834434
8      41601915
9      48687238
10     45029848

7. 生成隨機字符串

上述所有可以生成隨機整數的方法,都可以生成隨機字符串,原理是對隨機整數進行 md5sum 計算

示例:生成10位隨機字符串

# 使用date 生成隨機字符串
date +%s%N | md5sum | head -c 10

# 使用 /dev/urandom 生成隨機字符串
cat /dev/urandom | head -n 10 | md5sum | head -c 10

隨機數應用一

隨機生成端口號范圍為 1025 ~ 65536 (通用于 CentOS, Ubuntu, MacOS),并支持排除任意添加的端口號

應用的隨機數是 方法3. 使用 /dev/random 和 /dev/urandom 隨機文件

應用代碼:

#!/bin/bash
# mimvp.com 2016.05.10

## 應用一: 隨機生成端口號 1025 ~ 65536 (通用于 CentOS, Ubuntu, MacOS)
function mimvp_app_port() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(head -n 20 /dev/urandom | cksum | cut -f1 -d ' ')
  randnum=$(($num%$mid+$min))    

  # 排除的端口號 1080, 4500, 8080, 58866, 可以任意添加
  port_exclude='1080,4500,8080,58866'
  flag=`echo ${port_exclude} | grep ${randnum} | wc -l`
  while [ "$flag" -eq "1" ]
  do
    num=$(head -n 20 /dev/urandom | cksum | cut -f1 -d ' ')
    randnum=$(($num%$mid+$min))    
    flag=`echo ${port_exclude} | grep ${randnum} | wc -l`
  done
  echo $randnum
}

function print_app_port() {
  for i in {1..10};
  do
    randnum=$(mimvp_app_port 1025 65535)
    echo -e "$i \t $randnum"
  done
}

print_app_port

運行結果:

# sh mimvp_shell_rand.sh 
1      29483
2      61738
3      31935
4      3242
5      19865
6      56677
7      5944
8      28579
9      12510
10     31844

隨機數應用二

隨機生成長度為10的密碼字符串 (通用于 CentOS, Ubuntu, MacOS)

應用的隨機數是 方法1:使用系統的 $RANDOM 變量

應用代碼:

#!/bin/bash
# mimvp.com 2016.05.10

## 應用二: 隨機生成長度為10的密碼字符串 (通用于 CentOS, Ubuntu, MacOS)
function mimvp_app_passwd() {
  user_array=`seq -w 10`
  echo ${user_array[@]}

  for idx in ${user_array[@]}
  do
    user_name="user-${idx}"
    passwd=`echo $RANDOM | md5sum | cut -c11-20`
    echo -e "${user_name} \t ${passwd}"
  done
}

mimvp_app_passwd

運行結果:

# sh mimvp_shell_rand.sh   
01 02 03 04 05 06 07 08 09 10
user-01        52cf5272cb
user-02        40f20d352d
user-03        9fe9a7b770
user-04        ff4e20e6e0
user-05        88fc4a3ea3
user-06        6494032261
user-07        6a42732519
user-08        6fc7a25dd5
user-09        f0b6a95608
user-10        49219467fa

隨機數應用三

統計擲骰子,投擲6000次統計分別為1-6的次數 (通用于 CentOS, Ubuntu, MacOS)

應用的隨機數是 方法1:使用系統的 $RANDOM 變量

應用代碼:

#!/bin/bash
# mimvp.com 2016.05.10

## 應用三: 統計擲骰子, 投擲6000次統計分別為1-6的次數 (通用于 CentOS, Ubuntu, MacOS)
function mimvp_app_dice() {
  MAX=6000
  stat_1=0
  stat_2=0
  stat_3=0
  stat_4=0
  stat_5=0
  stat_6=0

  i=1
  while [ "$i" -le "$MAX" ]
  do
    randnum=$(($RANDOM%6)) # 對6取余, 余數為0時記作6點
    case "$randnum" in
      0) stat_6=`expr ${stat_6} + 1`;;  # 余數為0時記作6點 
      1) stat_1=`expr ${stat_1} + 1`;;
      2) stat_2=`expr ${stat_2} + 1`;;
      3) stat_3=`expr ${stat_3} + 1`;;
      4) stat_4=`expr ${stat_4} + 1`;;
      5) stat_5=`expr ${stat_5} + 1`;;
    esac
    let "i=i+1"
  done
  
  echo "stat_1 ${stat_1}"
  echo "stat_2 ${stat_2}"
  echo "stat_3 ${stat_3}"
  echo "stat_4 ${stat_4}"
  echo "stat_5 ${stat_5}"
  echo "stat_6 ${stat_6}"
}

mimvp_app_dice

運行結果:

# sh mimvp_shell_rand.sh 
stat_1  923
stat_2  994
stat_3  977
stat_4  1039
stat_5  1072
stat_6  995

總結

random、urandom、uuid、openssl rand、自定義數組(用到了 $RANDOM)產生隨機碼的偽數據來源,都與 /dev/random 設備有關系,只是它們各自呈現不同。

date 日期生成的隨機數,與Linux 系統的隨機設備 /dev/random 的關系不大,但系統時間也會影響  /dev/random 設備,兩者并非絕對無關系。

所有可以生成隨機整數的方法,都可以生成隨機字符串,原理是對隨機整數進行 md5sum 計算

最后,附上完整的 shell 代碼,方便愛好者研究、調試

#!/bin/bash
# mimvp.com 2016.05.10

## 1. Linux 系統默認隨機數
function print_randnum() {
  for i in {1..10};
  do
    randnum=$RANDOM     # Linux 內置隨機數, 范圍[0,32767], 最多5位隨機數
#    randnum=$(awk 'BEGIN{srand(); print rand()*1000000; }') # awk 隨機種子函數, 最多5位隨機數, 跟時間有關
    echo -e "$i \t $randnum"
  done
}


## Linux 系統隨機數 + 范圍上限值后, 再取余
function mimvp_randnum_bignum() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(($RANDOM+$max))    # 隨機數+范圍上限, 然后取余
  randnum=$(($num%$mid+$min)) # 隨機數包含上下限邊界數值
  echo $randnum
}

function print_randnum_bignum() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_bignum 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}


## 2. Linux 時間戳隨機數 (CentOS, Ubuntu支持, MacOS不支持納秒+%N)
function mimvp_randnum_date() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(date +%s%N | cut -c1-17)   # 19位數, 截取第1-17位數, 下標從1開始
  num=$(date +%s%N)          # 19位數, 截取第1-17位數, 下標從1開始
  randnum=$(($num%$mid+$min))     # 隨機數包含上下限邊界數值
  echo $randnum
}

function print_randnum_date() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_date 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}

 

## 3. Linux 隨機文件
function mimvp_randnum_file() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(head -n 20 /dev/urandom | cksum | cut -f1 -d ' ')
#  num=$(head -n 20 /dev/urandom | cksum | cut -d ' ' -f1)       # ok
#  num=$(head -n 20 /dev/urandom | cksum | awk '{print $1}')      # ok
#  num=$(head -n 20 /dev/urandom | cksum | awk -F " " '{print $1}')  # ok
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_file() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_file 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}


## 4. Linux uuid
function mimvp_randnum_uuid() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(head -n 20 /proc/sys/kernel/random/uuid | cksum | cut -f1 -d ' ')
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_uuid() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_uuid 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}


## 5. Linux openssl
function mimvp_randnum_openssl() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(openssl rand -base64 8 | cksum | cut -f1 -d ' ')   # -base64
#  num=$(openssl rand -hex 8 | cksum | cut -f1 -d ' ')    # -hex
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_openssl() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_openssl 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}


## 6. custom array, 可以生成整數, 字符串
function mimvp_randnum_array() {
  NUM_LENGTH=18    # 整數的位數, 依據取值范圍設定, 默認最長為18位整數(取決于正整數的范圍)
  STR_ARRAY=(0 1 2 3 4 5 6 7 8 9 a b c d e f g h i j k l m n o p q r s t u v w x y z A B C D E F G H I J K L M N O P Q R S T U V W X Y Z)   # 生成字符串
  STR_ARRAY=(0 1 2 3 4 5 6 7 8 9)   # 生成整數

  str_array_count=${#STR_ARRAY[@]}  # 字符串數組的元素個數, 62 = 10 + 26 + 26
#  echo "str_array_count: ${str_array_count}"

  i=1
  randnum_array=()
  while [ "$i" -le "${NUM_LENGTH}" ];
  do
    randnum_array[$i]=${STR_ARRAY[$((RANDOM%str_array_count))]}
    let "i=i+1"
  done
  randnum_array_count=${#randnum_array[@]}
#  echo "randnum_array_count: ${randnum_array_count}" # NUM_LENGTH 的長度: 18
#  echo "randnum_array: ${randnum_array[@]}"      # 打印出全部數組元素, 如 B 2 y t z K c Z s N l 9 T b V w j 6

  num='1'       # 整數首位不能是0, 因此直接固定為1, 防止整數時首位為0的異常錯誤
  for item in ${randnum_array[@]};
  do
    num="${num}${item}"
  done
#  echo "num: $num"  # 1B2ytzKcZsNl9TbVwj6 

  min=$1
  max=$2
  mid=$(($max-$min+1))
  randnum=$(($num%$mid+$min))    
  echo $randnum
}

function print_randnum_array() {
  for i in {1..10};
  do
    randnum=$(mimvp_randnum_array 40000000 50000000)
    echo -e "$i \t $randnum"
  done
}


## 應用一: 隨機生成端口號 1025 ~ 65536 (通用于 CentOS, Ubuntu, MacOS)
function mimvp_app_port() {
  min=$1
  max=$2
  mid=$(($max-$min+1))
  num=$(head -n 20 /dev/urandom | cksum | cut -f1 -d ' ')
  randnum=$(($num%$mid+$min))    

  # 排除的端口號 1080, 4500, 8080, 58866, 可以任意添加
  port_exclude='1080,4500,8080,58866'
  flag=`echo ${port_exclude} | grep ${randnum} | wc -l`
  while [ "$flag" -eq "1" ]
  do
    num=$(head -n 20 /dev/urandom | cksum | cut -f1 -d ' ')
    randnum=$(($num%$mid+$min))    
    flag=`echo ${port_exclude} | grep ${randnum} | wc -l`
  done
  echo $randnum
}

function print_app_port() {
  for i in {1..10};
  do
    randnum=$(mimvp_app_port 1025 65535)
    echo -e "$i \t $randnum"
  done
}


## 應用二: 隨機生成長度為10的密碼字符串 (通用于 CentOS, Ubuntu, MacOS)
function mimvp_app_passwd() {
  user_array=`seq -w 10`
  echo ${user_array[@]}

  for idx in ${user_array[@]}
  do
    user_name="user-${idx}"
    passwd=`echo $RANDOM | md5sum | cut -c11-20`
    echo -e "${user_name} \t ${passwd}"
  done
}


## 應用三: 統計擲骰子, 投擲6000次統計分別為1-6的次數 (通用于 CentOS, Ubuntu, MacOS)
function mimvp_app_dice() {
  MAX=6000
  stat_1=0
  stat_2=0
  stat_3=0
  stat_4=0
  stat_5=0
  stat_6=0

  i=1
  while [ "$i" -le "$MAX" ]
  do
    randnum=$(($RANDOM%6)) # 對6取余, 余數為0時記作6點
    case "$randnum" in
      0) stat_6=`expr ${stat_6} + 1`;;  # 余數為0時記作6點 
      1) stat_1=`expr ${stat_1} + 1`;;
      2) stat_2=`expr ${stat_2} + 1`;;
      3) stat_3=`expr ${stat_3} + 1`;;
      4) stat_4=`expr ${stat_4} + 1`;;
      5) stat_5=`expr ${stat_5} + 1`;;
    esac
    let "i=i+1"
  done
  
  echo "stat_1 ${stat_1}"
  echo "stat_2 ${stat_2}"
  echo "stat_3 ${stat_3}"
  echo "stat_4 ${stat_4}"
  echo "stat_5 ${stat_5}"
  echo "stat_6 ${stat_6}"
}


print_randnum

#print_randnum_bignum

#print_randnum_date

#print_randnum_file

#print_randnum_uuid

#print_randnum_openssl

#print_randnum_array


#print_app_port

#mimvp_app_passwd

#mimvp_app_dice     # 循環次數多, 運行時間較長, 大約30秒, 請慎用

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • shell 生成隨機數的實現方法總結
  • Linux Shell里面生成隨機數的一些思路分析
  • linux shell實現隨機數幾種方法分享(date,random,uuid)
  • Shell腳本實現隨機數多種方法介紹(date、random、uuid)
  • shell產生隨機數七種方法的實現

標簽:紹興 武威 安康 麗江 迪慶 日喀則 西寧 蚌埠

巨人網絡通訊聲明:本文標題《Linux Shell 生成隨機數和隨機字符串的方法示例》,本文關鍵詞  Linux,Shell,生成,隨機數,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Linux Shell 生成隨機數和隨機字符串的方法示例》相關的同類信息!
  • 本頁收集關于Linux Shell 生成隨機數和隨機字符串的方法示例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩国产小视频| 91麻豆精品国产91久久久使用方法 | 成人av电影观看| 国内不卡的二区三区中文字幕| 一区二区三区四区精品在线视频| 2014亚洲片线观看视频免费| 日韩精品一区二区三区视频播放 | 欧美一区二区三区四区视频| 国产黄色成人av| 麻豆精品国产91久久久久久| 国产精品久久二区二区| 精品欧美一区二区久久| 国产欧美一区二区三区在线老狼| 欧美日韩高清影院| 欧美人与性动xxxx| 在线日韩av片| 欧美午夜不卡在线观看免费| 在线观看www91| 欧美亚洲精品一区| 欧美色区777第一页| 欧美日韩国产美女| 制服.丝袜.亚洲.另类.中文| 911国产精品| 欧美三级一区二区| 这里只有精品免费| 久久青草欧美一区二区三区| 中文成人综合网| 亚洲精品中文在线影院| 五月激情丁香一区二区三区| 91小视频在线| 777久久久精品| 欧美激情自拍偷拍| 亚洲第一福利视频在线| 精一区二区三区| 99热这里都是精品| 欧美一级日韩不卡播放免费| 2023国产精品自拍| 亚洲女厕所小便bbb| 亚洲图片欧美一区| 麻豆国产一区二区| 91捆绑美女网站| 欧美一级日韩不卡播放免费| 中文字幕在线不卡国产视频| 亚洲综合一二三区| 成人av免费在线观看| 欧美日韩1区2区| 欧美激情一区在线| 日日夜夜免费精品| 成人午夜视频免费看| 欧美日韩精品综合在线| 日本一区二区免费在线| 亚洲福中文字幕伊人影院| 国产aⅴ综合色| 91麻豆精品国产无毒不卡在线观看 | 中文字幕在线一区免费| 久久精品国产精品亚洲红杏| 欧美性三三影院| 国产精品久久午夜| 国产精品99久久久久久久女警| 制服.丝袜.亚洲.另类.中文 | 成人黄色片在线观看| 久久综合狠狠综合久久激情| 裸体一区二区三区| 日韩一区二区在线观看视频| 亚洲欧美日本在线| 粉嫩aⅴ一区二区三区四区| xfplay精品久久| 国产精品99精品久久免费| 久久综合成人精品亚洲另类欧美| 图片区小说区国产精品视频| 欧美性受xxxx黑人xyx| 亚洲一区二区三区中文字幕| 精品1区2区在线观看| 欧美日韩日本视频| 91网站在线播放| 国产精品中文字幕一区二区三区| 亚洲免费在线播放| 国产精品私人自拍| 国产亚洲一区二区在线观看| 欧美伦理视频网站| 色婷婷av一区| 国产成人精品午夜视频免费| 亚洲已满18点击进入久久| 国产精品电影一区二区| 精品少妇一区二区三区在线视频| 91成人在线免费观看| 成人午夜精品在线| 国产精品99久久久久久久女警 | 亚洲123区在线观看| 欧美一卡二卡在线| 夫妻av一区二区| 久久综合综合久久综合| 日韩欧美国产一区二区三区| 91免费版pro下载短视频| 国产精品一区三区| 裸体一区二区三区| 日韩av二区在线播放| 亚洲图片一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 91精品国产免费久久综合| www.成人在线| av毛片久久久久**hd| 国产成人免费视频精品含羞草妖精| 青青草国产成人99久久| 日韩二区在线观看| 午夜电影久久久| 婷婷一区二区三区| 免费一级片91| 久久国产三级精品| 成人午夜在线视频| 色婷婷综合中文久久一本| 色94色欧美sute亚洲13| 在线观看日韩精品| 欧美日韩国产在线观看| 欧美一区中文字幕| 欧美mv日韩mv国产网站app| 国产亚洲欧美日韩日本| 亚洲免费伊人电影| 日韩不卡在线观看日韩不卡视频| 日本中文字幕一区| 成人免费黄色大片| 91亚洲精品久久久蜜桃网站 | 亚洲精品菠萝久久久久久久| 一区二区日韩电影| 天涯成人国产亚洲精品一区av| 奇米影视一区二区三区小说| 国产乱子伦一区二区三区国色天香| 成人av网址在线| 欧美精品1区2区3区| 中文字幕永久在线不卡| 国产精品无人区| 欧美一区二区三区日韩| 91.xcao| 91在线播放网址| 91精品办公室少妇高潮对白| 日韩视频免费直播| 亚洲亚洲人成综合网络| 国产精品影视天天线| 日韩精品一区二区三区四区视频 | 精品久久久久香蕉网| 亚洲精品国产一区二区三区四区在线| 久久99精品国产.久久久久久| 欧美日本高清视频在线观看| 亚洲欧美日韩中文字幕一区二区三区 | 欧美少妇一区二区| 日韩欧美一区二区久久婷婷| 午夜精品一区二区三区免费视频| 久久久蜜臀国产一区二区| 欧美日韩www| 国产成人综合在线观看| 国产亚洲人成网站| 国产精品区一区二区三区| 日韩不卡一区二区三区| 在线观看亚洲一区| 日本不卡一区二区三区| 欧美一级午夜免费电影| 精品一区二区三区不卡| www激情久久| 一本到三区不卡视频| 一色桃子久久精品亚洲| 色综合天天综合网天天狠天天| 亚洲观看高清完整版在线观看| 欧美在线观看一二区| 久久99精品久久久久久| 精品在线免费观看| 成人永久免费视频| 91精品黄色片免费大全| 精品三级在线看| 国产精品乱码一区二区三区软件| 国产激情视频一区二区三区欧美 | 激情六月婷婷综合| 国产精品久久久久久福利一牛影视| 91成人网在线| 亚洲国产欧美在线人成| 暴力调教一区二区三区| 亚洲美女免费在线| 欧洲色大大久久| 日韩精品国产精品| 欧美视频精品在线| 亚洲特级片在线| 欧美高清性hdvideosex| 亚洲欧洲性图库| 成人久久久精品乱码一区二区三区| 亚洲在线观看免费视频| 欧美在线观看视频在线| 亚洲一区二区三区小说| 欧美一级在线免费| 国产91精品久久久久久久网曝门| 伊人婷婷欧美激情| 亚洲天堂久久久久久久| 国产精品久久久一本精品| 色一区在线观看| 国产综合色产在线精品 | 色狠狠综合天天综合综合| 亚洲人吸女人奶水| 欧美日韩高清影院| 色嗨嗨av一区二区三区| 日韩在线一区二区| 欧美三级电影网站| 午夜免费欧美电影|