linux文件管理命令与命令行展开

linux文件管理命令与命令行展开

一、 Linux上的文件管理类命令有哪些,其常用的使用方法及相关示例演示

  1. rmdir: 删除空目录,如果目录里面有内容,需要删除的话,则需要使用rm命令

格式: rmdir [options] directory…

选项: -p: 递归删除

示例:在 /tmp下创建了a/b/c的目录,首先,我们删除/tmp/a目录,看系统如何提示。 第二步,使用-p选项删除这些目录。

[root@localhost tmp]# mkdir -p /tmp/a/b/c

[root@localhost tmp]# tree /tmp/a

/tmp/a

└── b

└── c

 

[root@localhost tmp]# rmdir a

rmdir: 删除 “a” 失败: 目录非空

 

[root@localhost tmp]# rmdir -p a/b/c

 

 

 

 

  1. mkdir: 创建目录

格式: mkdir [选项] 目录…

选项: -m MODE: 创建目录时,设定目录的访问权限,默认权限为755,可以使用此选项更改目录的权限,权限可以是8进制数字格式,也可以指定ugo的权限

-p: 递归创建目录,创建一个目录,如果其父目录不存在,则递归创建其父目录

示例:

[root@localhost tmp]# mkdir -m 777 a

[root@localhost tmp]# ls -ld a

drwxrwxrwx. 2 root root 6 12月 10 20:06 a

 

[root@localhost tmp]# mkdir -m u=rwx,g=rw,o=rw b

[root@localhost tmp]# ls -ld b

drwxrw-rw-. 2 root root 6 12月 10 20:07 b

 

 

[root@localhost tmp]# mkdir /e/f/g

mkdir: 无法创建目录”/e/f/g”: 没有那个文件或目录

[root@localhost tmp]# mkdir -p /e/f/g

[root@localhost tmp]#

 

 

  1. touch: 创建文件或者修改文件的时间属性

atime和mtime都可以更改,但ctime不能使用命令更改,通过更改atime和mtime,ctime会自动修改。

格式: touch [-acm][-r ref_file(参照文件)|-t time(时间值)] file(文件名)…

 

用法描述: touch 修改每个指定文件 file 的存取(access)和/或修改(modifica‐ tion)时间戳记. 除非使用-r或-t选项,这些时间戳记都将修改为当前的时间. 使用-r选项时,这些戳记将按照文件–ref_file的时间戳记来修改(即变得和ref_file时间戳记值相同).使用-t选项,则这些戳记将按照给定的时间值 time 进行修改.同时使用或同时不使用选项-a和-m,存取和修改两个戳记都将被更改.若只使用选项-a,则只修改存取戳记.同样,只使用选项-m,则只修改修改戳记.若要修改戳记的文件尚不存在,除非使用-c选项,touch将创建它(作为空文件,并赋予0666的模式且受umask值的限制)

 

选项:

-a, –time=atime, –time=access, –time=use

只修改存取时间.

-c, –no-create

如果要修改的文件不存在,此选项使touch不去创建它.

 

-m, –time=mtime, –time=modify

只修改修改时间.

-r file, –reference=file

使用参照文件 file 的时间戳记值修改指定文件的时间戳记.

-t decimtime

这里时间值 decimtime 的格式为MMDDhhmm[[CC]YY][.ss]

从左至右分别是月份,日期,小时,分钟,可选的世纪和

年,以及可选的秒. touch 将用这组数值修改指定文件的

时间戳记.请注意,这个格式与POSIX标准所规定的格式并

不一样.

实际的时间格式为年年年年月月日日时时分分[秒秒]

 

示例:

1) 使用touch创建文件file1

[root@localhost tmp]# touch file1

[root@localhost tmp]# ll file1

-rw-r–r–. 1 root root 0 12月 10 20:16 file1

[root@localhost tmp]#

 

[root@localhost tmp]# stat file1

文件:”file1″

大小:0 块:0 IO 块:4096 普通空文件

设备:fd00h/64768d Inode:67167337 硬链接:1

权限:(0644/-rw-r–r–) Uid:( 0/ root) Gid:( 0/ root)

环境:unconfined_u:object_r:user_tmp_t:s0

最近访问:2017-12-10 20:16:52.075000000 +0800

最近更改:2017-12-10 20:16:52.075000000 +0800

最近改动:2017-12-10 20:16:52.075000000 +0800

创建时间:-

 

 

 

