linux文件、目录基本操作命令及bash特性介绍

1、文件层级FHS介绍:

Filesystem Hierarchy Standard(文件系统层次化标准)的缩写,多数Linux版本采用这种文件组织形式,类似于Windows操作系统中c盘的文件目录,FHS采用树形结构组织文件。

FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录,同时还给出了例外处理与矛盾处理。

/:linux文件系统根目录

/bin:供所有用户使用的基本命令文件

/sbin:供系统管理员使用的工具程序文件

/lib:供/bin和/sbin程序调用的库文件程序,及系统启动时需要的库文件

/lib64:供64为系统使用的库文件,及系统启动时需要的库文件

/boot:系统启动引导的静态文件(kernel、initranfs、grub等)

/dev:存储设备文件和特殊文件。

/etc:主机特有配置文件,只能为静态文件,一般是文本文件。 etc也是层级目录结构。

/etc/opt,/etc/x11,/etc/xml,

/home:用户家目录,可选目录

/media:便携设备挂载点,如光盘、u盘等

/mnt:其他文件的临时挂载点

/opt:附加应用程序的安装位置(第三方应用程序),可选路径。

/root:管理员的家目录

/srv:当前主机为服务提供数据的目录

/tmp:临时文件,为那些产生临时文件的程序提供的用于存储临时文件的目录,可供所有用户执行写操作。

/usr:全局共享只读数据路径,它也是一个层级文件系统。

/var:存储经常变化的数据目录,它也是一个层级文件系统。

/proc:用来为内核及进程存储相关信息,多位内核参数。

/sys:提供比/proc更理想的访问linux内核参数的方法途径,其主要作用于为管理linux设备提供一种统一模型的接口。

2、linux文件类型:

Linux文件的类型可以通过命令:ls -l 来查看,一般有如下几种

-:普通文件

d:目录文件

b:块设备文件,块设备文件以“block”为单位,对数据可以进行随机访问。

c:字符设备文件,字符设备文件以“字符”为单位,对数据只能进行线性访问。

l:符号链接文件,相当于windows中的快捷方式

p:命令管道文件

s:套接字文件

3、linux目录、文件操作常用命令:

3.1、创建目录:mkdir,删除目录rmdir

3.2、文件内容查看常用命令:cat、tac、首尾部分查看(tail、head)、分屏查看(more、less)

3.3、文件复制、移动、删除命令:cp、mv、rm

mkdir:创建目录

格式:

mkdir [OPTION]… DIRECTORY…

[OPTION]:

-p:如果父目录不存在,则自动创建父目录,

-m:创建目录时,设定目录权限

-v:显示命令执行的详细信息

如:

[root@localhost ~]# mkdir /tmp/x/y/z

mkdir: cannot create directory ‘/tmp/x/y/z’: No such file or directory

[root@localhost ~]# mkdir -p /tmp/x/y/z

[root@localhost ~]#

rmdir:删除空目录

格式:

rmdir [OPTION]… DIRECTORY…

[OPTION]:

-p:删除子目录后,如果父目录为空,则一并删除

-v:显示命令执行的详细信息

cat:把文件和标准输出连接起来,即查看文件内容,它会直接显示到文件尾部一行,

格式: cat [OPTION]… [FILE]…

[OPTION]

E:显示文件每一行尾的$

n:显示文件每一行号

如:

tac:和cat类似,只是它是从文件尾部进行查看,不做翻屏处理

tail:输出文件最后一部分内容,默认为文件尾部10行,

格式:tail [OPTION]… [FILE]…

[OPTION]

-c:输出文件尾部多少K字节内容;

-f:输出文件最后不退出,并显示追加的内容,

-n  数字:显示从文件尾部指定多少行开始显示,默认10行

-n   +数字:  显示从第几行开始显示到行尾

head:输出文件的开始部分,默认为10行;

格式: head [OPTION]… [FILE]…

[OPTION]:

