天天看點

linux指令cp指令行參數,linux cp指令參數及用法詳解---linux 複制檔案指令cp

轉載自:html

[[email protected] ~]# cp [-adfilprsu] 來源檔(source) 目的檔(destination)  [[email protected] ~]# 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 !  最後須要注意的,若是來源檔有兩個以上,則最後一個目的檔案必定要是『目錄』才行!linux

範例:  範例一:将家目錄下的 .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 這個參數來強制直接覆寫!bash

範例二:将 /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 的特性!socket

範例三:複制 /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 來下達指令喔!ide

範例四:将範例一複制的 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 喔!  # 這兩種連結的方式的異同,咱們會在下一章裡面進行介紹的!spa

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

範例六:将範例四形成的 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 全部了! 這樣說,能夠明白嗎?! ^_^get

因為具備這個特性,是以,當咱們在進行備份的時候,某些須要特别注意的特殊權限檔案, 例如密碼檔案 (/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選項。

http://www.linuxso.com/command/cp.html