2) 修改file1的atime为2012年10月20日19点16分

[root@localhost tmp]# touch -a -t 201210201916 file1

 

[root@localhost tmp]# stat file1

文件:”file1″

大小:0 块:0 IO 块:4096 普通空文件

设备:fd00h/64768d Inode:67167337 硬链接:1

权限:(0644/-rw-r–r–) Uid:( 0/ root) Gid:( 0/ root)

环境:unconfined_u:object_r:user_tmp_t:s0

最近访问:2012-10-20 19:16:00.000000000 +0800

最近更改:2017-12-10 20:16:52.075000000 +0800

最近改动:2017-12-10 20:33:04.285000000 +0800

创建时间:-

 

 

3) 使用touch -c,并不真正创建文件,但如果文件存在,会更新文件的三个时间戳

[root@localhost tmp]# touch -c file1

[root@localhost tmp]# stat file1

文件:”file1″

大小:0 块:0 IO 块:4096 普通空文件

设备:fd00h/64768d Inode:67167337 硬链接:1

权限:(0644/-rw-r–r–) Uid:( 0/ root) Gid:( 0/ root)

环境:unconfined_u:object_r:user_tmp_t:s0

最近访问:2017-12-10 20:34:47.505000000 +0800

最近更改:2017-12-10 20:34:47.505000000 +0800

最近改动:2017-12-10 20:34:47.505000000 +0800

创建时间:-

[root@localhost tmp]# touch -c file2

 

 

4) 修改文件file1的mtime时间为2012年10月20日19点16分

[root@localhost tmp]# touch -m -t 201210201916 file1

[root@localhost tmp]# stat file1

文件:”file1″

大小:0 块:0 IO 块:4096 普通空文件

设备:fd00h/64768d Inode:67167337 硬链接:1

权限:(0644/-rw-r–r–) Uid:( 0/ root) Gid:( 0/ root)

环境:unconfined_u:object_r:user_tmp_t:s0

最近访问:2017-12-10 20:34:47.505000000 +0800

最近更改:2012-10-20 19:16:00.000000000 +0800

最近改动:2017-12-10 20:42:13.486000000 +0800

创建时间:-

 

 

5) 使用file1的时间戳来创建file3,注意ctime没有同步

[root@localhost tmp]# stat file1

文件:”file1″

大小:0 块:0 IO 块:4096 普通空文件

设备:fd00h/64768d Inode:67167337 硬链接:1

权限:(0644/-rw-r–r–) Uid:( 0/ root) Gid:( 0/ root)

环境:unconfined_u:object_r:user_tmp_t:s0

最近访问:2017-12-10 20:34:47.505000000 +0800

最近更改:2012-10-20 19:16:00.000000000 +0800

最近改动:2017-12-10 20:42:13.486000000 +0800

创建时间:-

 

[root@localhost tmp]# touch -r file1 file3

 

[root@localhost tmp]# stat file3

文件:”file3″

大小:0 块:0 IO 块:4096 普通空文件

设备:fd00h/64768d Inode:67167358 硬链接:1

权限:(0644/-rw-r–r–) Uid:( 0/ root) Gid:( 0/ root)

环境:unconfined_u:object_r:user_tmp_t:s0

最近访问:2017-12-10 20:34:47.505000000 +0800

最近更改:2012-10-20 19:16:00.000000000 +0800

最近改动:2017-12-10 21:03:39.538000000 +0800

创建时间:-

 

 

 

 

  1. cp: 复制文件和目录

格式: cp SOURCE DEST

说明:

复制文件时,如果目录是目录,则将文件复制到目录下,使用原文件名;如果目标是文件,且文件不存在,则会创建这个文件,将源文件的内容复制到目标文件中; 如果目标是文件且存在,则会提 示是否覆盖

多源复制,指源为多个文件时,指定的目标应该是一个目录, 如果目标目录不存在,则报错

如果目标目录存在,是非目录文件,则报错,如果目标目录存在,是目录文件,则将源复制到这个目录下

 

选项:

-i: 覆盖之前提醒用户进行确认,有的版本,使用 cp命令时,别名有加-i选项

-f: force 如果目标文件存在,则强制覆盖

-r: recursive,递归复制目录及目录中的内容到目标目录

-d: 在复制符号链接作为符号链接而不是复制它指向的文件,并且保护在副本中原文件之间的硬链接

