Linux下分割、合並文件——dd和cat


功能說明:讀取,轉換並輸出數據。

語  法:dd [bs=<字節數>][cbs=<字節數>][conv=<關鍵字>][count=<區塊數>][ibs=<字節數>][if=<文件>][obs=<字節數>][of=<文件>][seek=<區塊數>][skip=<區塊數>][–help][–version]

補充說明:dd可從標准輸入或文件讀取數據,依指定的格式來轉換數據,再輸出到文件,設備或標准輸出。

參  數:

bs=<字節數>   將ibs( 輸入)與obs(輸出)設成指定的字節數。

cbs=<字節數>  轉換時,每次只轉換指定的字節數。

conv=<關鍵字> 指定文件轉換的方式。

count=<區塊數> 僅讀取指定的區塊數。

ibs=<字節數>  每次讀取的字節數。

if=<文件>    從文件讀取。

obs=<字節數>  每次輸出的字節數。

of=<文件>    輸出到文件。

seek=<區塊數>  一開始輸出時,跳過指定的區塊數。

skip=<區塊數>  一開始讀取時,跳過指定的區塊數。

dd的作用是轉換和拷貝文件,我們可以利用它來分割文件,相關的選項如下:

if=filename:輸入的文件名

of=finename:輸出的文件名

bs=bytes:一次讀寫的字節數,默認是512bytes

skip=blocks:拷貝前,跳過的輸入文件的前blocks塊,塊的大小有bs決定

count=blocks:只拷貝輸入文件的前blocks塊

 

例如,現在有一個文件file,大小為116616字節:

 

[root]# du -b file
116616  file

 

將其分割為兩文件file1和file2,那我們就設置每塊為1024字節,將file的前60塊放入file1,余下的放入file2:

 

[root]# dd if=file bs=1024 count=60 skip=0  of=file1
[root]# dd if=file bs=1024 count=60 skip=60 of=file2

 

然后用cat將兩個文件合並為file.bak,要注意文件的順序:

 

[root]# cat file1 file2 > file.bak

 

可以用md5sum驗證一下file和file.bak:

 

[root]# md5sum file
3ff53f7c30421ace632eefff36148a70  file
[root]# md5sum file.bak
3ff53f7c30421ace632eefff36148a70  file.bak

 

可以證明兩個文件時完全相同的。

 

為了方便分割、合並文件,我寫了兩個腳本:

ddf.sh:

 

#ddf.sh:分割文件,分割后的文件以數字結尾,例如file分割為兩個文件:file1和file2
#!/bin/sh

#使用腳本是第一參數是要分割的文件名
Filename=$1   
Filesize=0

Path=`pwd`

#驗證文件名是否正確,然后計算文件的大小
if [ -z $Filename ];then
    echo "Error:The file name can not be empty"
    exit
fi
if [ -e $Filename ];then
    Filesize=`du -b $Filename | awk '{print $1}'`
    if [ $Filesize == 0 ];then
    	echo "Error:The File size is zero!"
    	exit
    fi
    echo "The file size is $Filesize Byte"
    echo "Plese enter the subfile size(KB):"
else
    echo "Error:$Filename does not exist!"
    exit 
fi

#輸入分割后每個文件的大小,單位是KB
read Subfilesize
if [ -z $Subfilesize ];then
    echo "Error:Input can not be empty"
    exit
fi

echo $Subfilesize | grep '^[0-9]\+$' >> /dev/null
if [ $? -ne 0 ];then
    echo "Error:The Input is not a number!"
    exit
elif [ $Subfilesize -eq 0 ];then
    echo "Error:The Subfile size is zero!"
    exit
fi

#計算需要分割為幾個文件
SubfileByte=`expr $Subfilesize \* 1024`
Subfilenum=`expr $Filesize / $SubfileByte`
if [ `expr $Filesize % $Subfilesize` -ne 0 ];then
    Subfilenum=`expr $Subfilenum + 1`
fi

