首页 > 代码库 > Linux命令篇之stat命令和cp命令
Linux命令篇之stat命令和cp命令
# stat:
ls 命令可能是每一个Unix 使用者第一个学习的命令之一, 但它仅仅显示了 stat 命令能给出的信息的一小部分。
stat 命令从文件的索引节点获取信息。正如你可能已经了解的那样, 每一个系统里的文件都存有三组日期和时间, 它们包括最近修改时间(即使用 ls -l 命令时显示的日期和时间), 最近状态改变时间(包括对文件重命名)和最近访问时间。
使用长列表模式查看文件信息, 你会看到类似下面的内容:
代码如下:
$ ls -l trythis
-rwx------ 1 shs unixdweebs109 Nov 11 2013 trythis
使用 stat 命令, 你会看到下面这些:
代码如下:
$ stat trythis
File: `trythis‘
Size: 109 Blocks: 8 IOBlock: 262144 regular file
Device: 18h/24d Inode:12731691 Links: 1
Access: (0700/-rwx------)Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)
Access: 2014-09-0919:27:58.000000000 -0400
Modify: 2013-11-1108:40:10.000000000 -0500
Change: 2013-11-1108:40:10.000000000 -0500
在上面的情形中, 文件的状态改变和文件修改的日期/时间是相同的,而访问时间则是相当近的时间。 我们还可以看到文件使用了 8 个块, 以及两种格式显示的文件权限 -- 八进制(0700)格式和 rwx格式。 在第三行显示的索引节点是 12731681. 文件没有其它的硬链接(Links: 1)。 而且, 这个文件是一个常规文件。
把文件重命名, 你会看到状态改变时间发生变化。
这里的 ctime 信息, 最早设计用来存储文件的创建(create)日期和时间, 但后来不知道什么时候变为用来存储状态修改(change)时间。
代码如下:
$ mv trythis trythat
$ stat trythat
File: `trythat‘
Size: 109 Blocks: 8 IOBlock: 262144 regular file
Device: 18h/24d Inode:12731691 Links: 1
Access: (0700/-rwx------)Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)
Access: 2014-09-0919:27:58.000000000 -0400
Modify: 2013-11-1108:40:10.000000000 -0500
Change: 2014-09-2112:46:22.000000000 -0400
改变文件的权限也会改变 ctime 域。
你也可以配合通配符来使用 stat 命令以列出一组文件的状态:
代码如下:
$ stat myfile*
File: `myfile‘
Size: 20 Blocks: 8 IOBlock: 262144 regular file
Device: 18h/24d Inode:12731803 Links: 1
Access: (0640/-rw-r-----)Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)
Access: 2014-08-2303:00:36.000000000 -0400
Modify: 2014-08-2212:02:12.000000000 -0400
Change: 2014-08-2212:02:12.000000000 -0400
File: `myfile2‘
Size: 20 Blocks: 8 IOBlock: 262144 regular file
Device: 18h/24d Inode:12731806 Links: 1
Access: (0640/-rw-r-----)Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)
Access: 2014-08-2303:00:36.000000000 -0400
Modify: 2014-08-2212:03:30.000000000 -0400
Change: 2014-08-2212:03:30.000000000 -0400
File: `myfile3‘
Size: 40 Blocks: 8 IOBlock: 262144 regular file
Device: 18h/24d Inode:12730533 Links: 1
Access: (0640/-rw-r-----)Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)
Access: 2014-08-2303:00:36.000000000 -0400
Modify: 2014-08-2212:03:59.000000000 -0400
Change: 2014-08-2212:03:59.000000000 -0400
如果我们喜欢的话, 我们也可以通过其他命令来获取这些信息。
向 ls -l 命令添加 "u" 选项, 你会看到下面的结果。 注意这个选项会显示最后访问时间, 而添加 "c" 选项则会显示状态改变时间(在本例中, 是我们重命名文件的时间)。
代码如下:
$ ls -lu trythat
-rwx------ 1 shs unixdweebs109 Sep 9 19:27 trythat
$ ls -lc trythat
-rwx------ 1 shs unixdweebs109 Sep 21 12:46 trythat
stat 命令也可应用与文件夹。
在这个例子中, 我们可以看到有许多的链接。
代码如下:
$ stat bin
File: `bin‘
Size: 12288 Blocks: 24 IOBlock: 262144 directory
Device: 18h/24d Inode:15089714 Links: 9
Access: (0700/drwx------)Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)
Access: 2014-09-2103:00:45.000000000 -0400
Modify: 2014-09-1517:54:41.000000000 -0400
Change: 2014-09-1517:54:41.000000000 -0400
在这里, 我们还可以查看一个文件系统。
代码如下:
$ stat -f /dev/cciss/c0d0p2
File:"/dev/cciss/c0d0p2"
ID: 0 Namelen: 255 Type:tmpfs
Block size: 4096Fundamentalblock size: 4096
Blocks: Total: 259366 Free:259337 Available: 259337
Inodes: Total: 223834 Free:223531
注意 Namelen (文件名长度)域, 如果文件名长于 255 个字符的话, 你会很幸运地在文件名处看到心形符号!
stat 命令还可以一次显示所有我们想要的信息。下面的例子中, 我们只想查看文件类型, 然后是硬连接数。
代码如下:
$ stat --format=%F trythat
regular file
$ stat --format=%h trythat
1
在下面的例子中, 我们查看了文件权限 -- 分别以两种可用的格式 -- 然后是文件的 SELinux 安全环境。最后,我们可以以从 Epoch 开始的秒数格式来查看文件访问时间。
代码如下:
$ stat --format=%a trythat
700
$ stat --format=%A trythat
-rwx------
$ stat --format=%C trythat
(null)
$ stat --format=%X bin
1411282845
下面全部是可用的选项:
%a 八进制表示的访问权限
%A 可读格式表示的访问权限
%b 分配的块数(参见 %B)
%B %b 参数显示的每个块的字节数
%d 十进制表示的设备号
%D 十六进制表示的设备号
%f 十六进制表示的 Raw 模式
%F 文件类型
%g 属主的组 ID
%G 属主的组名
%h 硬连接数
%i Inode 号
%n 文件名
%N 如果是符号链接,显示器所链接的文件名
%o I/O 块大小
%s 全部占用的字节大小
%t 十六进制的主设备号
%T 十六进制的副设备号
%u 属主的用户 ID
%U 属主的用户名
%x 最后访问时间
%X 最后访问时间,自 Epoch 开始的秒数
%y 最后修改时间
%Y 最后修改时间,自 Epoch 开始的秒数
%z 最后改变时间
%Z 最后改变时间,自 Epoch 开始的秒数
针对文件系统还有如下格式选项:
%a 普通用户可用的块数
%b 文件系统的全部数据块数
%c 文件系统的全部文件节点数
%d 文件系统的可用文件节点数
%f 文件系统的可用节点数
%C SELinux 的安全上下文
%i 十六进制表示的文件系统 ID
%l 文件名的最大长度
%n 文件系统的文件名
%s 块大小(用于更快的传输)
%S 基本块大小(用于块计数)
%t 十六进制表示的文件系统类型
%T 可读格式表示的文件系统类型
cp命令
命令简介:
cp命令用来复制文件或目录。指令英文原义:copy
指令所在路径:/bin/cp
命令语法:
Usage: cp [OPTION]... [-T] SOURCE DEST
or: cp [OPTION]... SOURCE... DIRECTORY
or: cp [OPTION]... -t DIRECTORY SOURCE...
命令参数:
此命令参数是Red Hat Enterprise Linux Server release 5.7下cp命令参数,不同版本Linux的cp命令参数有可能不同。
参数 | 长参数 | 描叙 |
-a | 等同于-dR | |
-b | 若删除或者覆盖目标文件,将对目标文件进行备份,备份文件以备份的字符串结尾 | |
-d | 复制符号链接 | |
-f | 强制复制 | |
-h | 强制cp命令复制符号链接。缺省值是跟随符号链接,也就是将文件复制到符号链接指向处。 | |
-i | 交互式模式。覆盖目标文件之前先要进行询问 | |
-l | 建立硬链接,而非复制 | |
-p | 源目录或者文件的属性保留 | |
-P | 源目录或者文件的路劲保留 | |
-r/-R | 处理指定目录以及子目录 | |
-v | --verbose | 显示命令执行的详细信息 |
--help | 显示命令在线帮助 | |
--version | 显示命令版本信息 |
使用示例:
1: 查看rmdir命令的帮助信息
[root@DB-Server ~]# cp --help
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
--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=link
-f, --force if an existing destination file cannot be
opened, remove it and try again
-i, --interactive prompt before overwrite
-H follow command-line symbolic links
-l, --link link files instead of copying
-L, --dereference always follow symbolic links
-P, --no-dereference never follow symbolic links
-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
--remove-destination remove each existing destination file before
attempting to open it (contrast with --force)
--sparse=WHEN control creation of sparse files
--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, --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.
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.
Report bugs to bug-coreutils@gnu.org.
或
[root@DB-Server ~]# man cp
2: 拷贝文件file1并更名为file2
[root@DB-Server kerry]# ls
file1
[root@DB-Server kerry]# cp file1 file2
[root@DB-Server kerry]# ls
file1 file2
[root@DB-Server kerry]#
3:拷贝kerry目录下文件到tmp目录下
[root@DB-Server ~]# cp /home/kerry/* /tmp
[root@DB-Server ~]# cd /tmp
4:将目录下的所有目录包括子目录陆续复制到另外一个目录
[root@DB-Server ~]#cp -r /home/tomcat/ /tmp/bak
5: 复制时保留文件属性(保存与源文件相关联的修改日期、时间和访问控制列表等)
[root@DB-Server kerry]# ls -lrt
total 8
-rw-r--r-- 1 root root 3886 Jan 19 23:04 install.log.syslog
[root@DB-Server kerry]# cp -p install.log.syslog install.log.syslog.bak1
[root@DB-Server kerry]# cp install.log.syslog install.log.syslog.bak2
[root@DB-Server kerry]# ls -lrt
total 24
-rw-r--r-- 1 root root 3886 Jan 19 23:04 install.log.syslog.bak1
-rw-r--r-- 1 root root 3886 Jan 19 23:04 install.log.syslog
-rw-r--r-- 1 root root 3886 Jan 19 23:10 install.log.syslog.bak2
6: 以交换形式拷贝文件
[root@DB-Server kerry]# cp -i /var/log/* ./
cp: overwrite `./acpid‘? n
cp: overwrite `./anaconda.log‘? n
cp: overwrite `./anaconda.syslog‘? y
cp: overwrite `./anaconda.xlog‘? n
cp: omitting directory `/var/log/audit‘
cp: overwrite `./boot.log‘? n
cp: overwrite `./boot.log.1‘? n
cp: overwrite `./boot.log.2‘? n
本文出自 “鹏哥的博客” 博客,谢绝转载!
Linux命令篇之stat命令和cp命令