1 cp 拷贝、复制

NAME

cp - copy files and directories

SYNOPSIS

cp [OPTION]... [-T] SOURCE DEST        -- cp 源位置 目标位置

cp [OPTION]... SOURCE... DIRECTORY

cp [OPTION]... -t DIRECTORY SOURCE...

DESCRIPTION

Copy SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY. 拷贝一个文件(或多个文件)到目标目录

Mandatory arguments to long options are mandatory for short options too.

-a, --archive

same as -dR --preserve=all

--backup[=CONTROL]

make a backup of each existing destination file

-b like --backup but does not accept an argument

--copy-contents

copy contents of special files when recursive

-d same as --no-dereference --preserve=links

-f, --force 强制复制

if an existing destination file cannot be opened, remove it and try again (redundant if the -n option is used)

如果如已有的目标文件不能打开,删之,在尝试一次拷贝

-i, --interactive 交互式拷贝

prompt before overwrite (overrides a previous -n option) 如果目标文件已经存在,在覆盖时或询问是否覆盖

-H follow command-line symbolic links in SOURCE

-n, --no-clobber

do not overwrite an existing file (overrides a previous -i option)

-P, --no-dereference 非解除参考(如果源是一个软链接文件,则只拷贝该连接,不拷贝文件本身)

never follow symbolic links in SOURCE

测试:

[hadoop3@hadoop3 ~]$ ln -s file01.dat file01-slink.dat ##创建软连接文件file01-slink.dat

[hadoop3@hadoop3 ~]$ ll

total 4

-rw-rw-r--. 1 hadoop3 hadoop3 171 Jul 12 10:51 file01.dat

lrwxrwxrwx. 1 hadoop3 hadoop3 10 Jul 12 10:53 file01-slink.dat -> file01.dat

[hadoop3@hadoop3 ~]$ ln file01.dat file01-hlink.dat ##创建硬连接文件file01-hlink.dat

[hadoop3@hadoop3 ~]$ ll

total 8

-rw-rw-r--. 2 hadoop3 hadoop3 171 Jul 12 10:51 file01.dat

-rw-rw-r--. 2 hadoop3 hadoop3 171 Jul 12 10:51 file01-hlink.dat

lrwxrwxrwx. 1 hadoop3 hadoop3 10 Jul 12 10:53 file01-slink.dat -> file01.dat

[hadoop3@hadoop3 ~]$ cp -P file01-slink.dat backup/ ##非解除参考拷贝

[hadoop3@hadoop3 ~]$ ls -al backup/

total 8

drwxrwxr-x. 2 hadoop3 hadoop3 4096 Jul 12 10:56 .

drwx------. 3 hadoop3 hadoop3 4096 Jul 12 10:55 ..

lrwxrwxrwx. 1 hadoop3 hadoop3 10 Jul 12 10:56 file01-slink.dat -> file01.dat ##因为backup目录中没有file01.dat文件,所以下面的cat报错

[hadoop3@hadoop3 backup]$ cat file01-slink.dat

cat: file01-slink.dat: No such file or directory

[hadoop3@hadoop3 ~]$ cp file01.dat backup/ ##手动把符号链接引用的源文件拷贝到backup目录,cat就可以查看符号连接文件的内容了

[hadoop3@hadoop3 ~]$ cd backup/

[hadoop3@hadoop3 backup]$ ls -ln

total 4

-rw-rw-r--. 1 500 500 171 Jul 12 11:05 file01.dat

lrwxrwxrwx. 1 500 500 10 Jul 12 10:56 file01-slink.dat -> file01.dat

[hadoop3@hadoop3 backup]$ cat file01.dat

file01

-l, --link

link files instead of copying

sdfdsf

dgddsgd

gdfgdfhhgfhhfghfghfgjfjhgjhg

1111111111111111111111111111111111111111111111111

-L, --dereference

always follow symbolic links in SOURCE