#將文件分割
echo "$Filename will be divided into $Subfilenum" 
i=1
skipnum=0
while [ $i -le $Subfilenum ]
do
    echo "$Filename$i"
    dd if=$Filename of="$Path/$Filename$i" bs=1024 count=$Subfilesize skip=$skipnum
    i=`expr $i + 1`
    skipnum=`expr $skipnum + $Subfilesize`
done
echo "$Filename has been divided into $Subfilenum"
echo "Done !"

 

caf.sh:

 

#caf.sh:合並文件,需要合並的文件要放在一個文件夾里
#       文件名分為兩個部分,第一部分都相同,第二部分必須是從1開始的連續數字,例如file1,file2,file3
#       合並后的文件名為file.bak
#!/bin/sh

#輸入文件名的第一部分
echo "Please enter file name:"
read Filename
if [ -z $Filename ];then
	echo "Error:File name can not be empty"
	exit
fi

#輸入待合並文件的個數
echo "Please enter the number of subfiles:" 
read Subfilenum
if [ -z $Subfilenum ];then
	echo "Error:The number of subfiles can not be empty"
	exit
fi
echo $Subfilenum | grep '^[0-9]\+$' > /dev/null
if [ $? -ne 0 ];then
        echo "Error:Input must be a number"
exit
fi
if [ $Subfilenum -eq 0 ];then
        echo "Error:The number of subfiles can not be zero"
exit
fi


#合並文件
i=1
Newfile=$Filename\.bak
while [ $i -le $Subfilenum ]
do
	Subfilename=$Filename$i
        if [ -e $Subfilename ];then
            echo "$Subfilename done!"
            cat $Subfilename >> $Newfile
            i=`expr $i + 1`
        else
            echo "Error:$Subfilename does not exist"
            rm -rf $Newfile
            exit
        fi
done


echo "Subfiles be merged into $Newfile"
echo "Success!"

 

 

用這兩個腳本完成對file的分割、合並:

 

[root]# ./ddf.sh file 
The file size is 116616 Byte
Plese enter the subfile size(KB):
60
file will be divided into 2
file1
記錄了60+0 的讀入
記錄了60+0 的寫出
61440字節(61 kB)已復制,0.0352612 秒,1.7 MB/秒
file2
記錄了53+1 的讀入
記錄了53+1 的寫出
55176字節(55 kB)已復制,0.0316272 秒,1.7 MB/秒
file has been divided into 2
Done !
[root]# ls
caf.sh  ddf.sh  file  file1  file2
[root]# ./caf.sh 
Please enter file name:
file
Please enter the number of subfiles:
2
file1 done!
file2 done!
Subfiles be merged into file.bak
Success!
[root]# ls
caf.sh  ddf.sh  file  file1  file2  file.bak

 

linux下的兩個很實用的命令, 一個切分, 一個合並.非常實用

 

1. dd

dd的參數:

Copy a file, converting and formatting according to the operands.
 
  bs=BYTES        read and write up to BYTES bytes at a time
  cbs=BYTES       convert BYTES bytes at a time
  conv=CONVS      convert the file as per the comma separated symbol list
  count=N         copy only N input blocks
  ibs=BYTES       read up to BYTES bytes at a time (default: 512)
  if=FILE         read from FILE instead of stdin
  iflag=FLAGS     read as per the comma separated symbol list
  obs=BYTES       write BYTES bytes at a time (default: 512)
  of=FILE         write to FILE instead of stdout
  oflag=FLAGS     write as per the comma separated symbol list
  seek=N          skip N obs-sized blocks at start of output
  skip=N          skip N ibs-sized blocks at start of input
  status=WHICH    WHICH info to suppress outputting to stderr;
                  'noxfer' suppresses transfer stats, 'none' suppresses all

 if和of是輸入輸出

 

count是操作的塊數

bs就是塊的大小

seek是略過n個輸出的塊再寫入

skip是略過輸入的塊數

 

2.  cat命令

