Linux中的stat命令使用简介

ls 命令可能是每一个 Unix 使用者第一个学习的命令之一, 但它仅仅显示了 stat 命令能给出的信息的一小部分。

stat 命令从文件的索引节点获取信息。 正如你可能已经了解的那样, 每一个系统里的文件都存有三组日期和时间, 它们包括最近修改时间(即使用 ls -l 命令时显示的日期和时间), 最近状态改变时间(包括对文件重命名)和最近访问时间。

使用长列表模式查看文件信息, 你会看到类似下面的内容:

代码如下:

$ ls -l trythis

-rwx------ 1 shs unixdweebs 109 Nov 11 2013 trythis

使用 stat 命令, 你会看到下面这些:

代码如下:

$ stat trythis

File: `trythis'

Size: 109 Blocks: 8 IO Block: 262144 regular file

Device: 18h/24d Inode: 12731691 Links: 1

Access: (0700/-rwx------) Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)

Access: 2014-09-09 19:27:58.000000000 -0400

Modify: 2013-11-11 08:40:10.000000000 -0500

Change: 2013-11-11 08:40:10.000000000 -0500

在上面的情形中, 文件的状态改变和文件修改的日期/时间是相同的, 而访问时间则是相当近的时间。 我们还可以看到文件使用了 8 个块, 以及两种格式显示的文件权限 -- 八进制(0700)格式和 rwx 格式。 在第三行显示的索引节点是 12731681. 文件没有其它的硬链接(Links: 1)。 而且, 这个文件是一个常规文件。

把文件重命名, 你会看到状态改变时间发生变化。

这里的 ctime 信息, 最早设计用来存储文件的创建(create)日期和时间, 但后来不知道什么时候变为用来存储状态修改(change)时间。

代码如下:

$ mv trythis trythat

$ stat trythat

File: `trythat'

Size: 109 Blocks: 8 IO Block: 262144 regular file

Device: 18h/24d Inode: 12731691 Links: 1

Access: (0700/-rwx------) Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)

Access: 2014-09-09 19:27:58.000000000 -0400

Modify: 2013-11-11 08:40:10.000000000 -0500

Change: 2014-09-21 12:46:22.000000000 -0400

改变文件的权限也会改变 ctime 域。

你也可以配合通配符来使用 stat 命令以列出一组文件的状态:

代码如下:

$ stat myfile*

File: `myfile'

Size: 20 Blocks: 8 IO Block: 262144 regular file

Device: 18h/24d Inode: 12731803 Links: 1

Access: (0640/-rw-r-----) Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)

Access: 2014-08-23 03:00:36.000000000 -0400

Modify: 2014-08-22 12:02:12.000000000 -0400

Change: 2014-08-22 12:02:12.000000000 -0400

File: `myfile2'

Size: 20 Blocks: 8 IO Block: 262144 regular file

Device: 18h/24d Inode: 12731806 Links: 1

Access: (0640/-rw-r-----) Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)

Access: 2014-08-23 03:00:36.000000000 -0400

Modify: 2014-08-22 12:03:30.000000000 -0400

Change: 2014-08-22 12:03:30.000000000 -0400

File: `myfile3'

Size: 40 Blocks: 8 IO Block: 262144 regular file

Device: 18h/24d Inode: 12730533 Links: 1

Access: (0640/-rw-r-----) Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)

Access: 2014-08-23 03:00:36.000000000 -0400

Modify: 2014-08-22 12:03:59.000000000 -0400

Change: 2014-08-22 12:03:59.000000000 -0400

如果我们喜欢的话, 我们也可以通过其他命令来获取这些信息。

向 ls -l 命令添加 "u" 选项, 你会看到下面的结果。 注意这个选项会显示最后访问时间, 而添加 "c" 选项则会显示状态改变时间(在本例中, 是我们重命名文件的时间)。

代码如下:

$ ls -lu trythat

-rwx------ 1 shs unixdweebs 109 Sep 9 19:27 trythat

$ ls -lc trythat

-rwx------ 1 shs unixdweebs 109 Sep 21 12:46 trythat

stat 命令也可应用与文件夹。

在这个例子中, 我们可以看到有许多的链接。

代码如下:

$ stat bin

File: `bin'

Size: 12288 Blocks: 24 IO Block: 262144 directory

Device: 18h/24d Inode: 15089714 Links: 9

Access: (0700/drwx------) Uid: ( 263/ shs) Gid: ( 100/ unixdweebs)

Access: 2014-09-21 03:00:45.000000000 -0400

Modify: 2014-09-15 17:54:41.000000000 -0400

Change: 2014-09-15 17:54:41.000000000 -0400

在这里, 我们还可以查看一个文件系统。

代码如下:

$ stat -f /dev/cciss/c0d0p2

File: "/dev/cciss/c0d0p2"

ID: 0 Namelen: 255 Type: tmpfs

Block size: 4096Fundamental block 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 可读格式表示的文件系统类型

这些信息都可以得到,stat 命令也许可以帮你以稍微不同的角度来了解你的文件。

(0)

相关推荐

  • 如何在Linux中使用date命令修改日期时间

    Linux中可使用date命令查看修改日期及时间,本例中以CentOS6为例说明. 在Linux中使用date命令修改日期时间 01 直接输入"date"可查看当前系统日期及时间( ...

  • Linux中使用hostname命令修改主机名称(非常简单)

    在Linux中修改主机名其实是一件非常容易的事情,但网上有些帖子在这一块都说得很复杂,诸如修改什么配置文件之类的等等,用hostname这个命令我们就可以很轻易地修改了。 我们直接运行hostname ...

  • Linux中使用file命令识别文件类型默认没有扩展名

    在Linux系统操作过程中,没有扩展名的文件难以识别,我们可以使用命令来识别文件类型,下面小编就给大家介绍下如何使用file命令来识别文件类型。 我们知道Linux文件系统是Linux内核支持的基本功 ...

  • linux中如何查看命令所在目录

    Linux如何快速定位命令所在的文件目录,可以参考如下方法. 操作方法 01 可以通过type命令来查询命令所在的目录. 02 type命令是用来判断shell命令的类型的,如果是内部命令,没有独立可 ...

  • Linux中使用cp命令报cp:omitting directory错误

    在Linux系统中使用cp命令对文件夹或者目录进行复制操作时,有时候会出现cp:omitting directiory的错误提示.这是怎么回事呢,下面简单来解释一下,并给出解决方法. 问题分析 01 ...

  • linux 中的MYSQL命令汇总 适合学习linux下配置mysql的朋友

    一、总结一下: 1.linux下启动mysql的命令: mysqladmin start /ect/init.d/mysql start (前面为mysql的安装路径) 2.linux下重启mysql ...

  • Linux中的ls命令详细使用

    英文全名:List即列表的意思,当我们学习某种东西的时候要做到知其所以然,当你知道了这个东西大概是个什么了以后你的思维就会联想到很多的东西学习的就会很快。 1. ls -a 列出文件下所有的文件,包括 ...

  • linux中mkdir创建目录命令使用说明

    阅读这篇文章之前建议大家先看下这篇文章:http://www./LINUX/mkdir.htm 1.命令格式: mkdir [选项] 目录... 2.命令功能: 通过 mkdir 命令可以实现在指定位 ...

  • Linux中使用whereis命令快速查找文件只限程序名

    Linux下whereis命令和find命令有点相似,whereis命令查找速度更快,但只能查找程序名,下面随小编一起来了解下whereis命令的具体用法吧。 whereis命令只搜索二进制文件(参数 ...