Linux命令学习总结:cp命令

Linux命令学习总结:cp命令


命令简介:

     cp命令用来复制文件或目录。指令英文原义:copy,copy files and directories

     指令所在路径:/bin/cp

命令语法:

  • cp [OPTION]… [-T]   SOURCE   DEST

  • cp [OPTION]…   SOURCE…   DIRECTORY

  • cp [OPTION]… -t DIRECTORY   SOURCE…

命令参数:

参数 长参数 描述
-a 等同于-dR
-d 复制符号链接
-f – -force 强制复制
-i 交互式模式。覆盖目标文件之前先要进行询问
-n 不覆盖
-r/-R 处理指定目录以及子目录
-v – -verbose 显示命令执行的详细信息
– -help 显示命令在线帮助
– -version 显示命令版本信息

使用示例:

1. 选项-in 和 -ni 的区别

    cp -in /app/001.log /app/file.log 
    该命令,当file.log存在时,不会覆盖file.log,即file.log不会做任何的变化,且不会有任何提示信息;file.log不存在时,会创建file.log,并用001.log的内容进行填充。 
     cp -ni /app/001.log /app/file.log 
    该命令,当file.log存在时,会提示覆盖file.log,如果选择yes,就会覆盖文件的内容;file.log不存在时,会创建file.log,并用001.log的内容进行填充。 
     总结:-i 和 -n选项放在一起的时候,后面的选项会覆盖前面的选项。

2. cp的几种使用情况总结

    (1) SOURCE为文件,DEST不存在的话,创建DEST文件,复制SOURCE的内容过去,此时新创建的DEST文件的所有者是源。 
    几种情况:

命令 描述
cp /appa/a.txt /appb/b.txt b.txt 不存在,创建b.txt文件
cp /appa/a.txt /appb/b.sh b.sh 不存在,创建b.sh文件
cp /appa/a.txt /appb/abc abc不存在,创建abc文件,注意abc是文件

    (2) 目标文件存在,overwrite,覆盖是内容覆盖,目标文件的所有者和后缀等一些文件元数据不变,cp后的文件的名称为目标文件的名称,注意数据丢失风险,建议用-i选项 
     cp -i a.txt b.txt 
     cp -i a.txt bb.sh

    (3) 目标文件存在且为目录,在DEST目录下新建与原文件同名的文件,并将源文件中内容填充至新文件中 
     cp /appa/a.txt /appb/abc 
     abc此时存在且为目录

    (4) 源文件为多个文件,目标文件存在且为目录,在目标文件夹下新建与原 
文件同名的文件,并将原文件内容复制进新文件中,在此不再举例

    (5) 源文件为目录,目标文件不存在,此时,创建指定DEST同名目录,复制SRC目录中所有文件至DEST下,举例如下: 
    创建/testdir/rootdir目录,并复制/root下所有文件到该目录内,要求保留原有权限
    答案:cp -a /root    /testdir/rootdir 
    注意:rootdir这个目录不存在,而testdir存在

    (6) 源文件为目录,目标文件存在且为目录,在DEST下新建与原目录同名的目录,并将SRC中内容复制至新目录中,举例: 
    /testdir/rootdir目录存在,复制/app/test目录本身到rootdir目录内 
    答案: cp -a /app/test    /testdir/rootdir

    (7) 源文件为目录,目标文件存在且为目录,且下面是有文件的,如何把源文件夹下面的文件拷贝到目标文件夹下面?举例: 
    /testdir/rootdir目录存在,且下面有文件和文件夹,复制/app/test目录下面的内容到rootdir目录内 
    答案: cp -a /app/test/*    /testdir/rootdir


原创文章,作者:woking,如若转载,请注明出处:http://www.178linux.com/82535

(1)
wokingwoking
上一篇 2017-07-23 22:26
下一篇 2017-07-23 23:31

相关推荐

  • 第二十二周作业

    1、请描述本地文件系统和分布式文件系统的特点; 本地文件系统: 本地文件系统主要是指Ext2,Ext3,Btrfs,XFS这类(很难概括,只好举例子),它们通常提供以下功能: 1.扩展性:随着系统容量的增加保持性能,不随容量变化而导致性能震荡。比如一个目录下的海量文件,在EXT2/3中由于目录设计问题会导致较大的性能问题。再比如EXT2/3中的Metadat…

    2017-09-23
  • Ansible中文权威

    福利贴 运维神器 Ansible 本土化在际,除了每日分享,定期更新外,还有大虾不定期解惑,更多福利可关注  http://www.178linux.com/doc/ansible/  或 扫描二维码入( 372011984 )群关注.

    Linux干货 2015-08-13
  • 抵御DDOS攻击,iptables限制TCP连接和频率

    cc攻击一到就有点兵临城下的感觉,正确的设置防护规则可以做到临危不乱,这里给出一个iptables对ip进行连接频率和并发限制,限制单ip连接和频率的设置规则的介绍 #单个IP在60秒内只允许新建20个连接,这里假设web端口就是80, iptables -I  INPUT -i eth1 -p tcp -m tcp –dpo…

    系统运维 2016-05-08
  • 把编译安装的httpd 实现服务脚本,通过service和chkconfig 进行管理

    把编译安装的httpd 实现服务脚本,通过service和chkconfig 进行管理 1 编译安装httpd 把httpd编译安装在/app/httpd/目录下。 2 在/etc/rc.d/init.d/目录下新建一个文件httpd 这个文件的目的在于让service 命令可以管理编译安装的httpd服务。 文件内容如下: [root@CentOS68 ~…

    Linux干货 2017-05-15
  • 第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@wlm ~]# useradd tuser1 [root@wlm ~]# cp -r etc/skel/ /home/tuser1/…

    Linux干货 2016-11-21
  • class15磁盘管理(二) 高级磁盘管理(一)

    挂载点和/etc/fstab 配置文件系统体系 被mount、fsck和其它程序使用 系统重启时保留文件系统体系 可以在设备栏使用文件系统卷标 使用mount -a命令挂载  /etc/fstab 中的所有文件系统 文件挂载配置文件 /etc/fstab每行定义一个要挂载的文件系统;   &nbsp…

    Linux干货 2016-09-05