很簡單的常用法之一是把兩個文件合並在一起

cat a b >c

 

3. 其它應用 

1.將本地的/dev/hdb整盤備份到/dev/hdd
   dd if=/dev/hdb f=/dev/hdd              hdb –> 內存 -> hdd
2.將/dev/hdb全盤數據備份到指定路徑的image文件 dd if=/dev/hdb f=/root/image hdb –> 內存 -> image文件
3.將備份文件恢復到指定盤 dd if=/root/image f=/dev/hdb image文件 –> 內存 -> hdb
4.備份/dev/hdb全盤數據,並利用gzip工具進行壓縮,保存到指定路徑 dd if=/dev/hdb | gzip> /root/image.gz
5.將壓縮的備份文件恢復到指定盤 gzip -dc /root/image.gz | dd f=/dev/hdb
6.備份磁盤開始的512個字節大小的MBR 主引導記錄信息到指定文件 dd if=/dev/hda f=/root/image count=1 bs=512 默認從硬盤0柱面0磁道1扇區讀取512個字節 count=1指僅拷貝一個塊;bs=512指塊大小為512個字節。 恢復:dd if=/root/image f=/dev/hda
7.備份軟盤 dd if=/dev/fd0 f=disk.img count=1 bs=1440k (即塊大小為1.44M)
8.拷貝內存內容到硬盤 dd if=/dev/mem f=/root/mem.bin bs=1024 (指定塊大小為1k)
9.拷貝光盤內容到指定文件夾,並保存為cd.iso鏡像文件 dd if=/dev/cdrom(hdc) of=/root/cd.iso
10.增加swap交換分區文件大小 第一步:創建一個大小為256M的文件: dd if=/dev/zero of=/swapfile bs=1024 count=262144 第二步:把這個文件變成swap交換分區文件: mkswap /swapfile 第三步:啟用這個swap交換分區文件: swapon /swapfile 第四步:編輯/etc/fstab文件,使在每次開機時自動加載swap交換分區文件: /swapfile swap swap default 0 0

11.銷毀磁盤數據 dd if=/dev/urandom f=/dev/hda1 注意:利用隨機的數據填充硬盤,在某些必要的場合可以用來銷毀數據。
12.測試硬盤的讀寫速度 dd if=/dev/zero bs=1024 count=1000000 f=/root/1Gb.file 寫速度 dd if=/root/1Gb.file bs=64k | dd f=/dev/null 讀速度 通過以上兩個命令輸出的命令執行時間,可以計算出硬盤的讀、寫速度。
13.確定硬盤的最佳塊blocks大小:初始化硬盤 dd if=/dev/zero bs=1024 count=1000000 f=/root/1Gb.file 初始化硬盤 dd if=/dev/zero bs=2048 count=500000 f=/root/1Gb.file 初始化硬盤 dd if=/dev/zero bs=4096 count=250000 f=/root/1Gb.file 初始化硬盤 dd if=/dev/zero bs=8192 count=125000 f=/root/1Gb.file 初始化硬盤 通過比較以上命令輸出中所顯示的命令執行時間,即可確定系統最佳的塊大小。
14.修復硬盤: 自初始化硬盤 dd if=/dev/sda f=/dev/sda SCSI硬盤 或dd if=/dev/hda f=/dev/hda IDE

 

Linux 下的dd命令使用詳解

一、dd命令的解釋

dd:用指定大小的塊拷貝一個文件,並在拷貝的同時進行指定的轉換。

注意:指定數字的地方若以下列字符結尾,則乘以相應的數字:b=512c=1k=1024w=2

參數注釋:

1. if=文件名:輸入文件名,缺省為標准輸入。即指定源文件。< if=input file >

2. of=文件名:輸出文件名,缺省為標准輸出。即指定目的文件。< of=output file >

3. ibs=bytes:一次讀入bytes個字節,即指定一個塊大小為bytes個字節。

    obs=bytes:一次輸出bytes個字節,即指定一個塊大小為bytes個字節。

    bs=bytes:同時設置讀入/輸出的塊大小為bytes個字節。