[hadoop3@hadoop3 ~]$ cp -L file01-slink.dat backup/ ##软连接文件file01-slink.dat拷贝到backup目录中,得到的目的文件的大小为171个字节

[hadoop3@hadoop3 ~]$ ls -ln backup/ ##cp -L 拷贝软连接时,会把连接引用的源文件的内容一起拷贝过来,得到的是一个普通的文件 -- 即解引用

total 4

-rw-rw-r--. 1 500 500 171 Jul 12 11:08 file01-slink.dat

[hadoop3@hadoop3 ~]$ cat backup/file01-slink.dat

file01

-l, --link

link files instead of copying

sdfdsf

dgddsgd

gdfgdfhhgfhhfghfghfgjfjhgjhg

1111111111111111111111111111111111111111111111111

-p same as --preserve=mode,ownership,timestamps

--preserve[=ATTR_LIST] 连同文件的属性一起复制过去(而不是使用默认的属性 --- 备份常用)

preserve the specified attributes (default: mode,ownership,timestamps), if possible additional attributes: context, links, xattr, all

保存特定的属性(如,文件的模式、所有者、时间戳) 如果可能附加的属性也会保留

-c same as --preserve=context

--no-preserve=ATTR_LIST

don't preserve the specified attributes

--parents

use full source file name under DIRECTORY

-R, -r, --recursive

copy directories recursively 递归地拷贝目录

--reflink[=WHEN]

control clone/CoW copies. See below.

--remove-destination

remove each existing destination file before attempting to open it (contrast with --force) 移除每个现存的目标文件(在试图打开之前)

--sparse=WHEN

control creation of sparse files. See below. 控制稀疏文件的创建

--strip-trailing-slashes

remove any trailing slashes from each SOURCE argument 移除每个源参数中的末尾斜杠

-l, --link 硬连接

link files instead of copying

-s, --symbolic-link 软连接

make symbolic links instead of copying 做符号连接(当然是软连接)而不是拷贝

-S, --suffix=SUFFIX

override the usual backup suffix 指定通用的备份前缀

-t, --target-directory=DIRECTORY        目标dest是一个目录

copy all SOURCE arguments into DIRECTORY 拷贝所有源参到目录

-T, --no-target-directory                目标dest是一个文件

treat DEST as a normal file 把DEST参数看作为一个普通的文件

-u, --update

copy only when the SOURCE file is newer than the destination file or when the destination file is missing

更新式拷贝 --- 仅当源文件比目标文件新或目标文件丢失时,才进行拷贝

-v, --verbose

explain what is being done

-x, --one-file-system

stay on this file system

-Z, --context=CONTEXT

set security context of copy to CONTEXT

--help display this help and exit

--version

output version information and exit

By default, sparse SOURCE files are detected by a crude heuristic and the corresponding DEST file is made sparse as well.

That is the behavior selected by --sparse=auto.

Specify --sparse=always to create a sparse DEST file whenever the SOURCE file contains a long enough sequence of zero bytes.

Use --sparse=never to inhibit creation of sparse files.

When --reflink[=always] is specified, perform a lightweight copy, where the data blocks are copied only when modified.

默认,执行的是一个轻量的拷贝,仅拷贝哪些修改了的数据块

If this is not possible the copy fails, or if --reflink=auto is specified, fall back to a standard copy. 指定--reflink=auto回到标准拷贝模式

The backup suffix is '~', unless set with --suffix or SIMPLE_BACKUP_SUFFIX.

The version control method may be selected via the --backup option or through the VERSION_CONTROL environment variable.

Here are the values:

none, off

never make backups (even if --backup is given) 如果version_control环境变量值为none,则拷贝时不做备份(即使指定了--backup选项)

numbered, t

make numbered backups

existing, nil

numbered if numbered backups exist, simple otherwise

simple, never

always make simple backups

