linux 命令
文件类命令
cp
目录
man cp cp --h Usage: cp [OPTION]... [-T] SOURCE DEST or: cp [OPTION]... SOURCE... DIRECTORY or: cp [OPTION]... -t DIRECTORY SOURCE... 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 --attributes-only don't copy the file data, just the attributes --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 (this option is ignored when the -n option is also used) -i, --interactive prompt before overwrite (overrides a previous -n option) -H follow command-line symbolic links in SOURCE -l, --link hard link files instead of copying -L, --dereference always follow 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 -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 deprecated, 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 -s, --symbolic-link make symbolic links instead of copying -S, --suffix=SUFFIX override the usual backup suffix -t, --target-directory=DIRECTORY copy all SOURCE arguments into DIRECTORY -T, --no-target-directory treat DEST as a normal file -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 set SELinux security context of destination file to default type --context[=CTX] like -Z, or if CTX is specified then set the SELinux or SMACK security context to CTX --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. 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) 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. GNU coreutils online help: <http://www.gnu.org/software/coreutils/> For complete documentation, run: info coreutils 'cp invocation'
--version
查看版本 cp --version
--h
查看简介使用 cp --h
-a
cp -a a/ i/ 之前的目录情况: . ├── a │ ├── abc │ └── b │ └── c └── i └── e └── f 执行后的目录情况: . ├── a │ ├── abc │ └── b │ └── c └── i ├── a │ ├── abc │ └── b │ └── c └── e └── f 将a整个目录已经下面的全部递归到i目录下面 cp -a a/b/ i/ 会将b以及b下面的复制到i目录下面 复制前: . ├── a │ ├── abc │ └── b │ └── c └── i └── e └── f 复制后: . ├── a │ ├── abc │ └── b │ └── c └── i ├── b │ └── c └── e └── f
-b
cp -b fileA fileB 如果fileB已经存在,将会对fileB进行一个备份 备份名为fileB~
-f
强制操作 很多命令的这个选项都是force
-i
-i 交互 覆盖的时候进行询问 需要确认之后才会覆盖
-l
硬链接(inode相同的两个文件) 相对软链接(相当于一个链接) cp -l abc edf [root@pdemo a]# stat abc edf File: ‘abc’ Size: 4 Blocks: 8 IO Block: 4096 regular file Device: fd00h/64768d Inode: 50400245 Links: 2 Birth: - File: ‘edf’ Size: 4 Blocks: 8 IO Block: 4096 regular file Device: fd00h/64768d Inode: 50400245 Links: 2
-R -r
cp -r a i 复制前: . ├── a │ ├── abc │ └── b │ └── c └── i └── e └── f 复制后: . ├── a │ ├── abc │ └── b │ └── c └── i └── e └── f
-u
更新 进当source 比des 文件更新的时候会更新 [root@pdemo cp-test]# cp -u a/abc i [root@pdemo cp-test]# ll i/abc -rw-r--r-- 1 root root 4 Mar 29 20:49 i/abc [root@pdemo cp-test]# [root@pdemo cp-test]# [root@pdemo cp-test]# [root@pdemo cp-test]# [root@pdemo cp-test]# date Sun Mar 29 20:50:00 CST 2020 再次执行 源文件没有更新的话 不执行 [root@pdemo cp-test]# cp -u a/abc i [root@pdemo cp-test]# [root@pdemo cp-test]# [root@pdemo cp-test]# ll i/abc -rw-r--r-- 1 root root 4 Mar 29 20:49 i/abc 修改源文件 再次测试 [root@pdemo cp-test]# date Sun Mar 29 20:51:03 CST 2020 [root@pdemo cp-test]# [root@pdemo cp-test]# echo hello >> a/abc [root@pdemo cp-test]# [root@pdemo cp-test]# [root@pdemo cp-test]# cp -u a/abc i cp: overwrite ‘i/abc’? 此处因为有默认的alias cp=“cp -i” 导致覆盖的时候会出现交互式询问