4. cbs=bytes:一次轉換bytes個字節,即指定轉換緩沖區大小。

5. skip=blocks:從輸入文件開頭跳過blocks個塊后再開始復制。

6. seek=blocks:從輸出文件開頭跳過blocks個塊后再開始復制。

注意:通常只用當輸出文件是磁盤或磁帶時才有效,即備份到磁盤或磁帶時才有效。

7. count=blocks:僅拷貝blocks個塊,塊大小等於ibs指定的字節數。

8. conv=conversion:用指定的參數轉換文件。

    ascii:轉換ebcdicascii

     ebcdic:轉換asciiebcdic

    ibm:轉換asciialternate ebcdic

    block:把每一行轉換為長度為cbs,不足部分用空格填充

    unblock:使每一行的長度都為cbs,不足部分用空格填充

    lcase:把大寫字符轉換為小寫字符

    ucase:把小寫字符轉換為大寫字符

    swab:交換輸入的每對字節

     noerror:出錯時不停止

     notrunc:不截短輸出文件

    sync:將每個輸入塊填充到ibs個字節,不足部分用空(NUL)字符補齊。

二、dd應用實例

1.將本地的/dev/hdb整盤備份到/dev/hdd

#dd if=/dev/hdb of=/dev/hdd

2./dev/hdb全盤數據備份到指定路徑的image文件

#dd if=/dev/hdb of=/root/image

3.將備份文件恢復到指定盤

#dd if=/root/image of=/dev/hdb

4.備份/dev/hdb全盤數據,並利用gzip工具進行壓縮,保存到指定路徑

#dd if=/dev/hdb | gzip > /root/image.gz

5.將壓縮的備份文件恢復到指定盤

#gzip -dc /root/image.gz | dd of=/dev/hdb

6.備份與恢復MBR

備份磁盤開始的512個字節大小的MBR信息到指定文件:

#dd if=/dev/hda of=/root/image count=1 bs=512

   count=1指僅拷貝一個塊;bs=512指塊大小為512個字節。

恢復:

#dd if=/root/image of=/dev/had

將備份的MBR信息寫到磁盤開始部分

7.備份軟盤

#dd if=/dev/fd0 of=disk.img count=1 bs=1440k (即塊大小為1.44M)

8.拷貝內存內容到硬盤

#dd if=/dev/mem of=/root/mem.bin bs=1024 (指定塊大小為1k)  

9.拷貝光盤內容到指定文件夾,並保存為cd.iso文件

#dd if=/dev/cdrom(hdc) of=/root/cd.iso

10.增加swap分區文件大小

第一步:創建一個大小為256M的文件:

#dd if=/dev/zero of=/swapfile bs=1024 count=262144

第二步:把這個文件變成swap文件:

#mkswap /swapfile

第三步:啟用這個swap文件:

#swapon /swapfile

第四步:編輯/etc/fstab文件,使在每次開機時自動加載swap文件:

/swapfile    swap    swap    default   0 0

11.銷毀磁盤數據

#dd if=/dev/urandom of=/dev/hda1

注意:利用隨機的數據填充硬盤,在某些必要的場合可以用來銷毀數據。

12.測試硬盤的讀寫速度

#dd if=/dev/zero bs=1024 count=1000000 of=/root/1Gb.file

#dd if=/root/1Gb.file bs=64k | dd of=/dev/null

通過以上兩個命令輸出的命令執行時間,可以計算出硬盤的讀、寫速度。

13.確定硬盤的最佳塊大小:

#dd if=/dev/zero bs=1024 count=1000000 of=/root/1Gb.file

#dd if=/dev/zero bs=2048 count=500000 of=/root/1Gb.file

#dd if=/dev/zero bs=4096 count=250000 of=/root/1Gb.file

#dd if=/dev/zero bs=8192 count=125000 of=/root/1Gb.file