-n:指定前多少行

more:分屏查看文件内容,最后直接退出

格式:more [options] file […]

less:分屏查看文件内容,最后不直接退出,需敲入q退出,man命令调用的less命令;

/pattern:从上往下搜索内容,n方向一致,N方向相反搜索

?pattern:从下往上搜索内容,n方向一致,N方向相反搜索

#G:跳转指定行

GG:跳转文件尾部

空格:向尾部翻一屏

b键:向首部翻一屏

cp:文件复制命令  : 复制源文件到目的文件或目录,复制多个源文件到目录

格式:

单源复制:cp [OPTION]… [-T] SOURCE DEST

多源复制:cp [OPTION]… SOURCE… DIRECTORY

多源复制:cp [OPTION]… -t DIRECTORY SOURCE…

单源复制:cp [OPTION]… [-T] SOURCE DEST

如果DEST不存在,则事先创建此文件,并复制源文件的数据流至DEST中

如果DEST存在,

如果DEST是非目录文件,则复制源文件数据流覆盖目标文件;

如果DEST是目录文件,则先在DEST目录下创建一个与源文件同名的文件,并复制源文件

多源复制:cp [OPTION]… SOURCE… DIRECTORY

如果DEST不存在,会报错

如果DEST存在,

如果DEST是非目录文件,会报错

如果DEST是目录文件,分别复制每个文件至目录文件中,并保持原名。

[OPTION]:

-i:交换式复制,即覆盖前提醒用户确认

-f:强制覆盖目标文件

-r:递归复制目录文件

-d:复制符号链接文件本身,而非其指向的源文件

-a:用于实现归档,保持源文件的所有读写执行和属主属组权限。

如:

[user@localhost ~]$ cp /etc/issue /tmp  //DEST目标文件不存在,

[user@localhost ~]$ ls /tmp

anaconda.log

hsperfdata_root

hsperfdata_user

ifcfg.log

issue

[root@localhost user]# cp /etc/issue /etc/fstab /tmp/abc  //复制issue、fstab文件到目录abc

cp: target ‘/tmp/abc’ is not a directory

[root@localhost user]# mkdir /tmp/abc

[root@localhost user]# !cp

cp /etc/issue /etc/fstab /tmp/abc

[root@localhost user]# ls /tmp/abc

fstab  issue

[root@localhost user]#

[root@localhost ~]# mkdir /tmp/bcd

[root@localhost ~]# cp -rv  /var/log/ /tmp/bcd  //复制目录,DEST需事先存在

注意:复制后的文件/目录权限和属主属组发生了变化。可以用-a选项保持这些参数

[root@localhost ~]# cp /var/log/tomcat/ /tmp/

cp: omitting directory ‘/var/log/tomcat/’

[root@localhost ~]# cp -rv /var/log/tomcat/ /tmp/

‘/var/log/tomcat/’ -> ‘/tmp/tomcat’

‘/var/log/tomcat/catalina.out’ -> ‘/tmp/tomcat/catalina.out’

[root@localhost ~]# ll /var/log/tomcat/ /tmp/tomcat/

/tmp/tomcat/:

total 4

-rw-r—–. 1 root root 28 Sep 17 18:16 catalina.out

/var/log/tomcat/:

total 4

-rw-rw—-. 1 tomcat tomcat 28 Nov  6  2016 catalina.out

[root@localhost ~]# cp -a /var/log/firewalld  /tmp/

[root@localhost ~]# ll /var/log/firewalld /tmp/firewalld

-rw-r–r–. 1 root root 0 Aug 29 20:22 /tmp/firewalld

-rw-r–r–. 1 root root 0 Aug 29 20:22 /var/log/firewalld

 

mv:移动文件或重命名文件

格式:    mv [OPTION]… [-T] SOURCE DEST

mv [OPTION]… SOURCE… DIRECTORY

mv [OPTION]… -t DIRECTORY SOURCE…

