• linux系统学习(二)


    Bash基础特性1

    用户空间: 命令全部在用户空间交由给Shell翻译后让内核进行执行并返回执行结果

    命令相关

    Shell程序找到输入命令所对应的执行程序或者代码,并由其分析之后提交给内核分配资源

    运行起来之后,将表现为一个或者多个进程

    进程:正在运行的程序

    Shell中可执行的2类命令

    内建命令:Shell自带

    [root@test ~]# type cd

    cd is a shell builtin

    外部命令:某个文件系统路径下有相对应的可执行程序文件

    [root@test ~]# type find

    find is /usr/bin/find

    相关命令:type/whereis/which等命令

    [root@test ~]# whereis ls

    ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz

    [root@test ~]# whereis cd

    cd: /usr/bin/cd /usr/share/man/man1/cd.1.gz

    [root@test ~]# which ls

    alias ls='ls --color=auto'

    /usr/bin/ls

    [root@test ~]# which cd

    /usr/bin/cd

    命令格式:

    <Command> <Options...> <obj/arguments...>

    Options: 长短选项

    arguments: 命令作用的对象/命令提供的数据

    命令执行结果: 失败(非0)或者成功(0)

    echo $? : 判断上一条命令执行的结果

    [root@test ~]# echo $?

    0

    [root@test ~]# cat/etc/sysconfig/network-scripts/ifcfg-ens32

    -bash: cat/etc/sysconfig/network-scripts/ifcfg-ens32: No such file or directory

    [root@test ~]# echo $?

    127

    注意:

    多个选项及参数之间使用空格字符分割,短选项可以合写

    取消命令的执行: Ctrl + c

    命令历史

    查看命令历史: history命令

    历史命令文件: ~/.bash_history  上一次shell所保留的命令

    登录shell时会读取历史命令文件,并将后续的操作命令添加到历史命令文件中

    history命令相关参数:

    -a : 追加本地会话执行的命令历史列表到历史文件当中

    -d : 删除历史中指定的命令

    [root@test ~]# history -d 28 (命令历史ID)

    -c :清空历史命令

    [root@test ~]# history -c

    快捷操作:

    !# 调用历史列表中的第#条命令

    !string 调用历史列表中最近一条以string开头的命令

    !! 调用的是上一条命令

    路径补全

    Tab键进行路径补全操作,所输入的路径必须要唯一

    double Tab键 输出所有符合补全条件的选项

    [root@test ~]# cd /etc/sysc

    sysconfig/   sysctl.conf  sysctl.d/  

    别名

    查看别名: alias

    定义别名: alias [name]=[value]

    alias ll='ls -l --color=auto'

    [root@test ~]# alias pingdu='ping www.baidu.com'

    [root@test ~]# pingdu

    取消别名: unalias [name]

    ---- 对当前会话有效

    如果想要对当前用户生效: 需要将别名的定义写入~/.bashrc配置文件中,并让其生效

    生效:

    立即生效: source .bashrc

    Linxu基础文件操作

    - 目录管理命令

    mkdir命令: 创建目录

    常用参数:

    -p : 递归创建

    -v :显示创建过程

    -m :指定权限

    [root@test tmp]# mkdir -pv book/linux

    mkdir: created directory ‘book’

    mkdir: created directory ‘book/linux’

    rmdir命令:删除目录

    常用参数:

    -p :递归删除

    -v :显示删除过程

    tree命令: 显示目录结构

    [root@test ~]# tree /tmp/

    /tmp/

    ├── ks-script-hAIee3

    ├── systemd-private-337d6cdbf79b462f95ef4782f48a3ab1-chronyd.service-ypCcww

    │   └── tmp

    ├── systemd-private-55cde1ad559f484b84523beb79a83a28-chronyd.service-LGGcQB

    │   └── tmp

    ├── systemd-private-bc28c96f3b4444cbb8187e2ad8be1f16-chronyd.service-QGXJnX

    │   └── tmp

    └── yum.log

    - 文件常用命令

    cat命令:查看文件内容

    tac命令:查看文件内容(从尾部开始)

    more命令: 查看部分文件内容

    less命令: 查看部分文件内容

    head命令: 查看部分文件内容(默认查看文件前10行内容)

    -c : 获取前n个字节

    -n :获取前n行内容

    tail命令: 查看部分文件内容(默认查看文件后10行内容)

    -c :获取后n个字节

    -n :获取后n行内容

    -f : 与tailf命令功能相似

    tailf命令:实时追踪文件尾部内容

    - 文件时间戳

    文件 = 元数据 + 用户数据

    metadata + data

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

    三种类型的文件时间戳:

    Access: 2020-02-06 02:34:47.219532839 -0500  访问时间(读取文件内容) atime

    Modify: 2020-02-06 02:34:47.219532839 -0500  修改时间(改变文件内容) mtime

    Change: 2020-02-06 02:34:47.219532839 -0500  改变事件(元数据的改变) ctime

    touch命令:可以创建文件

    Update the access and modification times of each FILE to the current time.

    命令参数:

    -a :只更改atime

    -m : 只更改mtime

    -t :指定更改时间的格式

    - 文件管理类命令

    cp命令: 复制文件

    Usage: cp [OPTION]... [-T] SOURCE DEST

      or:  cp [OPTION]... SOURCE... DIRECTORY

      or:  cp [OPTION]... -t DIRECTORY SOURCE...

    常见选项参数:

    -i : 交互式

    -r /-R : 递归复制目录和文件

    -a : 归档,文件相关属性

    -p : 连同属性复制

    注意项:

    SRC是单个文件:

    DEST不存在: 将SRC文件内容写入到DEST文件中

    DEST存在: 将SRC文件覆盖至DEST文件中

    SRC是多个文件:

    DEST必须是个目录

    SRC是目录文件:

    需要使用-r参数

    DEST为目录:

    DEST不存在: 创建同名目录和一致性文件

    DEST存在: 一致性文件

    DEST为文件:报错

    mv命令: 移动文件

    Usage: mv [OPTION]... [-T] SOURCE DEST

      or:  mv [OPTION]... SOURCE... DIRECTORY

      or:  mv [OPTION]... -t DIRECTORY SOURCE...

    注意事项类比cp命令

    常用参数:

    -i : 交互式

    -f : 强制性

    rm命令: 删除文件

    常用选项:

    -i : 交互式

    -r : 递归

    -f : 强制

    文件链接

    文件链接(图解)

     

    链接文件类型

    [l]

    ll stat 查看文件类型

    链接方式:

    硬链接:为inode分配多个文件名,通过文件名找到inode,从而读取文件信息

    软链接:类似Window上的快捷方式

    文件 = metadata + data

    inode: 一个指向数据存储位置的指针

    metdata: inode 文件名 等信息

    元数据信息

    [root@test ~]# stat hello

      File: ‘hello’

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

    Device: fd00h/64768d Inode: 33575029    Links: 1

    权限 用户ID ID

    Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)

    selinux权限

    Context: unconfined_u:object_r:admin_home_t:s0

    时间戳

    Access: 2020-02-06 02:51:04.011007753 -0500

    Modify: 2020-02-06 02:50:51.949787952 -0500

    Change: 2020-02-06 02:50:51.950787970 -0500

     Birth: -

    ln命令:创建链接文件

    Usage: ln [OPTION]... [-T] TARGET LINK_NAME   (1st form)

    常见选项:

    -s: 建立软链接文件,默认情况下是硬链接文件

    -f: 强制创建

    [root@test tmp]# ll -i 1.txt

    16777289 -rw-r--r--. 1 root root 0 Feb  6 06:53 1.txt

    [root@test tmp]# echo "hello" > 1.txt

    [root@test tmp]# ln 1.txt 1_hard.txt

    [root@test tmp]# ln -s 1.txt 1_soft.txt

    [root@test tmp]# ll -i

    total 8

    16777289 -rw-r--r--. 2 root root 6 Feb  6 06:53 1_hard.txt

    17256888 lrwxrwxrwx. 1 root root 5 Feb  6 06:55 1_soft.txt -> 1.txt

    16777289 -rw-r--r--. 2 root root 6 Feb  6 06:53 1.txt

    注意:

    1.当我们创建硬链接文件的时候,inode不会发生改变,链接数会加1,同时文件内容相同

    2.当我们创建软链接文件的时候,inode会重新分配,链接数保持为1,同时文件内容相同

    3.链接目的:在节省存储空间的情况下,共享文件

    4. 当源文件内容改变时,软硬链接文件内容都会改变

    [root@test tmp]# echo "eagles" >> 1.txt

    [root@test tmp]# cat 1_soft.txt && cat 1_hard.txt

    hello

    eagles

    hello

    eagles

    5. 当删除源文件时,软链接失效,硬链接正常;硬链接其实和源文件可以说表现上是独立的

    [root@test tmp]# rm 1.txt

    [root@test tmp]# cat 1_soft.txt

    cat: 1_soft.txt: No such file or directory

    [root@test tmp]# cat 1_hard.txt

    hello

    eagles

    硬链接特点:

    1. 无论修改源文件还是硬链接文件,另一个文件都会改变

    2. 无论删除源文件还是硬链接文件,只要存在一个文件(link),这个文件依然可用

    3. 硬链接不会新建inode,也不会更改inode的总数

    4. 硬链接不能跨文件系统,因为在不同的文件系统中inode号是可以重新进行分配的

    5. 硬链接不能够链接目录

    软链接特点:

    1. 无论修改源文件还是软链接文件,另一个文件都会改变

    2. 删除软链接文件,源文件不受影响;反之,软链接文件不正常

    3. 软链接会新建inode号和block,block中不存储实际文件数据,只存源文件的inode和绝对路径

    4. 软链接是可以链接目录的

    5. 软连接是可以跨分区的

    那只删除文件名的话,文件占用的空间会释放吗?

    会将link数减1; 当link为0时,文件占用的空间将释放掉

     

     

    文件系统

    重定向及管道

    程序 = 指令 + 数据

    数据: 输入/输出数据

    每打开一个文件都会有一个文件描述符fd

    输入输出

    标准输入

    标准输出 1

    标准错误输出 2

    输出重定向

    >  覆盖重定向

    >> 追加重定向

    2> 覆盖重定向错误输出流

    2>> 追加重定向错误输出流

    [root@test tmp]# echo "hello eagles"

    hello eagles

    [root@test tmp]# echo "hello eagles" > 2.txt

    [root@test tmp]# cat 2.txt

    hello eagles

    [root@test tmp]# echo "hello eagles" >> 2.txt

    [root@test tmp]# cat 2.txt

    hello eagles

    hello eagles

    [root@test tmp]# lnd

    -bash: lnd: command not found

    [root@test tmp]# lnd 2> output_error

    [root@test tmp]# cat output_error

    -bash: lnd: command not found

    [root@test tmp]# lnd 2>> output_error

    [root@test tmp]# cat output_error

    -bash: lnd: command not found

    -bash: lnd: command not found

    标准输出和错误输出到各自不同的位置

    [root@test tmp]# ll 1> file.out 2> file_error.out

    [root@test tmp]# cat file.out

    total 8

    lrwxrwxrwx. 1 root root  5 Feb  6 07:26 1_soft.txt -> 1.txt

    -rw-r--r--. 1 root root  0 Feb  6 07:26 1.txt

    -rw-r--r--. 1 root root 26 Feb  6 07:51 2.txt

    -rw-r--r--. 1 root root  0 Feb  6 07:53 file_error.out

    -rw-r--r--. 1 root root  0 Feb  6 07:53 file.out

    -rw-r--r--. 1 root root 60 Feb  6 07:51 output_error

    [root@test tmp]# lld 1> file.out 2> file_error.out

    [root@test tmp]# cat file_error.out

    -bash: lld: command not found

    垃圾桶: /dev/null

    合并标准输出和错误输出为同一数据流进行重定向

    &>  覆盖重定向

    &>> 追加重定向

    2>&1  将错误流重定向到标准输出文件中 (>>)

    1>&2  将正确流重定向到错误输出文件中  (>>)

    [root@test tmp]# lld &> all.out

    [root@test tmp]# ll &>> all.out

    [root@test tmp]# cat all.out

    -bash: lld: command not found

    total 16

    lrwxrwxrwx. 1 root root  5 Feb  6 07:26 1_soft.txt -> 1.txt

    -rw-r--r--. 1 root root  0 Feb  6 07:26 1.txt

    -rw-r--r--. 1 root root 26 Feb  6 07:51 2.txt

    -rw-r--r--. 1 root root 30 Feb  6 07:56 all.out

    -rw-r--r--. 1 root root 30 Feb  6 07:53 file_error.out

    -rw-r--r--. 1 root root  0 Feb  6 07:53 file.out

    -rw-r--r--. 1 root root 60 Feb  6 07:51 output_error

    [root@test tmp]# lld 1> file.out 2> file_error.out 2>&1

    [root@test tmp]# cat file.out

    -bash: lld: command not found

    [root@test tmp]# ll 1> file.out 2> file_error.out 1>&2

    [root@test tmp]# cat file_error.out

    total 16

    -rw-r--r--. 1 root root  30 Feb  6 07:57 1.out

    lrwxrwxrwx. 1 root root   5 Feb  6 07:26 1_soft.txt -> 1.txt

    -rw-r--r--. 1 root root   0 Feb  6 07:26 1.txt

    -rw-r--r--. 1 root root  26 Feb  6 07:51 2.txt

    -rw-r--r--. 1 root root 396 Feb  6 07:56 all.out

    -rw-r--r--. 1 root root   0 Feb  6 07:59 file_error.out

    -rw-r--r--. 1 root root   0 Feb  6 07:59 file.out

    -rw-r--r--. 1 root root  60 Feb  6 07:51 output_error

    标准输入

    覆盖:

    cat > /path/somefile <<EOF

    ....

    EOF

    追加:

    cat >> /path/somefile <<EOF

    ....

    EOF

    cat > test.txt <<EOF

    hello eagles

    hello Linux

    EOF

    cat >> test.txt <<EOF

    hello eagles

    hello Linux

    EOF

    管道

    command1 | command2 | command3 ...

    最后一个命令会在当前shell进程的子shell进程中执行;前一个命令的执行结果

    会由当前命令继续使用

    tr命令:

    Usage: tr [OPTION]... SET1 [SET2]

    常用选项:

    -d: 删除

    案例1:将/etc/passwd文件中的前5行内容转换为大写后保存至/tmp/passwd.out文件中 

    [root@node1 ~]# head ‐n 5 /etc/passwd | tr 'a‐z' 'A‐Z' > /tmp/passwd.output 

    案例2:将登陆至当前系统上用户信息中的最后1行的信息转换为大写后保存至/tmp/who.out文件中 

    [root@node1 ~]# who | tail ‐n 1 | tr 'a‐z' 'A‐Z' >/tmp/who.out

    案例3:将文件中的:删除之后重定向到新文件中

    [root@test tmp]# cat output_error | tr -d ":" > output_error_new

    wc命令:统计

    Usage: wc [OPTION]... [FILE]...

    [root@test tmp]# wc test.txt

     4  8 50 test.txt

    常用参数:

    -l : 行数

    -w : 单词数

    -c :字符数

    [root@test tmp]# wc -l test.txt

    4 test.txt

    [root@test tmp]# wc -w test.txt

    8 test.txt

    [root@test tmp]# wc -c test.txt

    50 test.txt

    cut命令:

    [root@test tmp]# cut --help

    Usage: cut OPTION... [FILE]...

    Print selected parts of lines from each FILE to standard output.

    常用参数:

    -d: 指定分隔符

    -f: 指定字段

    实例: :为分隔符显示第7列内容

    [root@test tmp]# cut -d: -f7 passwd.output

    sort命令

    常用参数:

    -f: 忽略大小写

    -r:逆序

    -t:字段分隔符

    -k #: 以指定字段为标准排序

    -n: 以数字进行排序(默认情况下,如果没有-n参数,会以ASCII进行排序)

    -u: 排序后进行去重

    实例: :为分隔符,指定第3字段,以数字进行逆序

    [root@test tmp]# sort -t: -k3 -r -n passwd.output

    uniq命令:去重

    常用参数:

    -c : 显示每行出现的次数

    -d :仅显示重复过的行

    -u :仅显示不曾重复过的行

    实例:

    [root@test tmp]# uniq -c test.txt

          2 hello eagles

          2 hello Linux

          1 fjkldlaj

          1 fdkajjf;

    [root@test tmp]# uniq -d test.txt

    hello eagles

    hello Linux

    [root@test tmp]# uniq -u test.txt

    fjkldlaj

    fdkajjf;

    测试文本:

    [root@test tmp]# cat test.txt

    hello eagles

    hello eagles

    hello Linux

    hello Linux

    fjkldlaj

    fdkajjf;

    综合案例:以:为分割,取出/etc/passwd文件的第6列至第10列,并将这些信息按照第3个字段的数值大小进行排序,最后仅显示一个字段

    [root@node1 ~]# cut ‐d: ‐f6‐10 /etc/passwd |cut ‐f3 | sort ‐n |uniq -c

    [root@test tmp]# cut -d: -f6-10 /etc/passwd | sort -t: -k3 -n | uniq -c

    文件目录结构

    CentOS的目录大体上可分为四类:管理类、用户类、应用程序类、信息类文件目录。

    管理类目录:

        /boot linux

          的内核及引导系统程序所需要的文件目录

        /bin

          存放标准 linux 的工具,在终端里输入ls,系统就系统将会到该目录查看是否存在该命令程序。

        /sbin

          大多是涉及系统管理的命令的存放,是超级权限用户root的可执行命令存放地,普通用户无权限执行这个目录下的命令

        /var

          这个目录的内容是经常变动的,用来存储经常被修改的文件,如日志、数据文件、邮箱等

        /etc

          主要存放系统配置方面的文件

        /dev

          主要存放与设备有关的文件

        /mnt

          这个目录一般是用于存放挂载储存设备的挂载目录的,比如有cdrom 等目录。可以参看/etc/fstab的定义

    用户类目录:

        /root

          系统管理员目录

        /home

          主要存放个人数据

    应用程序类目录:

        /lib

          该目录用来存放系统动态链接共享库,几乎所有的应用程序都会用到该目录下的共享库

        /tmp

          临时目录,有些linux会定期清理

        /usr

          存放一些不适合放在/bin 或 /etc 目录下的额外工具,如个人安装的程序或工具

        /usr/local

          主要存放那些手动安装的软件,

        /usr/bin

          用于存放程序

        /usr/share

          用于存放一些共享数据

        /usr/lib

          存放一些不能不能直接运行,但却是许多程序运行所必需的一些函数库文件

        /opt

          主要存放可选程序,直接删除程序不影响系统其设置。安装到/opt目录下的程序,它所有的数据、库文件等等都是放在同个目录下面

    信息类目录:

        /lost+found

          在ext2或ext3文件系统中,当系统意外崩溃或机器意外关机,而产生一些文件碎片放在这里。但当突然停电、或者非正常关机后,有些文件就临时存放在这里。

        /proc

          操作系统运行时,进程信息及内核信息(比如cpu、硬盘分区、内存信息等)存放在这里

    其他重要目录:

        /etc/rc.d

          放置开机和关机的脚本。

        /etc/rc.d/init.d

          放置启动脚本

        /etc/xinetd.d

          配置xinetd.conf可以配置启动其他额外服务。

        /usr/include

          一些distribution套件的头文件放置目录,安装程序时可能会用到。

        /usr/lib*

          套件的程序库

        /usr/local

          默认的软件安装目录。

        /usr/share/doc

          系统说明文件的放置目录

        /usr/share/man

          程序说明文件放置目录

        /usr/src

          内核源代码目录

        /usr/X11R6

          X的存放目录

    linux 目录结构

    目录结构

        /:

          根目录,一般根目录下只存放目录,不要存放文件,/etc、/bin、/dev、/lib、/sbin应该和根目录放置在一个分区中

        /bin:/usr/bin:

          可执行二进制文件的目录,如常用的命令ls、tar、mv、cat等。

        /boot:

          放置linux系统启动时用到的一些文件。/boot/vmlinuz为linux的内核文件,以及/boot/gurb。建议单独分区,分区大小100M即可

        /dev:

          存放linux系统下的设备文件,访问该目录下某个文件,相当于访问某个设备,常用的是挂载光驱mount /dev/cdrom /mnt。

        /etc:

          系统配置文件存放的目录,不建议在此目录下存放可执行文件,重要的配置文件有/etc/inittab、/etc/fstab、/etc/init.d、/etc/X11、/etc/sysconfig、/etc/xinetd.d修改配置文件之前记得备份。注:/etc/X11存放与x windows有关的设置。

        /home:

          系统默认的用户家目录,新增用户账号时,用户的家目录都存放在此目录下,~表示当前用户的家目录,~test表示用户test的家目录。建议单独分区,并设置较大的磁盘空间,方便用户存放数据

        /lib:/usr/lib:/usr/local/lib:

          系统使用的函数库的目录,程序在执行过程中,需要调用一些额外的参数时需要函数库的协助,比较重要的目录为/lib/modules。

        /lost+fount:

          系统异常产生错误时,会将一些遗失的片段放置于此目录下,通常这个目录会自动出现在装置目录下。如加载硬盘于/disk 中,此目录下就会自动产生目录/disk/lost+found

        /mnt:/media:

          光盘默认挂载点,通常光盘挂载于/mnt/cdrom下,也不一定,可以选择任意位置进行挂载。

        /opt:

          给主机额外安装软件所摆放的目录。如:FC4使用的Fedora 社群开发软件,如果想要自行安装新的KDE 桌面软件,可以将该软件安装在该目录下。以前的 Linux 系统中,习惯放置在 /usr/local 目录下

        /proc:

          此目录的数据都在内存中,如系统核心,外部设备,网络状态,由于数据都存放于内存中,所以不占用磁盘空间,比较重要的目录有/proc/cpuinfo、/proc/interrupts、/proc/dma、/proc/ioports、/proc/net/*等

        /root:

          系统管理员root的家目录,系统第一个启动的分区为/,所以最好将/root和/放置在一个分区下。

        /sbin:/usr/sbin:/usr/local/sbin:

          放置系统管理员使用的可执行命令,如fdisk、shutdown、mount等。与/bin不同的是,这几个目录是给系统管理员root使用的命令,一般用户只能”查看”而不能设置和使用。

        /tmp:

          一般用户或正在执行的程序临时存放文件的目录,任何人都可以访问,重要数据不可放置在此目录下

        /srv:

          服务启动之后需要访问的数据目录,如www服务需要访问的网页数据存放在/srv/www内

        /usr:

          应用程序存放目录, /usr/bin 存放应用程序, /usr/share 存放共享数据, /usr/lib 存放不能直接运行的,却是许多程序运行所必需的一些函数库文件。 /usr/local:存放软件升级包。 /usr/share/doc: 系统说明文件存放目录。 /usr/share/man: 程序说明文件存放目录,使用 man ls时会查询/usr/share/man/man1/ls.1.gz的内容建议单独分区,设置较大的磁盘空间

        /var:

          放置系统执行过程中经常变化的文件,如随时更改的日志文件 /var/log,/var/log/message: 所有的登录文件存放目录, /var/spool/mail: 邮件存放的目录, /var/run: 程序或服务启动后,其PID存放在该目录下。建议单独分区,设置较大的磁盘空间

    /dev: 目录

        dev是设备(device)的英文缩写。/dev这个目录对所有的用户都十分重要。因为在这个目录中包含了所有Linux系统中使用的外部设备。但是这里并不是放的外部设备的驱动程序,这一点和windows,dos操作系统不一样。它实际上是一个访问这些外部设备的端口。我们可以非常方便地去访问这些外部设备,和访问一个文件,一个目录没有任何区别。

        Linux沿袭Unix的风格,将所有设备认成是一个文件。

        设备文件分为两种:块设备文件(b)和字符设备文件(c)

        设备文件一般存放在/dev目录下,对常见设备文件作如下说明:

        /dev/hd[a-t]:IDE设备

        /dev/sd[a-z]:SCSI设备

        /dev/fd[0-7]:标准软驱

        /dev/md[0-31]:软raid设备

        /dev/loop[0-7]:本地回环设备

        /dev/ram[0-15]:内存

        /dev/null:无限数据接收设备,相当于黑洞

        /dev/zero:无限零资源

        /dev/tty[0-63]:虚拟终端

        /dev/ttyS[0-3]:串口

        /dev/lp[0-3]:并口

        /dev/console:控制台

        /dev/fb[0-31]:framebuffer

        /dev/cdrom => /dev/hdc

        /dev/modem => /dev/ttyS[0-9]

        /dev/pilot => /dev/ttyS[0-9]

        /dev/random:随机数设备

        /dev/urandom:随机数设备

        /dev目录下的节点是怎么创建的?

        devf或者udev会自动帮你创建得。

        kobject是sysfs文件系统的基础,udev通过监测、检测sysfs来获取新创建的设备的。

    /etc: 目录

    包含很多文件.许多网络配置文件也在/etc 中.

        /etc/rc or /etc/rc.d or /etc/rc*.d

          启动、或改变运行级时运行的scripts或scripts的目录.

        /etc/passwd

          用户数据库,其中的域给出了用户名、真实姓名、家目录、加密的口令和用户的其他信息.

        /etc/fstab

          启动时mount -a命令(在/etc/rc 或等效的启动文件中)自动mount的文件系统列表. Linux下,也包括用swapon -a启用的swap区的信息.

        /etc/group

          类似/etc/passwd ,但说明的不是用户而是组.

        /etc/inittab

          init 的配置文件.

        /etc/issue

          getty 在登录提示符前的输出信息.通常包括系统的一段短说明或欢迎信息.内容由系统管理员确定.

        /etc/motd

          Message Of The Day,成功登录后自动输出.内容由系统管理员确定.经常用于通告信息,如计划关机时间的警告.

        /etc/mtab

          当前安装的文件系统列表.由scripts初始化,并由mount 命令自动更新.需要一个当前安装的文件系统的列表时使用,例如df 命令.

        /etc/shadow

          在安装了影子口令软件的系统上的影子口令文件.影子口令文件将/etc/passwd 文件中的加密口令移动到/etc/shadow 中,而后者只对root可读.这使破译口令更困难.

        /etc/login.defs

          login 命令的配置文件.

        /etc/printcap

          类似/etc/termcap ,但针对打印机.语法不同.

        /etc/profile , /etc/csh.login , /etc/csh.cshrc

          登录或启动时Bourne或C shells执行的文件.这允许系统管理员为所有用户建立全局缺省环境.

        /etc/securetty

          确认安全终端,即哪个终端允许root登录.一般只列出虚拟控制台,这样就不可能(至少很困难)通过modem或网络闯入系统并得到超级用户特权.

        /etc/shells

          列出可信任的shell.chsh 命令允许用户在本文件指定范围内改变登录shell.提供一台机器FTP服务的服务进程ftpd 检查用户shell是否列在 /etc/shells 文件中,如果不是将不允许该用户登录.

        /etc/sysconfig

          网络配置相关目录

    /proc: 目录

        /proc/cmdline

          加载 kernel 时所下达的相关参数!查阅此文件,可了解系统是如何启动的!

        /proc/cpuinfo

          本机的 CPU 的相关资讯,包含时脉、类型与运算功能等

        /proc/devices

          这个文件记录了系统各个主要装置的主要装置代号,与 mknod 有关呢!

        /proc/filesystems

          目前系统已经加载的文件系统罗!

        /proc/interrupts

          目前系统上面的 IRQ 分配状态。

        /proc/ioports

          目前系统上面各个装置所配置的 I/O 位址。

        /proc/kcore

          这个就是内存的大小啦!好大对吧!但是不要读他啦!

        /proc/loadavg

          还记得 top 以及 uptime 吧?没错!上头的三个平均数值就是记录在此!

        /proc/meminfo

          使用 free 列出的内存资讯,嘿嘿!在这里也能够查阅到!

        /proc/modules

          目前我们的 Linux 已经加载的模块列表,也可以想成是驱动程序啦!

        /proc/mounts

          系统已经挂载的数据,就是用 mount 这个命令呼叫出来的数据啦!

        /proc/swaps

          到底系统挂加载的内存在哪里?呵呵!使用掉的 partition 就记录在此啦!

        /proc/partitions

          使用 fdisk -l 会出现目前所有的 partition 吧?在这个文件当中也有纪录喔!

        /proc/pci

          在 PCI 汇流排上面,每个装置的详细情况!可用 lspci 来查阅!

        /proc/uptime

          就是用 uptime 的时候,会出现的资讯啦!

        /proc/version

          核心的版本,就是用 uname -a 显示的内容啦!

        /proc/bus/*

          一些汇流排的装置,还有 U盘 的装置也记录在此喔!

    /usr: 目录

    /usr 文件系统经常很大,因为所有程序安装在这里. /usr 里的所有文件一般来自Linux distribution;本地安装的程序和其他东西在/usr/local下.这样可能在升级新版系统或新distribution时无须重新安装全部程序.

        /usr/etc

          存放设置文件

        /usr/games

          存放游戏和教学文件

        /usr/include

          存放C开发工具的头文件

        /usr/share

          存放结构独立的数据

        /usr/bin

          几乎所有用户命令.有些命令在/bin 或/usr/local/bin 中.

        /usr/sbin

          根文件系统不必要的系统管理命令,例如多数服务程序.

        /usr/share/man , /usr/share/info , /usr/share/doc

          手册页、GNU信息文档和各种其他文档文件.

        /usr/include

          C编程语言的头文件.为了一致性这实际上应该在/usr/lib 下,但传统上支持这个名字.

        /usr/lib

          程序或子系统的不变的数据文件,包括一些site-wide配置文件.名字lib来源于库(library); 编程的原始库存在/usr/lib 里.

        /usr/local

          本地安装的软件和其他文件放在这里.

        /usr/src

          存放程序的源代码

    /var: 目录

    /var 包括系统一般运行时要改变的数据.每个系统是特定的,即不通过网络与其他计算机共享.

        /var/catman

          当要求格式化时的man页的cache.man页的源文件一般存在/usr/man/man 中;有些man页可能有预格式化的版本,存在/usr/man/cat 中.而其他的man页在第一次看时需要格式化,格式化完的版本存在/var/man 中,这样其他人再看相同的页时就无须等待格式化了. (/var/catman 经常被清除,就象清除临时目录一样.)

        /var/lib

          系统正常运行时要改变的文件.

        /var/local

          /usr/local 中安装的程序的可变数据(即系统管理员安装的程序).注意,如果必要,即使本地安装的程序也会使用其他/var 目录,例如/var/lock .

        /var/lock

          锁定文件.许多程序遵循在/var/lock 中产生一个锁定文件的约定,以支持他们正在使用某个特定的设备或文件.其他程序注意到这个锁定文件,将不试图使用这个设备或文件.

        /var/log

          各种程序的Log文件,特别是login (/var/log/wtmp log所有到系统的登录和注销) 和syslog (/var/log/messages 里存储所有核心和系统程序信息. /var/log 里的文件经常不确定地增长,应该定期清除.

        /var/run

          保存到下次引导前有效的关于系统的信息文件.例如, /var/run/utmp 包含当前登录的用户的信息.

        /var/spool

          mail, news, 打印队列和其他队列工作的目录.每个不同的spool在/var/spool 下有自己的子目录,例如,用户的邮箱在/var/spool/mail 中.

        var/tmp

          比/tmp 允许的大或需要存在较长时间的临时文件. (虽然系统管理员可能不允许/var/tmp 有很旧的文件.)

    比较重要的目录

    Linux 系统中,有几个目录是特别需要注意的,以下提供几个需要注意的目录,以及预设相关的用途: 

        /etc:

          这个目录相当重要,如前所述,你的开机与系统数据文件均在这个目录之下,因此当这个目录被破坏,那你的系统大概也就差不多该死掉了!而在往后的文件中,你会发现我们常常使用这个目录下的 /etc/rc.d/init.d 这个子目录,因为这个 init.d 子目录是开启一些 Linux 系统服务的 scripts (可以想成是批次檔 )的地方。而在 /etc/rc.d/rc.local 这个文件是开机的执行档。 

        /bin, /sbin, /usr/bin, /usr/sbin:

          这是系统预设的执行文件的放置目录,例如 root 常常使用的 userconf, netconf, perl, gcc, c++ 等等的数据都放在这几个目录中,所以如果你在提示字符下找不到某个执行档时,可以在这四个目录中查一查!其中, /bin, /usr/bin 是给系统使用者使用的指令,而 /sbin, /usr/sbin 则是给系统管理员使用的指令!  

        /usr/local:

          这是系统预设的让你安装你后来升级的套件的目录。例如,当你发现有更新的 Web 套件(如 Apache )可以安装,而你又不想以 rpm 的方式升级你的套件,则你可以将 apache 这个套件安装在 /usr/local 底下。安装在这里有个好处,因为目前大家的系统都是差不多的,所以如果你的系统要让别人接管的话,也比较容易上手呀!也比较容易找的到数据喔!因此,如果你有需要的话,通常我都会将 /usr/local/bin 这个路径加到我的 path 中。 

        /home:

          这个是系统将有账号的人口的家目录设置的地方。  

        /var:

          这个路径就重要了!不论是登入、各类服务的问题发生时的记录、以及常态性的服务记录等等的记录目录,所以当你的系统有问题时,就需要来这个目录记录的文件数据中察看问题的所在啰!而 mail 的预设放置也是在这里,所以他是很重要的  

        /usr/share/man, /usr/local/man:

          这两个目录为放置各类套件说明档的地方,例如你如果执行 man man,则系统会自动去找这两个目录下的所有说明文件

    Bash快捷键

    bash快捷键  常用的很多没列出

      ctrl+l                                    清屏

      ctrl+y            将删除的粘贴到光标处

      ctrl+z          挂起

      ctrl+c            强行终止

      ctrl+s          锁定屏幕,组织输出

      ctrl+t          交换字符,将光标前的字符与光标处的字符交换

      ctrl+q          对应以上ctrl+s的命令,对ctrl+s进行恢复

      ctrl+o          执行当前命令,并重新显示本命令 

      ctrl+e          将光标移至行尾

      ctrl+a          将光标移至行首

      ctrl+u          删除到行首

      ctrl+k          删除到行尾

      ctrl+d          删除光标上的字符

      ctrl+h          删除光标前的字符

      ctrl+w          向左删除至单词首        

      alt+r          删除整行

      alt+f          光标向右移至单词尾

      alt+b          光标向左移至单词首

      alt+t          将光标处的单词与前一个单词换位置

      alt+d          向左删除至单词首

     

    面试题:如果创建文件失败可能有哪些原因

    .空间爆满
    空间不足没内存了

    .文件数量inodes超出限制

    三.权限不足

    没有写入权限

    四.存在同名文件

    五.Inodes用完了

    六.命令格式错了

  • 相关阅读:
    设置sqlplus输出格式
    Using CrunchBase API
    Docker ( Is docker really better than VM ?)
    Cross platform GUI for creating SSL certs with OpenSSL
    PHP, Python Nginx works together!
    Your personal Mail Server iRedMail on ubuntu14.04 x64
    iphone/ipad/iOS on Linux Debian7/ubuntu12.04/linuxmint13/ubuntu14.04 compiling from source
    Internet Liberity -- a specific anonymous internet guide
    Organic Solar Cells
    Organic Solar Cells
  • 原文地址:https://www.cnblogs.com/panfei-ywg/p/12712761.html
Copyright © 2020-2023  润新知