通過比較以上命令輸出中所顯示的命令執行時間,即可確定系統最佳的塊大小。

14.修復硬盤:

#dd if=/dev/sda of=/dev/sda 或dd if=/dev/hda of=/dev/hda

當硬盤較長時間(一年以上)放置不使用后,磁盤上會產生magnetic flux point,當磁頭讀到這些區域時會遇到困難,並可能導致I/O錯誤。當這種情況影響到硬盤的第一個扇區時,可能導致硬盤報廢。上邊的命令有可能使這些數 據起死回生。並且這個過程是安全、高效的。

15.利用netcat遠程備份

#dd if=/dev/hda bs=16065b | netcat < targethost-IP > 1234

在源主機上執行此命令備份/dev/hda

#netcat -l -p 1234 | dd of=/dev/hdc bs=16065b

在目的主機上執行此命令來接收數據並寫入/dev/hdc

#netcat -l -p 1234 | bzip2 > partition.img

#netcat -l -p 1234 | gzip > partition.img

以上兩條指令是目的主機指令的變化分別采用bzip2gzip對數據進行壓縮,並將備份文件保存在當前目錄。

16.將一個大視頻文件的第i個字節的值改成0x41(大寫字母AASCII值)

#echo A | dd of=bigfile seek=$i bs=1 count=1 conv=notrunc

17.建立linux虛擬盤,用文件模擬磁盤

在進行linux的實驗中,如果沒有多余的硬盤來做測試。則可以在linux下使用文件來模擬磁盤,以供測試目的。

其模擬過程如下所示,摘錄自《Oracle數據庫核心技術與實務詳解-教你如何成為Oracle 10g OCP》一書。

1)root用戶創建一個ASM磁盤所在的目錄。

# mkdir –p /u01/asmdisks

2)通過dd命令創建6400M大小的文件,每個文件代表一塊磁盤。

[root@book u01]# cd asmdisks

[root@book asmdisks]# dd if=/dev/zero of=asm_disk1 bs=1024k count=400

[root@book asmdisks]# dd if=/dev/zero of=asm_disk2 bs=1024k count=400

[root@book asmdisks]# dd if=/dev/zero of=asm_disk3 bs=1024k count=400

[root@book asmdisks]# dd if=/dev/zero of=asm_disk4 bs=1024k count=400

[root@book asmdisks]# dd if=/dev/zero of=asm_disk5 bs=1024k count=400

[root@book asmdisks]# dd if=/dev/zero of=asm_disk6 bs=1024k count=400

3)將這些文件與裸設備關聯。

[root@book asmdisks]# chmod 777 asm_disk*

[root@book asmdisks]# losetup /dev/loop1 asm_disk1

[root@book asmdisks]# losetup /dev/loop2 asm_disk2

[root@book asmdisks]# losetup /dev/loop3 asm_disk3

[root@book asmdisks]# losetup /dev/loop4 asm_disk4

[root@book asmdisks]# losetup /dev/loop5 asm_disk5

[root@book asmdisks]# losetup /dev/loop6 asm_disk6

注意:如果要刪除通過dd模擬出的虛擬磁盤文件的話,直接刪除模擬出的磁盤文件

(也就是asm_disk1asm_disk2asm_disk6)還不夠,還必須執行losetup -d /dev/loopN,在這里N16。否則,磁盤文件所占用的磁盤空間不能釋放

三、/dev/null和/dev/zero的區別

/dev/null,外號叫無底洞,你可以向它輸出任何數據,它通吃,並且不會撐着!

/dev/zero,是一個輸入設備,你可你用它來初始化文件。該設備無窮盡地提供0,可以使用任何你需要的數目——設備提供的要多的多。他可以用於向設備或文件寫入字符串0

/dev/null------它是空設備,也稱為位桶(bit bucket)。任何寫入它的輸出都會被拋棄。如果不想讓消息以標准輸出顯示或寫入文件,那么可以將消息重定向到位桶。

