Linux目录结构&文件管理

Windows: 以多根的方式组织文件 C:\ D:\ E:\
Linux: 以单根的方式组织文件 /

/目录结构: FSH (Filesystem Hierarchy Standard)

  1 [root@admin ~]# ls /
  2 bin     dev   lib          media  net   root     srv  usr
  3 boot    etc   lib64       misc   opt   sbin     sys  var
  4 cgroup  home  lost+found  mnt    proc  selinux  tmp

注:下图为Centos7目录结构

1210730-20180826202113774-1466136100


  1 bin            普通用户使用的命令 /bin/ls, /bin/date
  2 sbin           管理员使用的命令 /sbin/service
  3 dev            设备文件 /dev/sda,/dev/sda1,/dev/tty1,/dev/tty2,/dev/pts/1, /dev/zero,/dev/null, /dev/random
  4 root            root用户的HOME
  5 home            存储普通用户家目录
  6 lost+found      fsck修复时,存储没有链接的文件或目录
  7 proc            虚拟的文件系统,反映出来的是内核,进程信息或实时状态


  1 usr               系统文件,相当于C:\Windows
  2                      /usr/local     软件安装的目录,相当于C:\Program
  3                      /usr/bin      普通用户使用的应用程序
  4                      /usr/sbin     管理员使用的应用程序
  5                      /usr/lib      库文件Glibc
  6                      /usr/lib64   库文件Glibc
  7 
  1 boot                存放的系统启动相关的文件,例如kernel,grub(引导装载程序)
  2 etc                  配置文件(系统相关如网络/etc/sysconfig/network,应用相关配置文件如/etc/ssh/sshd_config...)
  3 lib              库文件Glibc
  4 lib64            库文件Glibc
  5 tmp                临时文件(全局可写:进程产生的临时文件)
  6 var                存放的是一些变化文件,比如数据库,日志,邮件....
  7                     mysql:              /var/lib/mysql
  8                     vsftpd:            /var/ftp
  9                     mail:                /var/spool/mail
 10                     cron:                /var/spool/cron
 11                     log:                /var/log
 12                     临时文件:     /var/tmp(进程产生的临时文件)
==设备(主要指存储设备)挂载目录==
    media         移动设备默认的挂载点
    mnt           手工挂载设备的挂载点
    misc          automount进程挂载
    net           automount进程挂载
命令存储位置:
  1 /bin              普通用户使用的命令 /bin/ls, /bin/date           RHEL7淘汰
  2 /sbin             管理员使用的命令                                RHEL7淘汰
  3 /usr/bin          普通用户使用的应用程序
  4 /usr/sbin         管理员使用的应用程序
库文件存储位置:
  1 /lib      库文件Glibc RHEL7淘汰
  2 /lib64      库文件Glibc RHEL7淘汰
  3 /usr/lib   库文件Glibc
  4 /usr/lib64   库文件Glibc


文件时间

ls -l 文件名 仅看的是文件的修改时间

  Linux文件有四种时间:

# stat anaconda-ks.cfg //查看文件的详细属性(其中包括文件时间属性)
访问时间:atime, 查看内容 //RHEL6会延后修改atime
修改时间:mtime,修改内容
改变时间:ctime, 文件属性,比如权限
删除时间:dtime, 文件被删除的时间

  1 [root@root ~]# ls -l install.log
  2 -rw-r--r-- 1 root root 34793 08-23 13:49 install.log
  1 [root@root ~]# stat install.log
  2   File: “install.log”
  3   Size: 34793           Blocks: 80         IO Block: 4096   一般文件
  4 Device: 802h/2050d      Inode: 65282       Links: 1
  5 Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
  6 Access: 2020-08-23 16:53:20.000000000 +0800
  7 Modify: 2020-08-23 13:49:46.000000000 +0800
  8 Change: 2020-08-23 13:49:52.000000000 +0800

   注:RHEL6开始relatime,atime延迟修改,必须满足其中一个条件:
        1. 自上次atime修改后,已达到86400秒;
        2. 发生写操作时;

文件类型:

      通过颜色判断文件的类型是不一定正确的!!!
      Linux系统中文件是没有扩展名!!!

方法一:
ls   -l 文件名    //看第一个字符
-    普通文件(文本文件,二进制文件,压缩文件,电影,图片。。。)
d    目录文件(蓝色)
b    设备文件(块设备)存储设备硬盘,U盘 /dev/sda, /dev/sda1
c    设备文件(字符设备)打印机,终端 /dev/tty1
s    套接字文件
p    管道文件
l    链接文件(淡蓝色)
  1 [root@root ~]# ll -d /etc/hosts /bin/ls /home /dev/sda /dev/tty1 /etc/grub2.cfg /dev/log /run/dmeventd-client
  2 -rwxr-xr-x.  1 root root 117616 Nov 20  2015 /bin/ls
  3 srw-rw-rw-   1 root root      0 Mar 14  2017 /dev/log
  4 brw-rw----   1 root disk   8, 0 Mar 14 09:03 /dev/sda
  5 crw--w----   1 root tty    4, 1 Mar 14 09:03 /dev/tty1
  6 lrwxrwxrwx.  1 root root     22 Dec 21 01:40 /etc/grub2.cfg -> ../boot/grub2/grub.cfg
  7 -rw-r--r--   1 root root    392 Feb 22 15:51 /etc/hosts
  8 drwxr-xr-x. 10 root root   4096 Mar 14 11:00 /home
