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

相关推荐

  • Linux 进程及作业管理

    一 进程、线程、程序概念 1、进程(Process) 什么是进程,简单的说,进程是程序的执行实例,即运行中的程序,同时也是程序的一个副本;程序是放置于磁盘的,而运行中的程序是位于内存中的。 2、线程(Thread) 一个进程至少包括一个线程,通常将该线程称为主线程,所以线程是比进程更小的单位,是系统分配处理器时间资源的基本单元。一个进程要想同时在多颗CPU上…

    Linux干货 2016-03-15
  • grep用法

    一、前言 grep是功能强大的文本处理工具,全称:global search regular expression and print out the line,grep一行一行使用正则表达式匹配文本,之后对匹配到的文本整行显示(除非使用特定的选项取反,如 grep -v)。 二、grep用法 grep命令用法:    &nbs…

    Linux干货 2015-08-24
  • Linux基础知识及常用命令

    pwd:printing working directory -显示当前工作目录            [root@edu tmp]# pwd          &nbs…

    Linux干货 2016-09-15
  • N22-北京-追求极境之人-RSYNC差分编码同步原理

    1客户端发送自己的filelist,filelist包含文件hashindexid(alert32)和关联的文件chunkChecksum(MD5)和hashindexID以便进行快速查找,chunksize根据文件大小进行等分,不足均值部分直接发送不进行MD5校验值生成 发送进程一次从生成器读取一个文件索引号和关联的块校验集合 2对于生成器发送的每个文件I…

    Linux干货 2016-08-22
  • tomcat

    tomcat 简述 tomcat的结构 tomcat配置 总结与问题 简述 什么是tomcat? tomcat是一个java2ee的web容器的残缺实现,提供了serverlet,asp转换等组件。 tomcat的功能? tomcat能够将asp文件通过转换,转换为serverlet格式,这样子就可以被java识别运行并将结果转为asp响应,并且tomcat…

    2016-06-24
  • Linux学习总结01—操作系统与硬件介绍(原创)

      在计算机中,分为以下结构,运算器,控制器,存储器,输入、输出设备,运算器和控制起的整个就形成了中央处理器(称作为CPU),而cpu的功能就是提供运算,运算的数据都是经由控制器而来,控制器其实是往主存储器中取得数据,内存中的数据是由用户来输入的,其运算的结果通过控制器存储在内存当中,之后可以根据用户的指令输出在一个设备当中(例如显示器),我们都知…

    Linux干货 2016-10-29