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命令的帮助信息

[[email protected] ~]# 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 [email protected] 

[[email protected] ~]# man cp 

2: 拷贝文件file1并更名为file2

[[email protected] kerry]# ls
file1
[[email protected] kerry]# cp file1 file2
[[email protected] kerry]# ls
file1  file2
[[email protected] kerry]# 

3:拷贝kerry目录下文件到tmp目录下

[[email protected] ~]# cp /home/kerry/*  /tmp
[[email protected] ~]# cd /tmp

4:将目录下的所有目录包括子目录陆续复制到另外一个目录

[[email protected] ~]#cp -r /home/tomcat/ /tmp/bak 

5: 复制时保留文件属性(保存与源文件相关联的修改日期、时间和访问控制列表等)

[[email protected] kerry]# ls -lrt
total 8
-rw-r--r-- 1 root root 3886 Jan 19 23:04 install.log.syslog
[[email protected] kerry]# cp -p install.log.syslog  install.log.syslog.bak1
[[email protected] kerry]# cp install.log.syslog install.log.syslog.bak2
[[email protected] 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: 以交换形式拷贝文件

[[email protected] 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
时间: 2024-11-01 10:37:04

Linux命令篇之stat命令和cp命令的相关文章

Linux——学习篇(二)之find命令

Linux中的find命令: 对于Linux而言,有着"一切皆文件"的这一特性,所以相比较windows而言对于文件没有后缀名,查找是并不轻松的的.因此,需要我们熟悉Linux下的find命令,更快地找到我们所需要的文件. 1. 命令格式 find   pathname   -options   [   -print  -exec   -ok ...] 2. 命令参数 pathname: find 命令所查找的目录路径.例如用.来表示当前目录,用.表示系统根目录. -print:   

Linux里面拷贝cp命令的使用

*********************记录下来,仅供学习.复习使用.**************************** 学习环境:Ubuntu 16.04.2 LTS 64位 cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录.它可以将单个源文件复制成一个指定文件名的具体的文件或一个已经存在的目录下.cp命令还支持同时复制多个文件,当一次复制多个文件时,目标文件参数必须是一个已经存在的目录,否则将出现错误. -a:此参数的效果和同时指定"-dpR"参数相同: -

linux dd、echo 、watch、fuser命令

  一.dd命令 以数据流进行复制,cp命令则是以文件为单位进行复制 if=数据来源    of=数据存储目标    bs=# 复制的字节数   count=# 复制几个bs   seek=# 跳过多少内容 eg:dd if=/dev/zero of /dev/sda  bs-512 count=1 抹除磁盘信息 二.echo 命令 1. echo   "n"| fdisk -l /dev/sda   echo命令直接将命令中需要的参数 通过管道送给命令 2.echo 命令可以显示字体

Linux文件与目录管理之:cp,mv,rm

在对Linux中的文件与目录进行管理时,cp(copy).mv(move).(remove)是最常用的三个命令,那么这三个命令的具体用法如何呢? 复制文件或目录:cp cp命令的主要作用就是复制文件或目录,其命令语法为: cp [OPTION]... [-T] SOURCE DEST cp [OPTION]... SOURCE... DIRECTORY cp [OPTION]... -t DIRECTORY SOURCE... 可以看出,对于cp命令,源文件可以为单个文件.多个文件或目录,目标文

Linux基础篇之五基础命令 ---- 2

回顾: 上一篇博文我们讲的是几个处理目录类的常用命令,分别是ls, cd, pwd, mkdir, rmdir, cp, rm  链接:http://ccschan.blog.51cto.com/11854461/1841723 本文主要讲文件查看类的命令,在linux中,这些命令是最基本的,也是必须掌握的. 文件查看类命令,主要有以下几个: ·cat    由第一行开始显示文件内容 ·tac     由最后一行开始逆序显示文件内容,同tac命令是倒着写的 ·nl     显示的时候,顺道输出行

Linux系统管理——基础命令篇

终于开始接触Linux,现在是一个标准的菜鸟,那么就踏踏实实,一步一步开始进阶,希望我的博客慢慢可以给后来人带来帮助. 废话少说,下面就是我所接触的Linux系统管理的一些基础命令,以及我个人添加的命令的释义,还望大大们多多指教. 一.Linux命令行基础 [[email protected] ~]# uname -r       //查看内核版本 [[email protected] ~]# uname -a       //查看内核相关详细信息 [[email protected] ~]#

Android系统篇之----Android中的run-as命令引出升降权限的安全问题(Linux中的setuid和setgid)

一.前言 最近一周比较忙,没时间写东西了,今天继续开始我们今天的话题:run-as命令,在上周的开发中,遇到一个问题,就是在使用run-as命令的时候出现了一个错误,不过当时因为工作进度的问题,这问题就搁浅没有解决,用了其他一个曲线救国的方式去解决的.那么咋们今天闲来说说Android中的run-as命令吧. 二.遇到的问题&解决问题 Android中我们知道如果设备没有root,我们想看一个应用的沙盒数据(/data/data/目录内容),在以前的方式很难办到,一般人都是选择root之后,去查

Linux命令篇之cut命令和join命令

cut命令的用法 cut是一个选取命令,就是将一段数据经过分析,取出我们想要的.一般来说,选取信息通常是针对"行"来进行分析的,并不是整篇信息分析的 (1)其语法格式为:cut  [-bn] [file] 或 cut [-c] [file]  或  cut [-df] [file] 使用说明cut 命令从文件的每一行剪切字节.字符和字段并将这些字节.字符和字段写至标准输出.如果不指定 File 参数,cut 命令将读取标准输入.必须指定 -b.-c 或 -f 标志之一. 主要参数-b

每天一个Linux命令(08)--cp命令

cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一.一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参数.但是如果是在shell脚本中执行cp时,没有-i参数时不会询问是否覆盖.这说明命令行和shell脚本的执行方式有些不同. 1.命令格式: 用法: cp [选项] [-T] 源 目的 或:cp  [选项] 源 目录 或:cp  [选项] -t 目录 源 2.命令功能: 将源文件复制至目标文件,或将多个源文件复制