方法二:file
  1 [root@localhost ~]# file /etc/hosts
  2 /etc/hosts: ASCII text
  3 
  4 [root@localhost ~]# file /bin/ls
  5 /bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=aa7ff68f13de25936a098016243ce57c3c982e06, stripped
  6 
  7 [root@localhost ~]# file /dev/sda
  8 /dev/sda: block special
  9 
 10 [root@localhost ~]# file /dev/tty1
 11 /dev/tty1: character special
 12 
 13 [root@localhost ~]# file /etc/grub2.cfg
 14 /etc/grub2.cfg: broken symbolic link to `../boot/grub2/grub.cfg'
 15 
 16 [root@localhost ~]# file /home
 17 /home: directory
 18 
 19 [root@localhost ~]# file /run/dmeventd-client
 20 /run/dmeventd-client: fifo (named pipe)

路径 (定位文件)


        /home/alice/file1 和 /home/bob/file1 不是同一文件!!!
       /abc/file5 和 abc/file5 有可能是不一样的!!!

       绝对路径: 从/开始的路径 /home/alice/file1
       相对路径: 相对于当前目录开始 a.txt ./a.txt ../bob/b.txt [假如:此时在目录/home/alice]

文件管理

      cd 改变目录
  1 cd                  绝对路径    cd /home/alice     cd ~alice
  2 cd                  相对路径    cd Desktop/abc    cd ..   cd .

cd 专用:
cd -                  返回上次目录   
cd                      直接回家

文件管理之:创建/复制/移动/删除
创建
  1 文件 touch
  2 # touch file1.txt                             //无则创建,有则修改时间
  3 # touch file3 file4
  4 # touch /home/file10.txt
  5 # touch /home/file5 file6
  6 # touch /home/{zhuzhu,gougou}
  7 # touch file{1..20}
  8 # touch file{a..c}
  9 # touch yang{a,b,c}                      //{}集合,等价touch yanga yangb yangc
 10 
 11 目录 mkdir
 12 # mkdir dir1
 13 # mkdir /home/dir2 /home/dir3
 14 # mkdir /home/{dir4,dir5}
 15 # mkdir -v /home/{dir6,dir7}
 16 # mkdir -v /hoem/dir8/111/22
 17 # mkdir -pv /hoem/dir8/111/222    //包括其父母的创建,不会有任何消息输出
 18 # mkdir -pv /home/{yang/{dir1,111},tianyun}
复制 cp
  1 Usage: cp [OPTION]... [-T] SOURCE DEST
  2 # cd
  3 # mkdir /home/dir{1,2}
  4 # cp -v install.log /home/dir1
  5 # cp -v install.log /home/dir1/yang.txt
  6 # cp -rv /etc /home/dir1
  7 # cp -v install.log /home/dir90       //没有/home/dir90
  8 # cp -v install.log /home/dir2
  9 # cp -v anaconda-ks.cfg !$
 10 # cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /home/dir2            //将多个文件拷贝到同一个目录
 11 # cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /etc/hosts .
 12 # cp -r /etc /tmp
 13 # cp -rf /etc /tmp
 14 # \cp -r /etc /tmp
  1 [root@localhost ~]#  type -a cp
  2 cp is aliased to `cp -i'
  3 cp is /bin/cp
  4 
  5 [root@localhost ~]#  cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,ifcfg-eth0.bak}
  6 [root@localhost ~]#  cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0{,-org}
  7 [root@localhost ~]#  cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,yang-eth0}
移动 mv
  1 Usage: mv [OPTION]... [-T] SOURCE DEST
  2 # mv file1 /home/dir3               将file2移动到/home/dir3
  3 # mv file2 /home/dir3/file20      将file2移动到/home/dir3,并改名为file20
  4 # mv file4 file5                          将file4重命名为file5,当前位置的移动就是重命名
删除 rm
  1 示例1:删除/home/dir1
  2 # cd /home
  3 # rm -rf dir1
  4 -r 递归
  5 -f force强制
  6 -v 详细过程
  7 
  8 示例2:
  9 [root@localhost~]# mkdir /home/dir10
 10 [root@localhost~]# touch /home/dir10/{file2,file3,.file4}
 11 [root@localhost~]# rm -rf /home/dir10/*                                    //不包括隐藏文件
 12 [root@localhost~]# ls /home/dir10/ -a
 13 .  ..  .file4
 14 
 15 示例3:
 16 [root@localhost~]# rm -rf file*
 17 [root@localhost~]# rm -rf *.pdf