rm:删除文件或目录

格式: rm [OPTION]… FILE…

[OPTION]:

-i:交互式命令

-r:递归操作,删除目录时会有用。

-f:强化操作

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

rm: cannot remove ‘/tmp/bcd/’: Is a directory

[root@localhost ~]# rm -r /tmp/bcd/

rm: remove directory ‘/tmp/bcd/’? y

[root@localhost ~]# ls /tmp/bcd

ls: cannot access /tmp/bcd: No such file or directory

[root@localhost ~]#

4、bash的基础特性介绍:

4.1、命令历史:history

shell进程会在其会话中保存此前用户提交的执行过的命令。

命令格式:history  【option】

history的环境变量有:

HISTSIZE:shell进程可保留的命令历史的条数

HISTFILE:持久保存命令历史的文件,一般每个用户下都会有,如家目录下的.bash_history

HISTFILESIZE:定义历史文件的大小。

option选项有:

-c:清空历史命令列表

-d:偏移量,删除指定命令历史

-r:从命令历史文件中读取命令至命令历史中(内存)

-w:把历史列表中命令追加至历史文件中。

调用命令历史列表中的命令:  !

!#:再一次执行命令历史列表中的第#条命令

!!:再一次执行上一次操作的命令

!sting:再一次执行最近一次可以匹配命令历史列表中的以sting开头的命令。

调用上一条命令中最后一个参数:

快捷键:esc + . :按esc键后松开,再按点号(.)

字符组合:!$.     :叹号和$号一起按

控制命令历史记录的方式:

环境变量:HISTCONTROL      (修改仅对当前shell有效)

HISTCONTROL=ignoredups:忽略重复的命令

HISTCONTROL=ignorespace:忽略以空白字符开头的命令

HISTCONTROL=ignoreboth:以上两者同时忽略

4.2、命令补全、路径补全(按tab键)

shell程序在接收到用户执行的命令请求时,分析完成后,最左侧的字符串会被当作命令执行。

命令处理机制:

查找内部命令

根据PATH环境变量中设定的目录,从左向右逐个按目录查找

命令补全机制:

给定的打头字符串如果唯一标识某命令文件,则tab键直接补全

给定的打头字符串如果不能唯一标识某命令程序文件,则再按一次tab键,会给出命令列表。

路径补全机制:

根据给定的起始路径补全,即以对应路径下的打头字符串来逐一匹配起始路径下的每个文件。

如果能唯一标识某路径,则补全,否则,再按一次tab,给出列表。

4.3、命令行展开:    ~、{ }

