国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Linux Shell > 正文

Shell腳本創建指定大小文件的測試數據

2020-07-27 19:08:05
字體:
來源:轉載
供稿:網友

我們在測試或調試的時候,有時候會需要生成某個size的文件,比如在測試存儲系統時,需要將磁盤剩余空間減少5G,最簡單的辦法就是拷貝一個5G的文件過來,但是從哪兒去弄這樣大小的文件呢,或許你想到隨便找一個文件,不停的拷貝,最后合并,這也不失為一種辦法,但是有了dd,你會更容易且更靈活的實現。
我們來case by case的介紹dd的用法。先看第一個

生成一個大小為5G的文件,內容不做要求

命令如下

復制代碼 代碼如下:

$ dd if=/dev/zero of=tmp.5G bs=1G count=5 

解釋一下這里用到的參數
復制代碼 代碼如下:

if=FILE      : 指定輸入文件,若不指定則從標注輸入讀取。這里指定為/dev/zero是Linux的一個偽文件,它可以產生連續不斷的null流(二進制的0) 
of=FILE      : 指定輸出文件,若不指定則輸出到標準輸出 
bs=BYTES     : 每次讀寫的字節數,可以使用單位K、M、G等等。另外輸入輸出可以分別用ibs、obs指定,若使用bs,則表示是ibs和obs都是用該參數 
count=BLOCKS : 讀取的block數,block的大小由ibs指定(只針對輸入參數) 

這樣上面生成5G文件的命令就很好理解了,即從/dev/null每次讀取1G數據,讀5次,寫入tmp.5G這個文件

再看下面一個問題

復制代碼 代碼如下:

將file.in的前1M追加到file.out的末尾

命令如下

復制代碼 代碼如下:

$ file_out_size=`du -b file.out | awk '{print $1}'` 
$ dd if=./file.in ibs=1M count=1 of=./file.out seek=1 obs=$file_out_size

這里ibs和obs設置為了不同的值,和前面的命令相比,只多了一個seek參數
復制代碼 代碼如下:

seek=BLOCKS : 在拷貝數據之前,從輸出文件開頭跳過BLOCKS個block,block的大小由obs指定 

命令的意思就是從file.in讀取1個1M的數據塊寫入file.out,不過寫入位置并不在file.out的開頭,而是在1*$file_out_size字節偏移處(也就是文件末尾)

在此基礎上再增加一個要求

將file.in的第3M追加到file.out的末尾

復制代碼 代碼如下:

$ file_out_size=`du -b file.out | awk '{print $1}'` 
$ dd if=./file.in skip=2 ibs=1M count=1 of=./file.out seek=1 obs=$file_out_size 

這里多了一個參數skip

復制代碼 代碼如下:

skip=BLOCKS : 拷貝數據前,從輸入文件跳過BLOCKS個block,block的大小由ibs指定。這個參數和seek是對應的

上面命令的意思就是,從文件file.in開始跳過2*1M,拷貝1*1M數據,寫入文件file.out的1*$file_out_size偏移處

這樣基本的參數都介紹全了,無非就是設置輸入輸出文件以及各自的偏移,設置讀寫數據塊大小和讀取數據塊個數,下面總結一下

復制代碼 代碼如下:

輸入參數: 
    if 
    skip 
    ibs 
    count 
輸出參數: 
    of 
    seek 
    obs 

最后來一道終極題。前面創建的都是null流,這次換一個

復制代碼 代碼如下:

指定某個字符,創建一個全是這個字符的指定大小的文件。比如創建一個文件,大小為123456字節,每個字節都是字符A

這問題看似沒什么意義,但有時候確實需要用到。比如我通過/dev/null創建了一個1G的文件,但是出于測試需求我想修改中間100M數據,這時我需要創建一個100M的文件,將該文件寫入到那個1G文件的指定位置,而這個100M的文件是不能從/dev/null創建的,否則達不到修改的目的,這時候就需要這樣的功能了

話不多說,直接上腳本,有了前面的基礎,相信都能看得懂

復制代碼 代碼如下:

#!/bin/bash 
if [ $# -ne 3 ];then 
    echo "usage : $0 character out_file file_size(Byte)" 
    exit 1 
fi 
 
echo "$1" | grep -q "^[a-zA-Z]$" 
if [ $? -ne 0 ];then 
    echo "arg1 must be character" 
    exit 1 
fi 
 
character=$1 
out_file=$2 
target_size=$3 
 
# echo輸出默認是帶'/n'字符的,所以需要通過dd指定輸入字節數 
echo "$character" | dd of=$out_file ibs=1 count=1 
while true 
do 
    cur_size=`du -b $out_file | awk '{print $1}'` 
    if [ $cur_size -ge $target_size ];then 
        break 
    fi 
    remain_size=$((target_size-$cur_size)) 
    if [ $remain_size -ge $cur_size ];then 
        input_size=$cur_size 
    else 
        input_size=$remain_size 
    fi 
    dd if=$out_file ibs=$input_size count=1 of=$out_file seek=1 obs=$cur_size || exit 1 
done 

有了這些技巧,在對文件內容無要求的前提下,你就可以任意創建指定大小的文件,任意修改文件指定字節數,這會讓某些測試場合變得非常方便

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 拜泉县| 循化| 常宁市| 朝阳县| 寿阳县| 张家口市| 奉贤区| 内黄县| 唐海县| 神农架林区| 洱源县| 汝州市| 娄底市| 曲靖市| 兴文县| 八宿县| 广安市| 东明县| 凌源市| 平顶山市| 宿州市| 克山县| 成都市| 海丰县| 天气| 宝清县| 温州市| 阳山县| 会理县| 汤阴县| 尤溪县| 仙桃市| 柘荣县| 乐平市| 宁晋县| 淮北市| 盈江县| 五指山市| 家居| 佛教| 赤城县|