Linux的文件系统、系统管理类命令、bash基础特性

Linux的文件系统
根文件系统(rootfs) root fileysystem

LSB,FHS(Filesystem Heirache Standard)文件系统层级结构标准,如:/etc、/usr、/var、/root、/home、/dev

/boot:引导文件存放目录,内核文件(vmlinuz)、引导加载器(bootloader,grub)都存放于此目录;
/bin:供所有用户使用的基本命令;不能关联至独立分区,OS启动即会用到的程序;
/sbin:管理类的基本命令;不能关联至独立分区,OS启动即会用到的程序;
/lib:基本共享库文件,以及内核模块文件(/lib/moudules);
/lib64:专用于x86_64系统上的辅助共享库文件;
/etc:配置文件目录(纯文本文件);
/home/username:普通用户家目录
/root:管理员的家目录;
/media:便携式移动设备挂载点;(cdrom、usb)
/mnt:临时文件系统挂载点;
/dev:设备文件及特殊文件存储位置;
    b:block device 随机访问设备
    c:character device 线性访问设备
/opt:第三方应用程序的安装位置;
/srv:系统上运行的服务用到的数据;
/tmp:临时文件存储位置

/usr:universal shared,read-only data
    bin:保证系统拥有完整功能而提供的应用程序;
    sbin:
    lib:
    lib64:
    include:C程序的头文件(header files);
    share:结构化独立的数据,例如:man,doc等
    local:第三方应用程序的安装位置;
        bin、sbin、lib、lib64、etc、share

/var:variable data files 可变数据文件
    cache:应用程序缓存数据目录;
    lib:应用程序状态信息数据;
    local:专用于为/usr/local下的应用程序存储可变数据;
    lock:锁文件
    log:日志目录及文件
    opt:专用于为/opt下的应用程序存储可变数据;
    run:运行中的进程相关的数据;通常用户存储进程的pid文件
    spool:应用程序数据池
    tmp:保存系统两次重启之间产生的临时数据

/proc:用于输出内核与进程信息相关的虚拟文件系统;
/sys:用于输出当前系统上硬件设备相关信息的虚拟文件系统
/selinux:security enhanced linux,selinux相关的安全策略等信息的存储位置

Linux上的应用程序的组成部分:
二进制程序:/bin、/sbin、/usr/bin、/usr/sbin、/usr/local/bin、/usr/local/sbin
库文件:/lib、/lib64、/usr/lib、/usr/lib64、/usr/local/lib、/usr/loacl/lib64
配置文件:/etc、/etc/directory、/usr/local/etc
帮助文件:/usr/share/man、/usr/share/doc、/usr/local/share/man、/usr/loacl/share/doc

Linux的文件类型
-(f):普通文件;
d:目录文件
b:块设备
c:字符设备
l:符号链接文件,仅表示软链接;
p:管道文件
s:套接字文件、socket;

系统管理类命令:
关机或重启
halt、poweroff 关机
reboot 重启

选项:-f:强制,不调用shutdown;-p:切断电源

shutdown
shutdown [option]... time [message]

选项:-r:reboot 重启;-h:halt 关机 ;-c:cancel 取消关机或重启

time时间表示法:
now:立刻,0亦可表示现在
+m:相对时间表示法,从命令提交开始多久之后,例如:+3;
hh:mm:绝对时间表示法,指明具体时间,24小时制;

用户登录信息查看命令:
whoami:显示当前登录有效用户
[root@localhost ~]# whoami
root

who:系统当前所有的登录会话:
[root@localhost ~]# who
root     pts/1        2018-03-21 11:25 (192.168.152.1)
root     pts/2        2018-03-21 14:15 (192.168.152.1)

w:系统当前所有的登录会话及所做的操作
[root@localhost ~]# w
 14:18:12 up  2:57,  2 users,  load average: 0.00, 0.00, 0.00
USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT
root     pts/1    192.168.152.1    11:25    2:53m  0.02s  0.02s -bash
root     pts/2    192.168.152.1    14:15    0.00s  0.01s  0.00s w

bash的基础特性:
(1)命令历史
history
环境变量:
HISTSIZE:命令历史记录的条数;
[root@localhost ~]# echo $HISTSIZE
1000

HISTFILE:命令历史文件
[root@localhost ~]# echo $HISTFILE
/root/.bash_history

HISTFILESIZE:命令历史文件记录历史的条数
[root@localhost ~]# echo $HISTFILESIZE
1000

history -d #:删除命令历史中第#条命令
[root@localhost ~]# history
1 history
2 ls
3 cd
4 history
[root@localhost ~]# history -d 2
[root@localhost ~]# history
1 history
2 cd
3 history
4 history -d 2
5 history