-a: 复制时,尽可能保持文件的结构和属性,(但不保持目录 结构)等同于-dpR archive,用于实现归档;

–preserv=

mode 权限

ownership 属主属组

timestamps 时间戳

context 安全标签

xattr: 扩展属性

all: 上述所有属性

 

示例:

1) 使用单源复制时,如果目标是目录,则将文件复制到目录中,不改名; 如果目标是文件,且不存在,则会创建文件,将源文件中的数据流复制到目标文件;如果目标文件存在,则会提示是否覆盖

[root@localhost ~]# cp /etc/fstab /tmp

[root@localhost ~]# cd /tmp

[root@localhost tmp]# ls

fstab ks-script-rDmdoC yum.log

[root@localhost tmp]# cp /etc/fstab /tmp/fstab2

[root@localhost tmp]# cp /etc/fstab /tmp/fstab2

cp:是否覆盖”/tmp/fstab2″?

 

2) 在CentOS中,cp命令是使用了alias的,默认添加了-i选项,即目标存在时,会提示是否覆盖

 

3) 使用-r选项,会强制覆盖已经存在的目标文件

[root@localhost tmp]# ls /tmp

fstab passwd

[root@localhost tmp]# cp -r /etc/fstab /tmp

cp:是否覆盖”/tmp/fstab”? n

[root@localhost tmp]# \cp -r /etc/fstab /tmp

 

4) 带权限复制文件,复制文件时,默认不复制文件的相关属性,使用-a选项,带属性复制。 非管理员不能复制文件的相关属性。

[root@localhost tmp]# cp -a fstab2 fstab3

[root@localhost tmp]# ll

总用量 16

-rw-r–r–. 1 root root 541 12月 10 21:54 fstab

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab2

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab3

-rw-r–r–. 1 root root 1151 12月 10 21:38 passwd

[root@localhost tmp]# cp fstab2 fstab4

[root@localhost tmp]# ll

总用量 20

-rw-r–r–. 1 root root 541 12月 10 21:54 fstab

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab2

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab3

-rw-r–r–. 1 root root 541 12月 10 22:05 fstab4

-rw-r–r–. 1 root root 1151 12月 10 21:38 passwd

 

 

 

 

 

  1. rm: 移除文件或者目录

格式: rm [options] file…

选项:

-f: force,在删除时,不出现提示

-i: 进行确认提示,在删除文件时,会提示

-r: 递归地移除目录中的内容

 

示例:

# 显示/tmp目录下的的文件及目录

[root@localhost ~]# tree /tmp

/tmp

├── a

│   └── b

│   └── c

│   └── d

│   └── e

├── fstab

├── fstab2

├── fstab3

├── fstab4

└── passwd

 

5 directories, 5 files

 

# 使用rm不带参数来删除一个目录,显示无法删除

[root@localhost ~]# rm /tmp/a

rm: 无法删除”/tmp/a”: 是一个目录

 

# 使用fm -rf来强制删除一个目录,且递归进行删除

[root@localhost ~]# rm -rf /tmp/a

[root@localhost ~]# tree /tmp

/tmp

├── fstab

├── fstab2

├── fstab3

├── fstab4

└── passwd

 

 

 

  1. mv: 移动文件或者对文件改名

格式: mv [选项]… 源文件 目标文件

mv [选项]… 源文件… 目录

mv [选项]… –target-directory=DIRECTORY SOURCE…

示例:

#将当前目录下的fstab移动到当前目录下,改名叫fstab

[root@localhost tmp]# ll

总用量 20

-rw-r–r–. 1 root root 541 12月 10 21:54 fstab

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab2

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab3

-rw-r–r–. 1 root root 541 12月 10 22:05 fstab4

-rw-r–r–. 1 root root 1151 12月 10 21:38 passwd

 

[root@localhost tmp]# mv fstab fstab5

 

[root@localhost tmp]# ll

总用量 20

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab2

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab3

-rw-r–r–. 1 root root 541 12月 10 22:05 fstab4

-rw-r–r–. 1 root root 541 12月 10 21:54 fstab5

-rw-r–r–. 1 root root 1151 12月 10 21:38 passwd

 

# 将当前目录下的fstab5移动到下一级目录a下

[root@localhost tmp]# mv fstab5 a/

[root@localhost tmp]# ll

总用量 16

drwxr-xr-x. 2 root root 20 12月 11 18:29 a

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab2

