cp和ln命令简述

cp和软ln命令简述

cp

         备注:

1.       该命令可以自动判断你所复制的是文件还是目录

2.       当源是一个文件,目标(目的地)不存在时,则在目的地新建一个文件,并将源文件的内容填充进新的文件中(在复制之前/app目录下并没有mima文件;wc –l的作用是查看指定文件的行数,此处查看两个文件的行数来大致判断文件是否一致。)

cp和ln命令简述

3.       当源是一个文件,目标(目的地)存在且是一个文件时,会覆盖目的文件的内容(由于root用户下的别名中定义了cp=cp –i,所以在不加参数的时候会提示是否覆盖目的文件,输入’y’即可确认覆盖,完成复制,但是也正因如此,要注意数据丢失的风险)

  cp和ln命令简述

4.       当源是一个文件,目标(目的地)存在但是一个目录时,不可能实现,文件无法覆盖文件。

  cp和ln命令简述

5.    当源是多个文件,目的地不存在时提示错误,目的地不能不存在。

6.       当源是多个文件,目的地存在,但是一个文件时,提示错误。

7.       当源是多个文件,目的地存在且是一个目录时,如果目录中存在与源文件同名的文件则覆盖;如果不存在与源文件同名的文件则新建并填充源文件中的内容;如果目的地目录中存在与源文件同名的目录,则不复制该源文件。

8.       当源是个目录,目的地不存在的时候,新建一个同名的目录,然后填充新内容。

当源是个目录,目的地存在且为目录时,在目的地新建与源目录同名的内容并将源文件中的内容复制至新目录中。

9.当源为目录时,需使用 –r选项。

参数

1       -i 覆盖前提示

备注:当系统登录的用户为root用户时,由于在~/.bashrc文件中已经定义了别名,所以root用户使用cp时默认情况下会出现提示信息。别名信息如下图所示:

cp和ln命令简述

2       -n 不覆盖(不覆盖没有写权限的文件)

3       -r -R 递归(通用大小写)

4       -d 复制软链接属性(不加-d的时候会根据路径找到源文件并复制其数据)

当复制链接时,系统会默认复制链接的原文件的内容,而不是仅仅的一个链接,相当于新建了一个文件,其内容与源文件的内容相同,但是改变该文件的内容并不会影响源文件以及链接文件的内容,当加上-d选项时才会复制链接本身。

cp和ln命令简述

cp和ln命令简述

5-p =
–perserv=mode,owner,timestamp
(复制这三个属性)

6-a 包含-dr
–perserv=all
(包含-d –r –p 的作用)

7-f 当覆盖时,如目的文件缺少写权限时,强制删除目的文件,并新建再填充内容(删除并新建,之后的目的文件的权限以及所属人所属组都会改变)。当有-n时,无效

Df  –i可以查看inode的使用数量以及剩余数量

软链接

命令:ln -s

(注意路径)

备注

1.当原文件内容发生变化时,链接文件的内容也会和原文件一样发生同样的改变,同样的,如果改变链接文件中内容也相当于改变原文件中的内容,原文件也会相应的发生改变,如下图中的命令行所示。

cp和ln命令简述

2.当复制链接时,系统会默认复制链接的原文件的内容,而不是仅仅的一个链接,相当于新建了一个文件,其内容与源文件的内容相同,但是改变该文件的内容并不会影响源文件以及链接文件的内容,当加上-d选项时才会复制链接本身,示例如下图所示:

cp和ln命令简述

cp和ln命令简述

3.当将原文件删除或者修改原文件的路径时,链接文件会失效,由此可见,软链接记录的仅仅是一个原文件的路径。当按照记录的路径找不到有效文件时,链接文件同样失效。如果重新创建一个和原来的文件相同名字的文件,则链接文件继续有效,但此时链接文件中的内容已经不再是原来第一个原文件的内容,而是与现在重建的文件的内容保持一致。示例如下图:

cp和ln命令简述

4.当使用相对路径创建链接时,需要站在链接的角度出发,从链接的当前目录出发,一步步找到被链接的目录。示例如下图所示:

cp和ln命令简述

5.当创建新链接时会产生新的inode

cp和ln命令简述

 

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

(0)
poetic snowpoetic snow
上一篇 2017-08-19
下一篇 2017-08-19

相关推荐

  • M20-1 8月3号 –权限、用户和组的管理

    一、权限管理:            ls -l                  rwxrwxrwx:               &nb…

    Linux干货 2016-08-08
  • N26-第四周

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

    Linux干货 2017-02-22
  • 计算机入门

    Linux入门 与 计算机

    Linux干货 2018-02-07
  • DNS简单概念 一

    DNS简单概念 一 DNS简单概念 一 1 §·主机角色 1 §·DNS服务器的类型: 1 §·DNS中简单术语 2 §·DNS中资源记录及其类型 2 §·DNS域与区域 4 §·BIND安全设置 5 §·BIND高级设置BIND VIEW 6   §·主机角色 在网络上不同的主机有不同的角色, 比如: DNS解析角色,邮件角色,网页服务器 §·D…

    Linux干货 2016-09-26
  • RPM软件包管理器及前端工具yum

    目前在linux系统之上软件安装方式最常见的有两种,分别是: dpkg:这个机制最早是由Debian Linux社区所开发出来的,透过dpkg的机制,Debian提供的软件就能够简单的安装起来,同时还能提供安装后的软件资讯,实在非常不错。只要是衍生于Debian的其他linux发行版,大多使用dpkg这个机制来管理软件的,包括B2D、Ubuntu等等。 RP…

    Linux干货 2016-08-20
  • 磁盘配额的限制

    用一个块新的分区当做硬盘进行磁盘的配额限制实验 堆一块新的硬盘进行三步骤 分区,格式化,挂载 以/dev/sdb为例  (1) 分区: fdisk /dev/sdb sdb 8:16 0 200G 0 disk └─sdb1 8:17 0 10G 0 part (2) 格式化: mkfs.ext4 /dev/sdb1 /dev/sdb1: UUID…

    Linux干货 2017-04-30