文件管理之:查看文件内容
  1 ==文本文件 (cat tac less more head tail tailf grep ...)
  2 /bin/date
  3 /etc/hosts
  4 /etc/sysconfig/network
  5 /etc/sysconfig/network-scripts/ifcfg-eth0
  6 /etc/passwd
  7 /etc/shadow
  8 /etc/group
  9 /etc/grub2.cfg
 10 /etc/resolv.conf
 11 /etc/profile                            //设置系统环境变量
 12 /etc/bashrc                           //影响bash shell环境
 13 /var/log/messages                   //系统主日志文件
  1 cat
  2 -n  显示行号
  3 -A  包括控制字符(换行符/制表符)
  4      linux $
  5      Windows ^M$
  6 
  7 less  more head  tail  tailf
  8 [root@localhost~]# head  /etc/passwd
  9 [root@localhost~]# head -2 /etc/passwd
 10 [root@localhost~]# tail /etc/passwd
 11 [root@localhost~]# tail -1 /etc/passwd
 12 [root@localhost~]# tail /var/log/messages
 13 [root@localhost~]# tail -20 /var/log/messages
 14 [root@localhost~]# tail -f /var/log/secure              //-f 动态查看文件的尾部
 15 [root@localhost~]# tail -F /var/log/secure              //-F 动态查看文件的尾部
 16 注:vim, gedit编辑文件时,索引号会改变
 17 
 18 grep 针对文件内容进行过滤
 19 # grep 'root' /etc/passwd
 20 # grep '^root' /etc/passwd
 21 # grep 'bash$' /etc/passwd
 22 # grep 'failure' /var/log/secure


文件管理之:修改文件内容

[root@localhost~]# ll -a > list.txt
文件编辑器 gedit
文件编辑器 vi, vim, nano


  1 命令模式:
  2     a. 光标定位
  3         hjkl
  4         0 $
  5         gg G
  6         3G      进入第三行
  7         /string (n N 可以循环的)  快速定位到某一行
  8         /^d
  9         /txt$
 10 
 11     b. 文本编辑(少量)
 12         y        复制  yy 3yy ygg  yG         (以行为单位)
 13         d        删除 dd 3dd dgg  dG           (以行为单位)
 14         p        粘贴
 15         x        删除光标所在的字符
 16         D        从光标处删除到行尾
 17         u        undo撤销
 18         ^r       redo重做
 19         r        可以用来修改一个字符
 20 
 21     c. 进入其它模式
 22         a        进入插入模式
 23         i        进入插入模式
 24         o        进入插入模式
 25         A        进入插入模式
 26 
 27         :        进入末行模式(扩展命令模式)
 28         v        进入可视模式
 29         ^v       进入可视块模式
 30         V        进入可视行模式
 31         R        进入替换模式
 32 
 33 
 34 插入模式:
 35 
 36 
 37 可视块模式:
 38         块插入(在指定块前加入字符):  选择块,I   在块前插入字符, ESC
 39         块替换:                                       选择块,r   输入替换的字符
 40         块删除:                                       选择块,d | x
 41         块复制:                                       选择块,y
 42 
 43 扩展命令模式:
 44     a. 保存退出
 45         :10     进入第10行
 46         :w      保存
 47         :q      退出
 48         :wq     保存并退出
 49         :w!     强制保存
 50         :q!     不保存并退出
 51         :wq!    强制保存退出
 52         :x      保存并退出   ZZ
 53 
 54 
 55     b. 查找替换
 56         :范围 s/old/new/选项
 57         :1,5 s/root/yang/                     从1-5行的root 替换为yang
 58         :5,$ s/root/yang/                     $表示最后一行
 59         :1,$ s/root/yang/g                    =     :% s/root/yang/g    %表示全文  g表示全局
 60         :% s#/dev/sda#/var/ccc#g
 61         :,8 s/root/yang/                      从当前行到第8行
 62         :4,9 s/^#//                           4-9行的开头#替换为空
 63         :5,10 s/.*/#&/                        5-10前加入#字符  (.*整行   &引用查找的内容)
 64 
 65     c. 读入文件/写文件(另存为)
 66         :w                                    存储到当前文件
 67         :w /tmp/aaa.txt                       另存为/tmp/aaa.txt
 68         :1,3 w /tmp/2.txt
 69         :r /etc/hosts                         读入文件到当前行后
 70         :5 r /etc/hosts                       读入文件到第5行后
 71 
 72     d. 设置环境
 73         临时设置:
 74         :set nu                                设置行号
 75         :set ic                                不区分大小写
 76         :set ai                                自动缩进
 77         :set list                              显示控制字符
 78         :set nonu                              取消设置行号
 79         :set noic
 80 
 81        永久的环境:
 82        /etc/vimrc                             影响所有系统用户
 83        ~/.vimrc                               影响某一个用户
 84 
 85         # vim ~/.vimrc
 86         set ic
 87         set nu



归类: Linux 学习

posted @ 2020-09-14 20:06  Py猫的故事  阅读(189)  评论(0编辑  收藏  举报
返回顶部