-rw-r–r–. 1 liuqing liuqing 541 12月 10 22:05 fstab3

-rw-r–r–. 1 root root 541 12月 10 22:05 fstab4

-rw-r–r–. 1 root root 1151 12月 10 21:38 passwd

[root@localhost tmp]# tree

.

├── a

│   └── fstab5

├── fstab2

├── fstab3

├── fstab4

└── passwd

 

# 使用–target-directory长选项移动文件

[root@localhost tmp]# mv –target-directory=’/tmp/a’ fstab3

[root@localhost tmp]# tree a

a

├── fstab3

├── fstab4

└── fstab5

 

 

 

 

二、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示

  1. bash的工作特性之命令执行状态返回值:

命令执行状态的返回值不同于命令的执行结果,当命令在bash中正常完成,其值为0,如果命令在bash中运行出错,其值为1-255,使用 echo $?来查看结果

 

# 命令运行成功,其执行状态结果为0

[root@localhost ~]# ls /tmp &> /dev/null

[root@localhost ~]# echo $?

0

 

# 命令执行不成功,其结果为1-255之间的一个值

[root@localhost ~]# ls /tmpp &> /dev/null

[root@localhost ~]# echo $?

2

 

  1. bash的工作特性之命令行展开

在bash中,可以使用一些特定的字符来代替参数

 

1) ~表示用户的家目录

# 快速切换到用户的家目录

[root@localhost tmp]# pwd

/tmp

[root@localhost tmp]# cd ~

[root@localhost ~]# pwd

/root

 

2) {}可以承载一个以逗号为分割符的列表,进行展开

# 使用{}进行命令行展开

[root@localhost ~]# mkdir {a,b}_{c,d}

[root@localhost ~]# ls

a_c a_d anaconda-ks.cfg b_c b_d

 

 

 

三、使用命令行展开功能来完成以下练习

  1. 创建/tmp目录下的a_c,a_d,b_c,b_d

[root@localhost tmp]# mkdir {a,b}_{c,d}

 

 

  1. 创建/tmp/mylinux目录下的以下目录

[root@localhost tmp]# mkdir -p mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}

 

[root@localhost tmp]# tree mylinux

mylinux

├── bin

├── boot

│   └── grub

├── dev

├── etc

│   ├── rc.d

│   │   └── init.d

│   └── sysconfig

│   └── network-scripts

├── lib

│   └── modules

├── lib64

├── proc

├── sbin

├── sys

├── tmp

├── usr

│   └── local

│   ├── bin

│   └── sbin

└── var

├── lock

├── log

└── run

 

 

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/89928

(0)
神策神策
上一篇 2017-12-11
下一篇 2017-12-11

相关推荐

  • 马哥教育N22期第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 root@xuc-virtual-machine:/home/xuc# cp -r /etc/skel/ /home/tuser1 root@xuc-virtual-machine:/…

    Linux干货 2016-09-06
  • linux开篇六式

    第一式. Linux上的文件管理类命令,其常用的使用方法及其相关示例。       mkdir, 创建目录       rmdir,删除目录       tree, 显示目录层级       cat和tac均用于查看文件,cat是从文件首向…

    Linux干货 2016-10-13
  • 系统管理之程序包管理(一) rpm详解

    系统管理之程序包管理(1):     程序包管理是运维人员的基本工作素质之一。在操作系统上,不断的安装,卸载,配置应用程序包,让不同程序包运行提供不同的服务;利用某种工具完成某些操作的过程。这就要求运维工作人员熟悉安装,管理应用程序包。 在linux上,程序包主要有两种:tar,rpm包。 一、程序包概述: 系统接口   &nb…

    Linux干货 2016-08-21
  • 从新开始,坚持记录

    从新开始,从心开始,记录自己的学习,不逼自己一把,永远不知道自己的潜力。

    Linux干货 2016-12-05
  • 文件管理

    一、文件系统     单根架构,根文件系统rootfs     不是linux大小写敏感,而是文件系统支不支持大小写。     路径分割 /     FHS:目录结构,文件分层标准  &nb…

    Linux干货 2016-08-02
  • 马哥Linux第四周作业

    1.复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限 ~]# cp -r /etc/skel/ /home/user1 ~]# chmod -R g0-rwx /home/user1/ 2.编辑/etc/group文件,添加组hadoop 编辑/etc/group 写入:hado…

    2018-01-07