1. 程式人生 > >linux cp命令參數及用法詳解---linux 復制文件命令cp

linux cp命令參數及用法詳解---linux 復制文件命令cp

linux file

linux cp命令參數及用法詳解---linux 復制文件命令cp

[root@Linux ~]# cp [-adfilprsu] 來源檔(source) 目的檔(destination)
[root@linux ~]# cp [options] source1 source2 source3 …. directory
參數:
-a :相當於 -pdr 的意思;
-d :若來源文件為連結文件的屬性(link file),則復制連結文件屬性而非檔案本身;
-f :為強制 (force) 的意思,若有重復或其它疑問時,不會詢問使用者,而強制復制;

-i :若目的檔(destination)已經存在時,在覆蓋時會先詢問是否真的動作!
-l :進行硬式連結 (hard link) 的連結檔建立,而非復制檔案本身;
-p :連同檔案的屬性一起復制過去,而非使用預設屬性;
-r :遞歸持續復制,用於目錄的復制行為;
-s :復制成為符號連結文件 (symbolic link),亦即『快捷方式』檔案;
-u :若 destination 比 source 舊才更新 destination !
最後需要註意的,如果來源檔有兩個以上,則最後一個目的文件一定要是『目錄』才行!


範例:
範例一:將家目錄下的 .bashrc 復制到 /tmp 下,並更名為 bashrc
[[email protected]

/* */ ~]# cd /tmp
[[email protected] tmp]# cp ~/.bashrc bashrc
[[email protected] tmp]# cp -i ~/.bashrc bashrc
cp: overwrite `basrhc’? n
# 重復作兩次動作,由於 /tmp 底下已經存在 bashrc 了,加上 -i 參數,
# 則在覆蓋前會詢問使用者是否確定!可以按下 n 或者 y 呢!
# 但是,反過來說,如果不想要詢問時,則加上 -f 這個參數來強制直接覆蓋!

範例二:將 /var/log/wtmp 復制到 /tmp 底下
[[email protected]

/* */ tmp]# cp /var/log/wtmp . <==想要復制到目前的目錄,最後的 . 不要忘
[[email protected] tmp]# ls -l /var/log/wtmp wtmp
-rw-rw-r– 1 root utmp 71808 Jul 18 12:46 /var/log/wtmp
-rw-r–r– 1 root root 71808 Jul 18 21:58 wtmp
# 註意到了嗎?!在不加任何參數的情況下,檔案的所屬者會改變,連權限也跟著改變了
# 這是個很重要的特性!要註意喔!還有,連檔案建立的時間也不一樣了!
# 如果您想要將檔案的所有特性都一起復制過來,可以加上 -a 喔!
[[email protected] tmp]# cp -a /var/log/wtmp wtmp_2
[[email protected] tmp]# ls -l /var/log/wtmp wtmp_2
-rw-rw-r– 1 root utmp 71808 Jul 18 12:46 /var/log/wtmp
-rw-rw-r– 1 root utmp 71808 Jul 18 12:46 wtmp_2
# 瞭了吧!整個資料特性完全一模一樣ㄟ!真是不賴~這就是 -a 的特性!

範例三:復制 /etc/ 這個目錄下的所有內容到 /tmp 底下
[[email protected] tmp]# cp /etc/ /tmp
cp: omitting directory `/etc’ <== 如果是目錄,不能直接復制,要加上 -r 的參數
[[email protected] tmp]# cp -r /etc/ /tmp
# 還是要再次的強調喔! -r 是可以復制目錄,但是,檔案與目錄的權限會被改變~
# 所以,也可以利用 cp -a /etc /tmp 來下達指令喔!

範例四:將範例一復制的 bashrc 建立一個連結檔 (symbolic link)
[[email protected] tmp]# ls -l bashrc
-rw-r–r– 1 root root 395 Jul 18 22:08 bashrc
[[email protected] tmp]# cp -s bashrc bashrc_slink
[[email protected] tmp]# cp -l bashrc bashrc_hlink
[[email protected] tmp]# ls -l bashrc*
-rw-r–r– 2 root root 395 Jul 18 22:08 bashrc
-rw-r–r– 2 root root 395 Jul 18 22:08 bashrc_hlink
lrwxrwxrwx 1 root root 6 Jul 18 22:31 bashrc_slink -> bashrc
# 那個 bashrc_slink 是由 -s 的參數造成的,建立的是一個『快捷方式』,
# 所以您會看到在檔案的最右邊,會顯示這個檔案是『連結』到哪裏去的!
# 至於那個 bashrc_hlink 有趣了!建立了這個檔案之後, bashrc 與 bashrc_hlink
# 所有的參數都一樣,只是,第二欄的 link 數改變成為 2 了~而不是原本的 1 喔!
# 這兩種連結的方式的異同,我們會在下一章裏面進行介紹的!

