转载自: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