As a special case, cp makes a backup of SOURCE when the force and backup options are given and SOURCE and DEST are the same name for an existing, regular file.

cp使用:

1 同时拷贝多个文件

格式: cp 文件1 文件2 目的目录

[hadoop3@hadoop3 ~]$ ls -ln

total 16

-rw-rw-r--. 1 500 500 176 Jul 12 11:15 a_1.txt

-rw-rw-r--. 1 500 500 137 Jul 12 11:16 a_2.txt

-rw-rw-r--. 1 500 500 106 Jul 12 11:16 a_3.txt

drwxrwxr-x. 2 500 500 4096 Jul 12 11:16 files

[hadoop3@hadoop3 ~]$ cp a_1.txt a_2.txt files/

[hadoop3@hadoop3 ~]$ ls -ln files/

total 8

-rw-rw-r--. 1 500 500 176 Jul 12 11:17 a_1.txt

-rw-rw-r--. 1 500 500 137 Jul 12 11:17 a_2.txt

2 拷贝一个目录

[hadoop3@hadoop3 ~]$ cp -r files files_backup

[hadoop3@hadoop3 ~]$ tree

.

├── a_1.txt

├── a_2.txt

├── a_3.txt

├── files

│   ├── a_1.txt

│   └── a_2.txt

└── files_backup

├── a_1.txt

└── a_2.txt

3硬连接拷贝,而不仅仅是拷贝一个文件(拷贝出来的文件与源文件会同步更新的)

[hadoop3@hadoop3 ~]$ mkdir links

[hadoop3@hadoop3 ~]$ cp -l a_2.txt links

[hadoop3@hadoop3 ~]$ ls -ln links

total 4

-rw-rw-r--. 2 500 500 137 Jul 12 11:16 a_2.txt

[hadoop3@hadoop3 ~]$ echo ' adddd' >> a_2.txt ##向源文件追加字符

[hadoop3@hadoop3 ~]$ cat a_2.txt

22222222222222222222222

2222222222222222222222222222222

222222222222222222222222222222222222

2222222222222222222222222222222222222222222

adddd

[hadoop3@hadoop3 ~]$ cat links/a_2.txt ##硬连接文件的内容同步更新了

22222222222222222222222

2222222222222222222222222222222

222222222222222222222222222222222222

2222222222222222222222222222222222222222222

adddd

4 软连接拷贝 -- 符号链接

[hadoop3@hadoop3 ~]$ cp -s a_3.txt links/