history -c:清空命令历史;
history #:显示命令历史中最近的#条命令
[root@localhost ~]# history
1 history
2 ls
3 cd
4 history
[root@localhost ~]# history 2
4 history
5 history 2

history -a:手动追加当前会话缓冲区的命令历史到命令历史文件中;

调用历史中的命令:
!#:重复执行第#条命令
[root@localhost ~]# history
1 history
2 ls
3 cd
4 history
[root@localhost ~]# !2
ls
anaconda-ks.cfg Desktop install.log install.log.syslog scsrun.log

!!:重复执行上一条命令
[root@localhost ~]# history
1 history
[root@localhost ~]# !!
history
1 history
2 history

!string:重复执行以string开头的命令
[root@localhost ~]# history
1 history
2 ls
3 cd
4 history
[root@localhost ~]# !l
ls
anaconda-ks.cfg Desktop install.log install.log.syslog scsrun.log

调用上一条命令的最后一个参数:
!$
ESC,.
alt+.

控制命令历史的记录方式:
环境变量:HISTCONTROL
ignoredups 忽略重复的命令;连续且相同方为重复;
ignorespace:忽略所有以空白开头的命令;
ignoreboth:兼容以上两者的特性

(2)命令补全
bash执行命令:bash根据PATH环境变量定义的路径,自左而右在每个路径搜寻以给定命令名命名的文件,第一次找到即为要执行的命令;
直接补全:Tab,用户给定的字符串只有一条唯一对应的命令;
以用户给定的字符串为开头对应的命令不唯一,则再次Tab会给出列表;

(3)路径补全
把用户给出的字符串当做路径开头,并在其指定上级目录下搜索以指定的字符串开头的文件名
如果唯一,则直接补全
否则,则再次Tab,给出列表;

(4)命令行展开
~:展开为用户的主目录
~username:展开为指定用户的主目录
{}:可承载一个逗号分隔的列表,并将其展开为多个路径
示例如下:
/tmp/{a,b}=/tmp/a,/tmp/b
/tmp/{tom,jerry}/hi=/tmp/tom/hi,/tmp/jerry/hi

(5)命令的执行状态结果
成功;失败

bash使用特殊变量$?保存最近一条命令的执行状态结果
0:成功
1-255:失败
[root@localhost ~]# cat /etc/issue
Red Hat Enterprise Linux Server release 5.7 (Tikanga)
Kernel \r on an \m

[root@localhost ~]# echo $?
0

[root@localhost ~]# catt /etc/issue
-bash: catt: command not found
[root@localhost ~]# echo $?
127

[root@localhost ~]# cat /etc/issuee
cat: /etc/issuee: No such file or directory
[root@localhost ~]# echo $?
1

程序执行有两类结果:
程序的返回值;
程序的执行状态结果;

目录管理类命令:
cd,pwd,ls

mkdir,rmdir
mkdir [options] /path/to/somewhere
-p:存在时不报错,且可自动创建所需的各目录,按层级递归创建
[root@localhost tmp]# ls -l
total 16
drwx------ 2 root root 4096 Mar 15 19:49 gconfd-root
srwxr-xr-x 1 root root    0 Mar 15 19:04 mapping-root
-rw-r--r-- 1 root root 1580 Mar 20 22:01 passwd
drwxr-xr-x 2 root root 4096 Mar 21 14:57 tom
[root@localhost tmp]# mkdir -p tom

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

-v:显示详细信息
[root@localhost tmp]# mkdir -v mary
mkdir: created directory `mary'

-m MODE:创建目录时直接指定权限
[root@localhost tmp]# mkdir -m 755 abc
[root@localhost tmp]# ls -dl abc
drwxr-xr-x 2 root root 4096 Mar 21 15:02 abc

tree:查看目录的层级结构
    -d:只显示目录,文件不予显示
    [root@localhost tmp]# tree -d /tmp
    /tmp
    |-- abc
    |-- gconfd-root
    |-- mary
    |-- tom
    `-- x
            `-- y
                    `-- z

    -L level:指定显示的层级数目
    [root@localhost tmp]# tree -L 2 /tmp
    /tmp
    |-- abc
    |-- gconfd-root
    |-- mapping-root
    |-- mary
    |-- passwd
    |-- tom
    `-- x
            `-- y

    -P pattern:只显示有指定pattern匹配到的路径

rmdir:删除空目录
    rmdir [option]... directory...
    -v:显示详细信息
    [root@localhost tmp]# rmdir -v mary
    rmdir: removing directory, mary

    -p:递归删除空目录