#if=/dev/zero of=./test.txt bs=1k count=1
#ls –l

total 4
-rw-r--r--    1 oracle   dba          1024 Jul 15 16:56 test.txt

#find / -name access_log  2>/dev/null

3.1使用/dev/null 

/dev/null看作"黑洞", 它等價於一個只寫文件,所有寫入它的內容都會永遠丟失.,而嘗試從它那兒讀取內容則什么也讀不到。然而, /dev/null對命令行和腳本都非常的有用

禁止標准輸出

#cat $filename >/dev/null

文件內容丟失,而不會輸出到標准輸出.

禁止標准錯誤

#rm $badname 2>/dev/null

這樣錯誤信息[標准錯誤]就被丟到太平洋去了

禁止標准輸出和標准錯誤的輸出

#cat $filename 2>/dev/null >/dev/null

如果"$filename"不存在,將不會有任何錯誤信息提示;如果"$filename"存在, 文件的內容不會打印到標准輸出

因此,上面的代碼根本不會輸出任何信息。當只想測試命令的退出碼而不想有任何輸出時非常有用。

#cat $filename &>/dev/null

這樣其實也可以, 由 Baris Cicek 指出

自動清空日志文件的內容

Deleting contents of a file, but preserving the file itself, with all attendant permissions (from Example 2-1 and Example 2-3): 

#cat /dev/null > /var/log/messages
#  : > /var/log/messages   有同樣的效果, 但不會產生新的進程.(因為:是內建的)
#cat /dev/null > /var/log/wtmp

特別適合處理這些由商業Web站點發送的討厭的"cookies"

隱藏cookie而不再使用

#if [ -f ~/.netscape/cookies ]  # 如果存在則刪除.
#then
#rm -f ~/.netscape/cookies
#fi
#ln -s /dev/null ~/.netscape/cookies

現在所有的cookies都會丟入黑洞而不會保存在磁盤上了.

3.2使用/dev/zero

/dev/null一樣, /dev/zero也是一個偽文件, 但它實際上產生連續不斷的null的流(二進制的零流,而不是ASCII型的)。 寫入它的輸出會丟失不見, 而從/dev/zero讀出一連串的null也比較困難, 雖然這也能通過od或一個十六進制編輯器來做到。 /dev/zero主要的用處是用來創建一個指定長度用於初始化的空文件,就像臨時交換文件

/dev/zero創建一個交換臨時文件

#!/bin/bash 

  # 創建一個交換文件. 

  ROOT_UID=0 # Root 用戶的 $UID 是 0. 

  E_WRONG_USER=65 # 不是 root? 

  FILE=/swap 

  BLOCKSIZE=1024

  MINBLOCKS=40 

  SUCCESS=0

  # 這個腳本必須用root來運行.

  if [ "$UID" -ne "$ROOT_UID" ] 

   then

   echo; echo "You must be root to run this script."; echo 

   exit $E_WRONG_USER

  fi 

  blocks=${1:-$MINBLOCKS} # 如果命令行沒有指定,

  #+ 則設置為默認的40塊. 

  # 上面這句等同如:

  # -------------------------------------------------- 

  # if [ -n "$1" ] 

  # then 

  # blocks=$1 

  # else 

  # blocks=$MINBLOCKS 

  # fi 

  # --------------------------------------------------

 if [ "$blocks" -lt $MINBLOCKS ] 

 then

 blocks=$MINBLOCKS # 最少要有 40 個塊長. 

 fi 

 echo "Creating swap file of size $blocks blocks (KB)." 

 dd if=/dev/zero of=$FILE bs=$BLOCKSIZE count=$blocks # 把零寫入文件. 

 mkswap $FILE $blocks # 將此文件建為交換文件(或稱交換分區). 

 swapon $FILE # 激活交換文件. 

 echo "Swap file created and activated." 

 exit $SUCCESS 