~ :自动展开为用户的家目录( # cd ~),或指定用户的家目录(# cd ~ user)

{ }: 可承载一个以“,”(逗号)分隔的路径列表,并能够将其展开为多个路径。如:/tmp/{a,b}相当于/tmp/a和/tmp/b

如:

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

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

[root@localhost ~]# ls /tmp/

a_b

a_d

b_b

b_d

创建/tmp/mylinux目录下的目录结构:

[root@localhost ~]# tree /tmp/mylinux/

/tmp/mylinux/

├── bin

├── boot

│   └── grup

├── dev

├── etc

│   ├── rc.d

│   │   └── init.d

│   └── sysconfig

│       └── network-scripts

├── lib

│   └── modules

├── lib64

├── proc

├── sbin

├── sys

├── tmp

├── usr

│   ├── local

│      ├── bin

│      └── sbin

└── var

├── lock

├── log

└── run

26 directories, 0 files

[root@localhost ~]#

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

4.4、命令的执行状态结果:

bash通过状态返回值来查看命令的执行结果,状态返回值保存于bash的特殊变量“$?”中。

注意:$? 只能获得最近命令执行的状态结果。

通过:#echo $? 执行结果来查看命令执行状态结果。

如果命令成功执行:输出数字“0”

如果命令未成功执行:输出数字“1-255”中的一个数字,

如:

[root@localhost ~]# ls /

1    boot  etc   lib    media  opt   root  sbin  sys  usr

bin  dev   home  lib64  mnt    proc  run   srv   tmp  var

[root@localhost ~]# echo $?

0

[root@localhost ~]#

[root@localhost ~]# lsls /

bash: lsls: command not found…

[root@localhost ~]# !echo

echo $?

127

[root@localhost ~]#

4.5、引用命令的执行结果: $(命令) 或 `命令`    注意 ` 为反引号。

如:#mkdir $(date +%H-%M-%S)             //引用时分秒为创建目录的名字。

4.6、变量的引用:

‘ 变量 ’  :单引号表示强引用,引用变量本身;

”变量“   :双引号表示弱引用,引用变量的执行结果

$(命令) :命令执行结果引用

4.7、bash快捷键:

ctrl+a:跳转至命令行首部

ctrl+e:跳转至命令行尾部

ctrl+u:删除行首至光标所在处之间的所有字符

ctrl+k:删除光标所在处至行尾之间的所有字符

ctrl+l:清屏,相当于clear命令

4.8、glob通配符(文件名通配符)

linux的哲学思想之一就是一切皆文件,众多文件组织在一起,可以通过glob通配符去匹配需要的文件名。

注意:glob匹配的是整个文件名,而非部分文件名。

glob通过“元字符”去匹配信息。

 

元字符介绍:

* :  *表示匹配任意长度任意字符

?:  ?表示匹配任意单个字符

[ ] :  [ ]表示匹配指定范围内的任意单个字符

[a-z]: 表示匹配a-z A-Z中的任意一个字母,不区分大小写;即匹配所有字母

[A-Z]:表示匹配a-z A-Z中的任意一个字母,不区分大小写;即匹配所有字母

[0-9]:表示匹配所有数字中的一个数字,即匹配所有数字

[a-z0-9]:表示匹配所有的字母和数字

[abcde]:表示匹配abcde中的任意一个字符

特定格式:

[[:upper:]] :表示匹配所有大写字母中的一个

[[:lower:]] :表示匹配所有小写字母中的一个

[[:alpher:]] :表示匹配所有字母(大小写)中的一个

[[:digit:]] :表示匹配所有数字

[[:alnum:]] :表示匹配所有字母和数字中的一个

[[:space:]] :表示匹配所有空白字符

[[:punct:]] :表示匹配所有标点符号

[^ ] : [^ ]表示匹配指定范围外的任意单个字符

[^[:upper:]] : 表示匹配所有大写字母以外的单个字符

[^abcde]   :  表示匹配abcde外的任意一个字符

如:

显示/var/log目录下所有以l开头,以一个小写字母结尾,且中间出现一位数字的文件或目录

[root@localhost ~]# ls -d /var/log/l[0-9][[:lower:]]

显示/etc目录下,以任意一位数字开头,且以非数字结尾的文件或目录

[root@localhost ~]# ls -d /etc/[0-9]*[^0-9]

复制/etc/目录下,所有以.conf结尾,且以mnrp开头的文件或目录至/tmp/conf.d目录下

[root@localhost ~]# mkdir /tmp/conf.d

[root@localhost ~]# cp -r /etc/[mnrp]*.conf /tmp/conf.d

 

5、常用命令:alias,unalias,stat,touch

[root@localhost ~]# alias cls=clear

[root@localhost ~]# alias

alias cls=’clear’

[root@localhost ~]# unalias cls

stat命令:查看文件元数据信息

每个文件都有两类数据:

元数据:metadata //不是文件的组成部分,描述文件属性的信息,类似winodws文件的属性常规信息

数据:data     //文件本身内容数据

如:

[root@localhost ~]# stat /tmp/yum.log.old

File: ‘/tmp/yum.log.old’

Size: 52        Blocks: 8          IO Block: 4096   regular file

Device: fd00h/64768dInode: 11797030    Links: 1

Access: (0600/-rw——-)  Uid: (    0/    root)   Gid: (    0/    root)

Context: unconfined_u:object_r:user_tmp_t:s0

Access: 2017-09-17 18:04:23.207995463 +0800

Modify: 2017-09-17 18:04:23.207995463 +0800

Change: 2017-09-17 18:37:48.960974954 +0800

Birth: –

[root@localhost ~]#

注意:元数据有三个重要的时间参数:只能修改访问时间和修改时间,不能修改改动时间,改动时间会因访问时间和修改时间改变而变化。

Access: 2017-09-17 18:04:23.207995463 +0800    //actime:访问时间

Modify: 2017-09-17 18:04:23.207995463 +0800    //mtime:修改时间

Change: 2017-09-17 18:37:48.960974954 +0800    //ctime:改动时间

touch:修改文件时间戳;如果文件不存在,则用来创建文件

格式:touch [OPTION]… FILE…

[OPTION]

-a:仅修改accestine

-m:仅修改modifytime

-c:指定文件不存在时,不创建文件

-t:use [[CC]YY]MMDDhhmm[.ss] instead of current time //用指定时间代替当前时间。

如:

[root@localhost ~]# touch -t 201709171219 /tmp/yum.log.old

[root@localhost ~]# stat /tmp/yum.log.old

File: ‘/tmp/yum.log.old’

Size: 52        Blocks: 8          IO Block: 4096   regular file

Device: fd00h/64768dInode: 11797030    Links: 1

Access: (0600/-rw——-)  Uid: (    0/    root)   Gid: (    0/    root)

Context: unconfined_u:object_r:user_tmp_t:s0

Access: 2017-09-17 12:19:00.000000000 +0800

Modify: 2017-09-17 12:19:00.000000000 +0800

Change: 2017-09-17 20:22:43.883910589 +0800

Birth: –

[root@localhost ~]#

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

(1)
N27_zhangweitaoN27_zhangweitao
上一篇 2017-09-17 20:25
下一篇 2017-09-18 00:13

相关推荐

  • 10月18日作业–hash,history

    1 生产环境发现一台服务器系统时间产生偏差,造成服务异常,请帮忙校正。 1、使用ntpdate对时间进行同步,然后hwclock -w;并再建立Crontab每小时进行一次时间同步。 2 生产有一个数据同步脚本需要执行很长时间,怎样做到无人值守,在管理工具退出的情况下,脚本依然能正常运行。 1、载光盘 2、进入/mnt/Packages 安装共享screen…

    Linux干货 2016-10-19
  • Linux磁盘与文件系统管理

    对于一块磁盘,如果我们想要使用的话,需要对磁盘进行分区并建立文件系统。下面,我们就了解一下Linux中的磁盘与文件系统管理 一、MBR 硬盘的0扇区为MBR扇区,其由以下几部分组成: l  主引导程序(偏移地址0000H–0088H),它负责从活动分区中装载,并运行系统引导程序。 l  出错信息数据区,偏移地址0089H&#8…

    Linux干货 2016-08-28
  • 第六周

      第6周   1 复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; cp /etc/rc.d/rc.sysinit ; sed -i 's@^[[:space:]]\+@#@g&#03…

    Linux干货 2017-02-13
  • iptables:防火墙以及网络协议基本原理

    一、 Linux 网络安全模型      1. 防火墙: 工作在主机或者网络边缘,对进出报文使用实现定义的规则进行检测,并且由匹配的规则进行处理的一组硬件或者软件。也可能两者结合。          1) 通常使用的防火…

    Linux干货 2015-07-24
  • 马哥教育网络班22期+第六周课程练习

    1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; ]# cp -v  /etc/rc.d/rc.sysinit /tmp/    `/etc/rc.d/rc.sysinit' -> `/tmp/rc.sysinit&…

    Linux干货 2016-10-17