Linux系统中cp(copy)命令是用来复制文件或者目录的。
man cp可以获得cp的详细描述
命令格式:
cp [OPTION]... [-T] SOURCE DEST //cp [选项]…[-T]源目的
cp [OPTION]... SOURCE... DIRECTORY // cp [选项]…源…目录
cp [OPTION]... -t DIRECTORY SOURCE... // cp [选项]…-t 目录 源…
功能:
Copy SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY.
//将源文件复制至目标文件,或将多个源文件复制至目标目录。
参数:
-a 该选项通常在拷贝目录时使用。它保留链接、文件属性,并递归地拷贝目录,其作用等于dpR选项的组合。
* -d 复制符号链接文件本身,而非其指向的源文件
*(慎用)-f 强制的意思,删除已经存在的目标文件而不提示。
* -i 交互式复制,即覆盖之前提醒用户确认
-p 此时cp除复制源文件的内容外,还将把其修改时间和访问权限也复制到新文件中。(备份常用)
* -r 递归持续复制,用于目录的复制行为:若给出的源文件是一目录文件,此时cp将递归复制该目录下所有的子目录和文件。此时目标文件必须为一个目录名。
-l 不作拷贝,只是链接文件,而非复制文件本身。
-s 复制成符号链接文件(symbolic link),即“快捷方式”文件
-u 若目标比来源文件旧时,才更新,常用于“备份”工作
命令示列:
1.-i参数示例,覆盖前会提示
1
2
3
|
[root@www ~]
# cp ~/.bashrc /tmp/bashrc 复制和更名操作
[root@www ~]
# cp -i ~/.bashrc /tmp/bashrc 由于已经复制,加入-i参数后,覆盖前会做提示
cp
: overwrite `
/tmp/bashrc
'? y 按y表示确认
|
2.-a参数示例,把权限等都复制过来
1
2
3
4
5
|
[root@www ~]
# cd /tmp 进入/tmp目录
[root@www tmp]
# cp /var/log/wtmp . 要想复制到当前目录,最后要加"."
[root@www tmp]
# ls -l /var/log/wtmp wtmp
-rw-rw-r--. 1 root utmp 24960 Apr 6 14:06
/var/log/wtmp
-rw-r--r-- 1 root root 24960 Apr 6 14:39 wtmp
|
在不加任何参数的情况下,某些属性/权限会改变
文件的创建时间也不同了
如果要将文件的所有特性都一起复制过来,可以加上-a,如下所示
1
2
3
4
|
[root@www tmp]
# cp -a /var/log/wtmp wtmp3
[root@www tmp]
# ls -l /var/log/wtmp wtmp3
-rw-rw-r--. 1 root utmp 24960 Apr 6 14:06
/var/log/wtmp
-rw-rw-r--. 1 root utmp 24960 Apr 6 14:06 wtmp3
|
整个数据特性完全一样,这就是-a的特性
由于具有这个特性,因此当我们在进行备份的时候,某些需要特别注意的特殊权限文件, 例如密码档 (/etc/shadow) 以及一些配置档,就不能直接以 cp 来复制,而必须要加上 -a 或者是 -p 等等可以完整复制文件权限的选项才行!另外,如果你想要复制文件给其他的使用者, 也必须要注意到文件的权限(包含读、写、运行以及文件拥有者等等), 否则,其他人还是无法针对你给予的文件进行修订的动作喔!注意注意!
3.-r示例,将目录下的所有目录包括子目录陆续复制到另外一个目录
1
2
3
4
|
[root@www tmp]
# cp /etc/ /tmp
cp
: omitting directory `
/etc/
' 如果是目录,不能直接复制
[root@www tmp]
# cp -r /etc/ /tmp 要加入-r才能复制目录
[root@www tmp]
#
|
4.-s,-l示例,创建软链接和硬链接
1
2
3
4
5
6
7
8
|
[root@www tmp]
# ls -l bashrc
-rw-r--r-- 1 root root 206 Apr 6 14:24 bashrc
[root@www tmp]
# cp -s bashrc bashrc_slink 创建软链接,就是一个快捷方式
[root@www tmp]
# cp -l bashrc bashrc_hlink 创建硬链接
[root@www tmp]
# ls -l bashrc*
-rw-r--r-- 2 root root 206 Apr 6 14:24 bashrc 源文件i-node,是2
-rw-r--r-- 2 root root 206 Apr 6 14:24 bashrc_hlink 硬链接i-node,是2
lrwxrwxrwx 1 root root 6 Apr 6 15:07 bashrc_slink -> bashrc 软链接i-node,还是1
|
5.-u示例,若~./bashrc比/tmp/bashrc新才复制过来
1
|
[root@www tmp]
# cp -u ~/.bashrc /tmp/bashrc 常用于备份工作
|
6.-d示例,将bashrc_slink复制成为bashrc_slink_1与bashrc_slink_2
1
2
3
4
5
6
7
|
[root@www tmp]
# cp bashrc_slink bashrc_slink_1
[root@www tmp]
# cp -d bashrc_slink bashrc_slink_2
[root@www tmp]
# ls -l bashrc bashrc_slink*
-rw-r--r-- 2 root root 206 Apr 6 14:24 bashrc
lrwxrwxrwx 1 root root 6 Apr 6 15:22 bashrc_slink -> bashrc
-rw-r--r-- 1 root root 206 Apr 6 15:22 bashrc_slink_1 与源文件相同
lrwxrwxrwx 1 root root 6 Apr 6 15:22 bashrc_slink_2 -> bashrc 是连接文件
|
这个例子也是很有趣喔!原本复制的是连结档,但是却将连结档的实际文件复制过来了
也就是说,如果没有加上任何选项时,cp复制的是原始文件,而非连结档的属性!
若要复制连结档的属性,就得要使用 -d 的选项了!如 bashrc_slink_2 所示。
7.使用zdw用户,完整复制
1
2
3
4
|
[zdw@www ~]$
cp
-a
/var/log/wtmp
/tmp/zdw_wtmp
[zdw@www ~]$
ls
-l
/var/log/wtmp
/tmp/zdw_wtmp
-rw-rw-r-- 1 zdw zdw 24960 Apr 6 14:06
/tmp/zdw_wtmp
-rw-rw-r--. 1 root utmp 24960 Apr 6 14:06
/var/log/wtmp
|
由于zdw的身份并不能随意修改文件的拥有者与群组,因此虽然能够复制wtmp的相关权限与时间等属性,但是与拥有者、群组相关的,原本zdw身份无法进行的动作,即使加上 -a 选项,也是无法达成完整复制权限的!
8.把多个数据一次复制到指定目录下
1
|
[root@www tmp]
# cp ~/.bashrc ~/.bash_history /tmp 可以填写多个数据,复制到一个目录下
|
9.由于cp的别名是cp -i,在前面加\可以不使用别名
[root@bogon shell]# type cp
cp 是 `cp -i' 的别名
[root@bogon shell]# \cp 123.sh 456.sh
本文转自cix123 51CTO博客,原文链接:http://blog.51cto.com/zhaodongwei/1871242,如需转载请自行联系原作者