關於 /dev/zero 的另一個應用是為特定的目的而用零去填充一個指定大小的文件, 如掛載一個文件系統到環回設備 (loopback device)或"安全地刪除一個文件

例子 創建ramdisk

#!/bin/bash 

 # ramdisk.sh 

 # "ramdisk"是系統RAM內存的一段, 

 #+ 它可以被當成是一個文件系統來操作. 

 # 它的優點是存取速度非常快 (包括讀和寫). 

 # 缺點: 易失性, 當計算機重啟或關機時會丟失數據.

 #+ 會減少系統可用的RAM. 

 # 10 # 那么ramdisk有什么作用呢?

 # 保存一個較大的數據集在ramdisk, 比如一張表或字典, 

 #+ 這樣可以加速數據查詢, 因為在內存里查找比在磁盤里查找快得多.

  E_NON_ROOT_USER=70 # 必須用root來運行. 

  ROOTUSER_NAME=root

  MOUNTPT=/mnt/ramdisk 

  SIZE=2000 # 2K 個塊 (可以合適的做修改)

  BLOCKSIZE=1024 # 每塊有1K (1024 byte) 的大小 

  DEVICE=/dev/ram0 # 第一個 ram 設備 

  username=`id -nu` 

  if [ "$username" != "$ROOTUSER_NAME" ] 

  then 

    echo "Must be root to run \"`basename $0`\"."

    exit $E_NON_ROOT_USER 

  fi 

   if [ ! -d "$MOUNTPT" ] # 測試掛載點是否已經存在了,

  then #+ 如果這個腳本已經運行了好幾次了就不會再建這個目錄了

    mkdir $MOUNTPT #+ 因為前面已經建立了. 

  fi 

  dd if=/dev/zero of=$DEVICE count=$SIZE bs=$BLOCKSIZE

   # 把RAM設備的內容用零填充.                                               

   # 為何需要這么做? 

  mke2fs $DEVICE # 在RAM設備上創建一個ext2文件系統. 

  mount $DEVICE $MOUNTPT # 掛載設備. 

  chmod 777 $MOUNTPT # 使普通用戶也可以存取這個ramdisk. 

  # 但是, 只能由root來缷載它. 

  echo "\"$MOUNTPT\" now available for use." 

 # 現在 ramdisk 即使普通用戶也可以用來存取文件了. 

 # 注意, ramdisk是易失的, 所以當計算機系統重啟或關機時ramdisk里的內容會消失.

 # 拷貝所有你想保存文件到一個常規的磁盤目錄下. 

 # 重啟之后, 運行這個腳本再次建立起一個 ramdisk. 

 # 僅重新加載 /mnt/ramdisk 而沒有其他的步驟將不會正確工作. 

 # 如果加以改進, 這個腳本可以放在 /etc/rc.d/rc.local,

 #+ 以使系統啟動時能自動設立一個ramdisk. 

 # 這樣很合適速度要求高的數據庫服務器. 

 exit 0

 

dd命令和cp/cat命令的區別

在了解了上面的內容之后,我更好奇了,為什么dd命令看上去這么好,現在人們在Linux系統上進行文件復制時用的都是cp命令呢?

難道僅僅是因為cp命令用起來簡單么?

dd works on the file you specify, making it able to copy data between devices, or from a device to a file.

This is commonly used for moving data if devices specifically are involved

(create an iso image from a cd-rom disc for example: dd if=/dev/cdrom of=mycdrom.iso),

or backup raw devices(sometimes used in RAC databases: dd if=/dev/raw/raw1 of=device_raw1)

cp is used for duplicating file content to a new file or to a new location.

things you specifically want there are preservation of ownership, timestamp and mode (rights),

and being able to recurse the operation(=being able to copy directories).

cp命令是用來復制文件內容的(同時保留所有者、時間戳和權限等信息),並且允許遞歸操作(方便進行文件夾級別的復制操作);
dd命令一般是用來在不同的設備之間復制數據或備份原始數據(早期用得較多)。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM