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

首頁 > 系統 > Linux > 正文

Linux VPS中cp復制文件命令應用詳解

2024-08-27 23:59:08
字體:
來源:轉載
供稿:網友

cp命令在Linux VPS操作和應用過程中還是比較常用的,我們可以用來復制文件或者文件夾,重命名一個新的文件以及復制到其他路徑中用于文件的轉移.

舉例用法:

1、復制root目錄下的itbulu.com.jpg文件到 /wwwroot/web 目錄中

cd /root/

cp -v itbulu.com.jpg /wwwroot/web/

2、復制 itbulu.com.jpg 文件變成itbulu-2.com.jpg文件

cp -v itbulu.com.jpg itbulu.com-2.jpg

這里,老蔣順帶分享一個mv的命令,是用于文件的轉移(剪切)、重命名文件.

1、文件改名

mv itbulu.log itbulu.txt

這里是將itbulu.log改成itbulu.txt文件名

2、文件轉移

mv itbulu.log file

將itbulu.log移動到file文件夾中.

-b:若需覆蓋文件,則覆蓋前先行備份.

-f:force 強制的意思,如果目標文件已經存在,不會詢問而直接覆蓋.

-i:若目標文件已經存在時,就會詢問是否覆蓋.

-u:若目標文件已經存在,且文件比較新,才會更新.

mv常用的參數.

cp命令介紹

功能:復制文件或目錄

說明:cp指令用于復制文件或目錄,如同時指定兩個以上的文件或目錄,且最后的目的地是一個已經存在的目錄,則它會把前面指定的所有文件或目錄復制到此目錄中,若同時指定多個文件或目錄,而最后的目的地并非一個已存在的目錄,則會出現錯誤信息.

參數:

 -a 或 --archive 此參數的效果和同時指定"-dpR"參數相同

-b 或 --backup  刪除、覆蓋目的文件先備份,備份的文件或目錄亦建立為符號鏈接,并指向源文件或目錄鏈接的源文件或目錄。假如沒有加上這個參數,在復制過程中若遇到符號鏈接,則會直接復制源文件或目錄

-f 或 --force   強行復制文件或目錄, 不論目的文件或目錄是否已經存在

-i 或 --interactive 覆蓋文件之前先詢問用戶

-l 或 --link對源文件建立硬鏈接,而非復制文件

-p 或 --preserve保留源文件或目錄的屬性,包括所有者、所屬組、權限與時間

-P 或 --parents 保留源文件或目錄的路徑,此路徑可以是絕對路徑或相對路徑,且目的目錄必須已經豐在

-r  遞歸處理,將指定目錄下的文件與子目錄一并處理。若源文件或目錄的形態,不屬于目錄或符號鏈接,則一律視為普通文件處理

-R 或 --recursive   遞歸處理,將指定目錄下的文件及子目錄一并處理

-s 或 --symbolic-link  對源文件建立符號鏈接,而非復制文件

-S <備份字尾字符串> 或 --suffix=<備份字尾字符串> 用"-b"參數備份目的文件后,備份文件的字尾會被加上一個備份字符串。默認的備份字尾符串是符號"~"

-u 或 --update  使用這項參數之后,只會在源文件的修改時間(Modification Time)較目的文件更新時,或是名稱相互對應的目的文件并不存在,才復制文件

-v 或 --verbose 顯示執行過程

-V <備份方式> 或 --version-control=<備份方式>  指定當備份文件時,備份文件名的命名方式,有以下3種:

1.numbered或t,將使用備份編號,會在字尾加上~1~字符串,其數字編號依次遞增

2.simple或never 將使用簡單備份,默認的備份字尾字符串是~,也可通過-S來指定

3.existing或nil將使用當前方式,程序會先檢查是否存在著備份編號,若有則采用備份編號,若無則采用簡單備份

-x 或 --one-file-system  復制的文件或目錄存放的文件系統,必須與cp指令執行時所處的文件系統相同,否則不復制,亦不處理位于其他分區的文件

--help  顯示在線幫助

--sparse=<使用時機>  設置保存希疏文件的時機

--version   顯示版本

范例一:將家目錄下的 .bashrc 復制到 /tmp 下,并更名為 bashrc

  1. [root@linux ~]# cd /tmp  
  2. [root@linux tmp]# cp ~/.bashrc bashrc  
  3. [root@linux tmp]# cp -i ~/.bashrc bashrc  
  4. cp: overwrite `basrhc’? n  

# 重復作兩次動作,由于 /tmp 底下已經存在 bashrc 了,加上 -i 參數.

# 則在覆蓋前會詢問使用者是否確定,可以按下 n 或者 y 呢.

# 但是,反過來說,如果不想要詢問時,則加上 -f 這個參數來強制直接覆蓋.

范例二:將 /var/log/wtmp 復制到 /tmp 底下.

  1. [root@linux tmp]# cp /var/log/wtmp . <==想要復制到目前的目錄,最后的 . 不要忘  
  2. [root@linux tmp]# ls -l /var/log/wtmp wtmp  
  3. -rw-rw-r– 1 root utmp 71808 Jul 18 12:46 /var/log/wtmp  
  4. -rw-r–r– 1 root root 71808 Jul 18 21:58 wtmp  

注意到了嗎?在不加任何參數的情況下,檔案的所屬者會改變,連權限也跟著改變了,這是個很重要的特性,要注意喔,還有,連檔案建立的時間也不一樣了,如果您想要將檔案的所有特性都一起復制過來,可以加上 -a 喔.

  1. [root@linux tmp]# cp -a /var/log/wtmp wtmp_2  
  2. [root@linux tmp]# ls -l /var/log/wtmp wtmp_2  
  3. -rw-rw-r– 1 root utmp 71808 Jul 18 12:46 /var/log/wtmp  
  4. -rw-rw-r– 1 root utmp 71808 Jul 18 12:46 wtmp_2  

# ?了吧,整個資料特性完全一模一樣,真是不賴~這就是 -a 的特性.

范例三:復制 /etc/ 這個目錄下的所有內容到 /tmp 底下:

  1. [root@linux tmp]# cp /etc/ /tmp  
  2. cp: omitting directory `/etc’ <== 如果是目錄,不能直接復制,要加上 -r 的參數  
  3. [root@linux tmp]# cp -r /etc/ /tmp  
  4. # 還是要再次的強調喔! -r 是可以復制目錄,但是,檔案與目錄的權限會被改變~  
  5. # 所以,也可以利用 cp -a /etc /tmp 來下達指令喔! 

范例四:將范例一復制的 bashrc 建立一個連結檔(symbolic link)

  1. [root@linux tmp]# ls -l bashrc  
  2. -rw-r–r– 1 root root 395 Jul 18 22:08 bashrc  
  3. [root@linux tmp]# cp -s bashrc bashrc_slink  
  4. [root@linux tmp]# cp -l bashrc bashrc_hlink  
  5. [root@linux tmp]# ls -l bashrc*  
  6. -rw-r–r– 2 root root 395 Jul 18 22:08 bashrc  
  7. -rw-r–r– 2 root root 395 Jul 18 22:08 bashrc_hlink  
  8. 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 新才復制過來

[root@linux tmp]# cp -u ~/.bashrc /tmp/bashrc

這個 -u 的特性,是在目標檔案與來源檔案有差異時,才會復制的,所以,比較常被用于『備份』的工作當中喔.

范例六:將范例四造成的 bashrc_slink 復制成為 bashrc_slink_2

  1. [root@linux tmp]# cp bashrc_slink bashrc_slink_2  
  2. [root@linux tmp]# ls -l bashrc_slink*  
  3. lrwxrwxrwx 1 root root 6 Jul 18 22:31 bashrc_slink -> bashrc  
  4. -rw-r–r– 1 root root 395 Jul 18 22:48 bashrc_slink_2  --Vevb.com

這個例子也是很有趣喔,原本復制的是連結檔,但是卻將連結檔的實際檔案復制過來了,也就是說,如果沒有加上任何參數時,復制的是源文件,而非連結文件的屬性,若要復制連結文件的屬性,就得要使用 -d 或者 -a 的參數了.

范例七:將家目錄的 .bashrc 及 .bash_history 復制到 /tmp 底下:

[root@linux 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選項.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安达市| 义马市| 四会市| 邳州市| 大竹县| 财经| 板桥市| 乌兰浩特市| 巴青县| 通州市| 岚皋县| 龙里县| 遵义市| 双牌县| 商都县| 方正县| 丰原市| 九江县| 灵石县| 九江县| 大冶市| 定兴县| 柘城县| 伊宁县| 海伦市| 曲阳县| 和平县| 吉林省| 温宿县| 博白县| 伊春市| 神池县| 蒙阴县| 大港区| 宁陕县| 吴堡县| 定安县| 佛教| 衢州市| 衡阳县| 宁强县|