首页 > 代码库 > 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命令