範例五:若 ~/.bashrc 比 /tmp/bashrc 新才復制過來
[[email protected] tmp]# cp -u ~/.bashrc /tmp/bashrc
# 這個 -u 的特性,是在目標檔案與來源檔案有差異時,才會復制的。
# 所以,比較常被用於『備份』的工作當中喔! ^_^

範例六:將範例四造成的 bashrc_slink 復制成為 bashrc_slink_2
[[email protected] tmp]# cp bashrc_slink bashrc_slink_2
[[email protected] tmp]# ls -l bashrc_slink*
lrwxrwxrwx 1 root root 6 Jul 18 22:31 bashrc_slink -> bashrc
-rw-r–r– 1 root root 395 Jul 18 22:48 bashrc_slink_2
# 這個例子也是很有趣喔!原本復制的是連結檔,但是卻將連結檔的實際檔案復制過來了
# 也就是說,如果沒有加上任何參數時,復制的是源文件,而非連結文件的屬性
# 若要復制連結文件的屬性,就得要使用 -d 或者 -a 的參數了!

範例七:將家目錄的 .bashrc 及 .bash_history 復制到 /tmp 底下
[[email protected] tmp]# cp ~/.bashrc ~/.bash_history /tmp
# 可以將多個數據一次復制到同一個目錄去!
這個 cp 的功能很多,而由於我們常常在進行一些數據的復制,所以也會常常用到這個指令的。 一般來說,我們如果去復制別人的數據 (當然,該檔案您必須要有 read 的權限才行啊! ^_^) 時, 總是希望復制到的數據最後是我們自己的,所以,在預設的條件中, cp 的來源檔與目的檔的權限是不同的,目的檔的擁有者通常會是指令操作者本身。舉例來說, 上面的範例二中,由於我是 root 的身份,因此復制過來的檔案擁有者與群組就改變成為 root 所有了! 這樣說,可以明白嗎?! ^_^

由於具有這個特性,因此,當我們在進行備份的時候,某些需要特別註意的特殊權限檔案, 例如密碼文件 (/etc/shadow) 以及一些設定檔,就不能直接以 cp 來復制,而必須要加上 -a 或者是 -p 等等可以完整復制檔案權限的參數才行!另外,如果您想要復制檔案給其它的使用者,也必須要註意到檔案的權限(包含讀、寫、執行以及檔案擁有者等等),否則,其它人還是無法針對您給予的檔案進行修訂的動作喔!註意註意!

至於上面的範例當中,第四個範例是最有趣的,使用 -l 及 -s 都會建立所謂的連結檔 (link file),但是這兩種連結檔確有不一樣的展現情況。這是怎麽一回事啊? 那個 -l 就是所謂的 hard link ,至於 -s 則是 symbolic link ,這裏先不介紹, 因為這個涉及 i-node 的相關知識,我們還沒有介紹到,下一章再來討論這個 link 的問題喔! 總之,由於 cp 有種種的檔案屬性與權限的特性,所以,在復制時,您必須要清楚的了解到:
是否需要完整的保留來源檔案的信息?
來源檔案是否為連結檔 (symbolic link file)?
來源檔是否為特殊的檔案,例如 FIFO, socket 等?
來源文件是否為目錄?

需要說明的是,為防止用戶在不經意的情況下用cp命令破壞另一個文件,如用戶指定的目標文件名已存在,用cp命令拷貝文件後,這個文件就會被新源文件覆蓋,因此,建議用戶在使用cp命令拷貝文件時,最好使用i選項。

本文出自 “12690807” 博客,請務必保留此出處http://12700807.blog.51cto.com/12690807/1939446

linux cp命令參數及用法詳解---linux 復制文件命令cp