cp: `links/a_3.txt': can make relative symbolic links only in current directory

##跨目录不能创建相对符号连接

[hadoop3@hadoop3 ~]$ cp -s /home/hadoop3/a_3.txt links

[hadoop3@hadoop3 ~]$ ls -ln links

total 4

-rw-rw-r--. 2 500 500 145 Jul 12 11:28 a_2.txt

lrwxrwxrwx. 1 500 500 21 Jul 12 11:34 a_3.txt -> /home/hadoop3/a_3.txt

cp拷贝的更多相关文章

  1. ubuntu mount u盘以及cp拷贝文件夹

    如果是ubuntu桌面环境的话,不用mount,接入的U盘就可以直接被系统识别,访问起来非常方便,但如果没有桌面环境呢,比如在ubuntu server端,如何访问U盘呢? 第一步:查看U盘信息sud ...

  2. linux cp 拷贝文件或目录

    cp 拷贝文件或目录 默认不能拷贝目录 常用来备份: [root@MongoDB ~]# cp a.txt /tmp/ [root@MongoDB ~]# cp /root/a.txt /tmp/ c ...

  3. Linux命令(2)--cp拷贝、mv剪切、head、tail追踪、tar归档

    文章目录 一.知识回顾 ls cd 二.Linux基本操作(二) 1.cp 拷贝 2.mv 移动(剪切) 3.head 头部 4.tail 追踪(尾部) 5.tar 归档 查看 压缩 解压 总结 一. ...

  4. linux 命令cp拷贝

    linux复制指定目录下的全部文件到另一个目录中复制指定目录下的全部文件到另一个目录中文件及目录的复制是经常要用到的.linux下进行复制的命令为cp.假设复制源目录 为 dir1 ,目标目录为dir ...

  5. shell cp拷贝的用法

    个人觉得这个记录的比较全 自己查阅: cp [options] <source file or directory> <target file or directory> 或 ...

  6. linux cp 拷贝不覆盖源文件

    cp 参数 CP() User Commands CP() NAME cp - copy files and directories SYNOPSIS cp [OPTION]... [-T] SOUR ...

  7. docker cp 拷贝文件 和 进入容器

    进入正在运行的容器 # 进入容器 新开一个终端 # docker exec -it 容器id /bin/bash docker exec -it eaac94ef6926 /bin/bash # 进入 ...

  8. cp -拷贝文件出现错误

    对于cp -a最主要的用法是在保留原文件属性的前提下复制文件. 如果出现了拷贝文件错误,在文件前面加上-a 即可

  9. Linux 命令 - cp: 拷贝文件和目录

    命令格式 cp [OPTION]... [-T] SOURCE DEST cp [OPTION]... SOURCE... DIRECTORY cp [OPTION]... -t DIRECTORY ...

随机推荐

  1. leetcode 350 easy

    350. Intersection of Two Arrays II class Solution { public: vector<int> intersect(vector<in ...

  2. web前端学习(四)JavaScript学习笔记部分(3)-- JavaScript函数+异常处理+事件处理

    1.Javascript函数-了解函数的用途 1.1.函数: 函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块 2.Javascript函数-定义函数 2.1.function必须小写 3. ...

  3. GCC/GDB学习

    GCC学习 1.gcc是根据后缀名来区分文件的 .c : c语言源文件 .a : 目标文件构成的库文件 .C/.cc/.cxx : c++源文件 .h : 头文件 .i : 预处理过的C源文件 .ii ...

  4. JS的八大数据类型

    js中的数据类型,包括基本数据类型(Number,String,Boolean, Undefined,Null)和   复杂(引用)数据类型(Object,Array,Function) 基本数据类型 ...

  5. Liferay如何连接本地的数据库

    Liferay自带的数据库非常迷你,一般就是玩玩的. 在真实的开发过程中,我们往往需要把它与我们本地的数据库相连. 有3中方法,我在这里就只介绍我自己最喜欢的方法啦.连的是mysql 1.在Lifer ...

  6. Linux常用命令4 帮助命令

    1.帮助命令:man 命令英文原意:manual 命令所在路径:/usr/bin/man    执行权限:所有用户 语法:man [命令或配置文件] 功能描述:获得命令或者配置文件的帮助信息 例如:m ...

  7. 人物-旅行-潘德明-Info:《近代中国徒步环游世界第一人:潘德明 》

    ylbtech-人物-旅行-潘德明-Info:<近代中国徒步环游世界第一人:潘德明 > 1.返回顶部 1. 近代中国徒步环游世界第一人:潘德明 2016-10-12 18:01 “以世界为 ...

  8. 手机monkey测试BUG重现及解决方法

    目录 1.1 Monkey测试简介...1 1.2 Monkey程序介绍...1 1.3 Monkey命令的简单帮助...2 1.4 Monkey命令参数介绍...2 1.5 Monkey测试步骤.. ...

  9. 《第一行代码》之——1.Android简介

    Android简介 Android系统架构 (图片源自维基百科) Android大致分为四层架构,五块区域. Linux内核层 Android系统基于Linux2.6,这一层为Android设备的各种 ...

  10. 【Django入坑之路】Django与Query Ajax的交互

    1:Jquery.ajax后端交互数据 $.ajax({ Url: /路由处理/, Type: GET/POST, #传送请求类型 Data: {user: “ XXXX”,pass:”XXXX”}, ...