练习:
1、如何创建/tmp/x/y1、/tmp/x/y2、/tmp/x/y1/a、/tmp/x/y1/b、/tmp/x/y2/a、/tmp/x/y2/b
[root@localhost ~]# mkdir -pv /tmp/x/{y1,y2}/{a,b}
mkdir: created directory `/tmp/x'
mkdir: created directory `/tmp/x/y1'
mkdir: created directory `/tmp/x/y1/a'
mkdir: created directory `/tmp/x/y1/b'
mkdir: created directory `/tmp/x/y2'
mkdir: created directory `/tmp/x/y2/a'
mkdir: created directory `/tmp/x/y2/b'

2、如何创建x_m、y_m、x_n、y_n
[root@localhost ~]# mkdir -v /tmp/{x,y}_{m,n}
mkdir: created directory `/tmp/x_m'
mkdir: created directory `/tmp/x_n'
mkdir: created directory `/tmp/y_m'
mkdir: created directory `/tmp/y_n'

3、如何创建/tmp/bin、/tmp/sbin、/tmp/usr、/tmp/usr/bin、/tmp/usr/sbin
[root@localhost ~]# mkdir -pv /tmp/{bin,sbin,usr/{bin,sbin}}
mkdir: created directory `/tmp/bin'
mkdir: created directory `/tmp/sbin'
mkdir: created directory `/tmp/usr'
mkdir: created directory `/tmp/usr/bin'
mkdir: created directory `/tmp/usr/sbin'

文本文件查看类命令:
    cat、tac
    more、less、tail、head

    more
    more [option...] [file...]
        -d:显示翻页及退出提示
        +#:定位在第#行开始显示

    less
    less [option...] [file...]

    head
    head [option...] [file...]
        -c #:指定获取前#字节
        [root@localhost ~]# head -c 5 /tmp/passwd
        root:

        -n #:指定获取前#行
        [root@localhost ~]# head -n 3 /tmp/passwd
        root:x:0:0:root:/root:/bin/bash
        bin:x:1:1:bin:/bin:/sbin/nologin
        daemon:x:2:2:daemon:/sbin:/sbin/nologin

        -#:指定获取前#行
        [root@localhost ~]# head -3 /tmp/passwd
        root:x:0:0:root:/root:/bin/bash
        bin:x:1:1:bin:/bin:/sbin/nologin
        daemon:x:2:2:daemon:/sbin:/sbin/nologin

        tail
        tail [option...] [file...]
            -c #:指定获取后#字节
            [root@localhost ~]# tail -c 5 /tmp/passwd
            tom.

            -n #:指定获取前#行
            [root@localhost ~]# tail -n 3 /tmp/passwd
            I am tom.
            I am tom.
            I am tom.

        -#:指定获取前#行
        [root@localhost ~]# tail -3 /tmp/passwd
        I am tom.
        I am tom.
        I am tom.

        -f:跟踪显示文件新追加的内容;

        文件的时间戳管理工具
        touch

        文件:metadata元数据,data数据
        查看文件状态:stat
        [root@localhost ~]# stat /tmp/passwd
                File: `/tmp/passwd'
                Size: 1580          Blocks: 8          IO Block: 4096   regular file
            Device: fd00h/64768d    Inode: 1336933     Links: 1
            Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
            Access: 2018-03-21 15:35:58.000000000 +0800
            Modify: 2018-03-20 22:01:10.000000000 +0800
            Change: 2018-03-20 21:58:31.000000000 +0800

            三个时间戳:
            access time:访问时间,atime 读取文件内容
            modify time:修改时间,mtime 改变文件内容
            changetime:改变时间,ctime 元数据发生改变

            touch命令:
            touch [option...] [file...]
            -a:only atime
            -m:only mtime
            -t 具体时间 [[CC]YY]MMDDhhmm.ss
            [root@localhost ~]# touch -a -t 201803211540.10 /tmp/passwd
            [root@localhost ~]# touch -m -t 201803211541.10 /tmp/passwd
            [root@localhost ~]# stat /tmp/passwd
                File: `/tmp/passwd'
                Size: 1580          Blocks: 8          IO Block: 4096   regular file
            Device: fd00h/64768d    Inode: 1336933     Links: 1
            Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
            Access: 2018-03-21 15:40:10.000000000 +0800
            Modify: 2018-03-21 15:41:10.000000000 +0800
            Change: 2018-03-21 15:45:00.000000000 +0800

            -c:如果文件不存在,则不予创建

转载于:https://blog.51cto.com/3832598/2089456

你可能感兴趣的:(Linux的文件系统、系统管理类命令、bash基础特性)