第六章:Linux文件重要核心属性知识

1、用户

  • Linux是个多用户、多任务的操作系统

    • 多个用户:多个用户同时登入
    • 多任务:每个用户可以执行多个任务
  • 用户:
    • 管理Linux系统而存在的
    • 用户一般分为用户名和用户ID(UID)
    • 用户名方便管理员使用,用户ID是唯一区别一个用户(计算机只识别ID)
  • 文件和进程对应用户关系
    • linux里所有的用户和进程都要有用户对应。
    • 文件存在必须对应用户
    • 进程运行必须对应用户
  • Linux用户分类
    • 超级管理员:root

      • UID为0
      • 如果用户对应的用户ID(UID)都有root的对应权限
      [[email protected] ~]# id root   #查看用户ID
        d=0(root) gid=0(root) groups=0(root)
      [[email protected] ~]# id
      uid=0(root) gid=0(root) groups=0(root) context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023
      [[email protected] ~]# su - oldboy		#切换用户
      [[email protected] ~]$ logout
      [[email protected] ~]# vim /etc/passwd    #修改用户ID
      root:x:0:0:root:/root:/bin/bash
      bin:x:1:1:bin:/bin:/sbin/nologin
      daemon:x:2:2:daemon:/sbin:/sbin/nologin
      adm:x:3:4:adm:/var/adm:/sbin/nologin
      lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
      sync:x:5:0:sync:/sbin:/bin/sync
      shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
      halt:x:7:0:halt:/sbin:/sbin/halt
      mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
      operator:x:11:0:operator:/root:/sbin/nologin
      games:x:12:100:games:/usr/games:/sbin/nologin
      ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
      nobody:x:99:99:Nobody:/:/sbin/nologin
      systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
      dbus:x:81:81:System message bus:/:/sbin/nologin
      polkitd:x:999:998:User for polkitd:/:/sbin/nologin
      tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sb
      in/nologin
      abrt:x:173:173::/etc/abrt:/sbin/nologin
      sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
      postfix:x:89:89::/var/spool/postfix:/sbin/nologin
      oldboy:x:0:1000:oldboy:/home/oldboy:/bin/bash
      tcpdump:x:72:72::/:/sbin/nologin
      "/etc/passwd" 22L, 1017C written
      [[email protected] ~]# su - oldboy
      Last login: Fri Apr 10 18:52:44 CST 2020 from 10.0.0.1 on pts/0
      [[email protected] ~]# cd /root/
      [[email protected] /root]# cd ..
      [[email protected] /]# ^C
      [[email protected] /]# logout
      [[email protected] ~]# id
      uid=0(root) gid=0(root) groups=0(root) context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023
      [[email protected] ~]# su - oldboy
      Last login: Fri Apr 10 18:53:33 CST 2020 on pts/0
      [[email protected] ~]# id
      uid=0(root) gid=1000(oldboy) groups=1000(oldboy) context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023
      [[email protected] ~]# whoami 	#查询当前用户
      root
      
      
      • 注意:不要修改除了root用户外的用户的UID的值为0,这样容易权限过大出现操作失误
  • 虚拟用户
    • 实际存在的用户,但是又不允许它登入
    • 价值何在?
      • 满足文件或进程运行属主的要求。但是又不会带来管理风险
    • UID:1-499
  • 普通用户
    • 实际存在的用户,又允许他登入,管理员身份创建的,帮助管理员管理系统的。
    • UID:1000~60000
      [[email protected] ~]# useradd oldgirl		#创建普通用户
      [[email protected] ~]# id oldgirl
      uid=1001(oldgirl) gid=1001(oldgirl) groups=1001(oldgirl)
      
      

1.1、root密码丢失了如何找回来?

  • 重启系统,在开机过程中,快速按下键盘上的方向键和。目的是告知引导程序,我们需要在引导页面选择不同的操作,以便让引导程序暂停。
  • 按键盘 e 键,进入编辑模式,找到 linux16 的那一行。将光标一直移动到 LANG=en_US.UTF-8 后面,空格,再追加 init=/bin/sh。这里特别注意,需要写在UTF-8后,保持再同一行,并注意空格。由于屏幕太小,会自动添加\换行,这个是正常的。

  • 挂载根目录

  • 选择要修改密码的用户名,这里选择root用户进行修改,可以更换为你要修改的用户

  • 输入2次一样的新密码,注意输入密码的时候屏幕上不会有字符出现。

    • 如果输入的密码太简单,会提示警告BAD PASSWORD:The password fails the dictionary check - it is too simplistic/systematic),可以无视它,继续输入密码,不过建议还是设置比较复杂一些的密码,以保证安全性
  • 更新系统信息 touch /.authorelabel
  • 最后输入以下命令重启系统即可

2、用户组

  • 相当于集合、组织(比如人的家庭)
  • Linux里每个用户必须要有一个组织,这个组织就是叫做用户组
    • 用户组也是给人看,用户组也有唯一标识,group ID 简称GID
    • 默认情况创建用户,并没有创建用户组,他会自动创建一个用户组,和用户名相同的用户组,以及相同的GID
      [[email protected] ~]# id oldgirl
      uid=1001(oldgirl) gid=1001(oldgirl) groups=1001(oldgirl)
      

2.1用户和用户组的对应关系

  • 一个用户(user)对应一个用户组(user group)
  • 一个用户(user)对应多个用户组(user groups)
  • 多个用户(users)对应一个用户组(user group)
    [[email protected] ~]# useradd oldgirl
    [[email protected] ~]# id oldgirl
    uid=1001(oldgirl) gid=1001(oldgirl) groups=1001(oldgirl)
    [[email protected] ~]# useradd -g root text	#创建用户指定用户组
    [[email protected] ~]# id text
    uid=1002(text) gid=0(root) groups=0(root)
    [[email protected] ~]# groupadd sa		#创建用户组
    [[email protected] ~]# useradd -g sa uu
    [[email protected] ~]# id uu
    uid=1003(uu) gid=1002(sa) groups=1002(sa)
    [[email protected] ~]# id oldboy
    uid=1000(oldboy) gid=1000(oldboy) groups=1000(oldboy)
    [[email protected] ~]# id root
    uid=0(root) gid=0(root) groups=0(root)
    
    

3、文件权限

  • Linux系统对文件安全权限要求严格

    [[email protected] /]# ls -lih /etc/sysconfig/
    total 108K
    33575490 -rw-r--r--. 1 root root  412 Apr  4 18:09 anaconda
    34063111 -rw-r--r--. 1 root root  483 Apr  4 18:08 authconfig
    16841044 drwxr-xr-x. 2 root root   43 Apr  4 18:22 cbq
    16881480 drwxr-xr-x. 2 root root    6 Aug  9  2019 console
    33743063 -rw-r--r--. 1 root root  150 Mar 18 07:59 cpupower
    34061028 -rw-------. 1 root root  110 Aug  9  2019 crond
    34061967 -rw-------. 1 root root 1.4K Apr 11  2018 ebtables-config
    1			2       3  4    5     6    7  8    9   10
    
  • rwxr-xr-x:文件权限
    • 9个字符,每三个字符为一组

      • 前三个字符代表主用户的权限
      • 中间三个字符代表用户组的权限
      • 后面三个字符代表其他用户的权限
    • r
      • 读取的权限
      • 用数字4表示
    • w
      • 可写的权限
      • 用数字2表示
    • x
      • 可执行的权限
      • 用数字1表示
      • 没有权限
  • 789列:文件的最后修改时间
    • 文件时间有三种

      • 修改时间:modify 文件内容被改过
      • 访问时间:access 文件内容被访问过的时间
      • 变化时间:change 文件属性发生改变的时间
    • stat查看文件的所有时间
      [[email protected] ~]# stat /etc/hosts
        File: ‘/etc/hosts’
        Size: 158       	Blocks: 8          IO Block: 4096   regular file
      Device: 803h/2051d	Inode: 16777794    Links: 1
      Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
      Context: system_u:object_r:net_conf_t:s0
      Access: 2020-04-10 19:27:37.963000075 +0800
      Modify: 2013-06-07 22:31:32.000000000 +0800
      Change: 2020-04-04 18:05:04.725808731 +0800
       Birth: -
      
      • -c 获取权限一部分

        • %A 显示字符权限

          [[email protected] ~]# stat -c %A /etc/hosts
          -rw-r--r--
          
#练习一、修改访问时间和变化时间
[[email protected] ~]# echo oldboy > test.txt
[[email protected] ~]# stat test.txt
  File: ‘test.txt’
  Size: 7         	Blocks: 8          IO Block: 4096   regular file
Device: 803h/2051d	Inode: 34060899    Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2020-04-10 20:26:41.347028313 +0800
Modify: 2020-04-10 20:26:41.347028313 +0800
Change: 2020-04-10 20:26:41.347028313 +0800
 Birth: -
[[email protected] ~]# echo oldboy >> test.txt
[[email protected] ~]# stat test.txt
  File: ‘test.txt’
  Size: 14        	Blocks: 8          IO Block: 4096   regular file
Device: 803h/2051d	Inode: 34060899    Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2020-04-10 20:26:41.347028313 +0800
Modify: 2020-04-10 20:26:59.226028455 +0800
Change: 2020-04-10 20:26:59.226028455 +0800
 Birth: -

#练习二、修改变化时间
[[email protected] ~]# stat test.txt
  File: ‘test.txt’
  Size: 14        	Blocks: 8          IO Block: 4096   regular file
Device: 803h/2051d	Inode: 34060899    Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2020-04-10 20:26:41.347028313 +0800
Modify: 2020-04-10 20:26:59.226028455 +0800
Change: 2020-04-10 20:26:59.226028455 +0800
 Birth: -
[[email protected] ~]# chmod +x test.txt
[[email protected] ~]# stat test.txt
  File: ‘test.txt’
  Size: 14        	Blocks: 8          IO Block: 4096   regular file
Device: 803h/2051d	Inode: 34060899    Links: 1
Access: (0755/-rwxr-xr-x)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2020-04-10 20:26:41.347028313 +0800
Modify: 2020-04-10 20:26:59.226028455 +0800
Change: 2020-04-10 20:29:18.668029566 +0800

  • 第一列

    • 文件节点

      • 表现形式是数字 33574978叫做文件的索引节点(index node)
      • 类似身份证,索引节点是文件在系统中的唯一标识
      • 找一个文件最终都要通过索引节点才能找到
      • 索引节点的概念出在ext文件系统中(ext2、ext3、ext4)
    • 索引节点
      • 索引节点是硬盘的一块存储空间,大小256字节或512字节
      • 索引节点里存放是数据是文件的属性
      • 在索引节点里,唯独不包含文件名(文件名在上级目录的block里)
    • inode和block
      • 格式化创建文件系统时,就会生成大量的inode和block
      • inode作用存储文件的属性信息,同时存放指向文件实体(block)的指针(类似软连接)
      • block作用是存放文件内容的(大片)
      • Block叫做磁盘块,是用来存放实际数据的实体单元(ext文件系统一般最大为4KB),即用来真正存放数据,例如:照片、视频等普通文件数据,单个大的文件需要占用多个Block块来存储,特别小的单个文件如果不能占满整个Block块,剩余的空间也无法在利用。
    • 查看inode
      [[email protected] /]# df -i
      Filesystem      Inodes IUsed   IFree IUse% Mounted on
      devtmpfs        480007   370  479637    1% /dev
      tmpfs           482665     1  482664    1% /dev/shm
      tmpfs           482665  1227  481438    1% /run
      tmpfs           482665    16  482649    1% /sys/fs/cgroup
      /dev/sda3      9960960 72530 9888430    1% /
      /dev/sda1       131072   334  130738    1% /boot
      tmpfs           482665     1  482664    1% /run/user/0
      
      
    • 查看block
      [[email protected] /]# df -h
      Filesystem      Size  Used Avail Use% Mounted on
      devtmpfs        1.9G     0  1.9G   0% /dev
      tmpfs           1.9G     0  1.9G   0% /dev/shm
      tmpfs           1.9G   12M  1.9G   1% /run
      tmpfs           1.9G     0  1.9G   0% /sys/fs/cgroup
      /dev/sda3        19G  2.0G   18G  11% /
      /dev/sda1       253M  161M   93M  64% /boot
      tmpfs           378M     0  378M   0% /run/user/0
      
    • 磁盘满的两种情况
      • inode满(文件索引节点被占满)
      • block满(存储空间占满)
    • 提示:
      • no space left no device报错,没有空间在设备上了(磁盘满了。)
      • 检查步骤
        • df -h
        • df -i 看看是不是inode满了
      #模拟磁盘被占满情况
      [[email protected] ~]# mkdir -p /app/logs
      [[email protected] ~]# dd if=/dev/zero of=/dev/sdc bs=8K count=10
      10+0 records in
      10+0 records out
      81920 bytes (82 kB) copied, 0.000135709 s, 604 MB/s
      [[email protected] ~]# mkfs.ext4 /dev/sdc
      mke2fs 1.42.9 (28-Dec-2013)
      /dev/sdc is not a block special device.
      Proceed anyway? (y,n) y
      
      Filesystem too small for a journal
      Discarding device blocks: done
      Filesystem label=
      OS type: Linux
      Block size=1024 (log=0)
      Fragment size=1024 (log=0)
      Stride=0 blocks, Stripe width=0 blocks
      16 inodes, 80 blocks
      4 blocks (5.00%) reserved for the super user
      First data block=1
      1 block group
      8192 blocks per group, 8192 fragments per group
      16 inodes per group
      
      Allocating group tables: done
      Writing inode tables: done
      Writing superblocks and filesystem accounting information: done
      
      [[email protected] ~]# mount -o loop /dev/sdc /app/logs/
      [[email protected] ~]# df -h
      Filesystem      Size  Used Avail Use% Mounted on
      devtmpfs        1.9G   52K  1.9G   1% /dev
      tmpfs           1.9G     0  1.9G   0% /dev/shm
      tmpfs           1.9G   12M  1.9G   1% /run
      tmpfs           1.9G     0  1.9G   0% /sys/fs/cgroup
      /dev/sda3        19G  2.0G   18G  11% /
      /dev/sda1       253M  161M   93M  64% /boot
      tmpfs           378M     0  378M   0% /run/user/0
      /dev/loop0       73K   14K   54K  21% /app/logs
      [[email protected] ~]# cd /app/logs/
      [[email protected] /app/logs]# touch {1..15}.txt
      touch: cannot touch ‘6.txt’: No space left on device
      touch: cannot touch ‘7.txt’: No space left on device
      touch: cannot touch ‘8.txt’: No space left on device
      touch: cannot touch ‘9.txt’: No space left on device
      touch: cannot touch ‘10.txt’: No space left on device
      touch: cannot touch ‘11.txt’: No space left on device
      touch: cannot touch ‘12.txt’: No space left on device
      touch: cannot touch ‘13.txt’: No space left on device
      touch: cannot touch ‘14.txt’: No space left on device
      touch: cannot touch ‘15.txt’: No space left on device
      [[email protected] /app/logs]# df -h
      Filesystem      Size  Used Avail Use% Mounted on
      devtmpfs        1.9G   52K  1.9G   1% /dev
      tmpfs           1.9G     0  1.9G   0% /dev/shm
      tmpfs           1.9G   12M  1.9G   1% /run
      tmpfs           1.9G     0  1.9G   0% /sys/fs/cgroup
      /dev/sda3        19G  2.0G   18G  11% /
      /dev/sda1       253M  161M   93M  64% /boot
      tmpfs           378M     0  378M   0% /run/user/0
      /dev/loop0       73K   15K   53K  23% /app/logs
      [[email protected] /app/logs]# df -i
      Filesystem      Inodes IUsed   IFree IUse% Mounted on
      devtmpfs        480007   375  479632    1% /dev
      tmpfs           482665     1  482664    1% /dev/shm
      tmpfs           482665  1233  481432    1% /run
      tmpfs           482665    16  482649    1% /sys/fs/cgroup
      /dev/sda3      9960960 72669 9888291    1% /
      /dev/sda1       131072   334  130738    1% /boot
      tmpfs           482665     1  482664    1% /run/user/0
      /dev/loop0          16    16       0  100% /app/logs
      
      • 为什么inode会满?

        • 小文件太多
        • 初始化时候 block数量远大于inode数量
    • 模拟磁盘空间被占满
      [[email protected] /app/logs]# rm -rf *
      [[email protected] /app/logs]# ll
      [[email protected] /app/logs]# cp /bin/cat ddd
      [[email protected] /app/logs]# cp /bin/cat ddddd
      cp: error writing ‘ddddd’: No space left on device
      cp: failed to extend ‘ddddd’: No space left on device
      [[email protected] /app/logs]# df -h
      Filesystem      Size  Used Avail Use% Mounted on
      devtmpfs        1.9G   80K  1.9G   1% /dev
      tmpfs           1.9G     0  1.9G   0% /dev/shm
      tmpfs           1.9G   12M  1.9G   1% /run
      tmpfs           1.9G     0  1.9G   0% /sys/fs/cgroup
      /dev/sda3        19G  2.0G   18G  11% /
      /dev/sda1       253M  161M   93M  64% /boot
      tmpfs           378M     0  378M   0% /run/user/0
      /dev/loop0       73K   72K     0 100% /app/logs
      
      
  • 第三列
    • 文件硬连接数

      • 普通文件硬连接数为1
      • 目录硬连接数为2
        • 是因为还有本身目录(.)

          [[email protected] /]# ls -lihd /data/ /data/.
          34060900 drwxr-xr-x. 2 root root 137 Apr 10 20:36 /data/
          34060900 drwxr-xr-x. 2 root root 137 Apr 10 20:36 /data/.
          
          

原文地址:https://www.cnblogs.com/sunyuhang1/p/12676100.html

时间: 2024-10-31 01:33:27

第六章:Linux文件重要核心属性知识的相关文章

第六章 Linux的文件权限与目录配置

第六章 Linux的文件权限与目录配置 6.1Linux用户身份与用户组记录的文件 每个账号都可以有多个用户组支持 /etc/passwd              用户账号 /etc/shadow             账号密码 /etc/group                 组账号 6.2权限 文件的RWX权限只涉及对文件内容的约束 文件夹的RWX权限只涉及对文件夹下的文件的约束 ls原理:根据身份对文件夹访问时,若该身份对该文件夹为r--,则结果只返回文件名列表:若为r-x,返回文

鸟哥的Linux私房菜_基础版_学习笔记2:第六章 linux的文件权限与目录配置

第六章 linux的文件权限与目录配置 6.1.用户与用户组 1.文件拥有者 2.群组概念 3.其他人的概念 在Linux里面,任何一个文件都有"User,Group和Others"3种身份的个别权限. 我们以王三毛为例,王三毛这个『文件』的拥有者为王三毛,他属于王大毛这个群组, 而张小猪相对于王三毛,则只是一个『其他人(others)』而已. 不过,这里有个特殊的人物要来介绍的,那就是『万能的天神』!这个天神具有无限的神力, 所以他可以到达任何他想要去的地方,呵呵!那个人在Linux

鸟哥的Linux私房菜_基础版_学习笔记3:第七章 Linux文件与目录管理

第七章 Linux文件与目录管理 7.1目录与路径: 7.1.1相对路径与绝对路径: 绝对路径:路径的写法『一定由根目录 / 写起』,例如: /usr/share/doc 这个目录. 相对路径:路径的写法『不是由 / 写起』,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成:『cd ../man』这就是相对路径的写法啦!相对路径意指『相对於目前工作目录的路径!』 7.1.2目录的相关操作: . 代表此层目录 .. 代表上一层目录 - 代表前一个工作目录

第5章 LINUX文件及目录管理命令基础

第5章 LINUX文件及目录管理命令基础5.1 操作LINUX必知必会基础知识5.1.1 Linux命令行组成结构root @ oldboy ~ # :当前用户名 分隔符 主机名 当前用户登陆后的位置,这是个变量 提示符 5.1.2 基本的Linux命令操作语法示例5.1.3 Linux与Windows的目录结构对比5.2 Linux文件及目录核心命令5.2.1 pwd:显示当前所在位置信息"print working directory"-L:逻辑路径:-P:物理路径系统Bash命令

Gradle 1.12 翻译——第十六章. 使用文件

有关其他已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或访问:http://gradledoc.qiniudn.com/1.12/userguide/userguide.html 本文原创,转载请注明出处:http://blog.csdn.net/maosidiaoxian/article/details/41113353 关于我对Gradle的翻译,以Github上的项目及http://gradledoc.qin

第十六章 在文件中搜索文本工具:grep命令 和egrep命令

第十六章 在文件中搜索文本工具:grep命令 和egrep命令 名词解释 grep(global search regular expression(RE)and print out the line,全面搜索正则表达式并把行打印出来) grep是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来. 选项 - -a :不要忽略二进制数据 - -A <显示行数>:除了显示符合范本样式的那一行之外,并显示该行之后的内容. - -b :在显示符合范本样式的那一行之外,并显示该行

第二十二章 Linux文件比较,文本文件的交集、差集与求差:comm命令

第二十二章 Linux文件比较,文本文件的交集.差集与求差:comm命令 名词解释 comm 命令 可以用于两个文件之间的比较,它有一些选项可以用来调整输出,以便执行交集.求差.差集操作. 交集:打印两个文件所共有的行 求差:打印出指定文件所包含的其不相同的行. 差集:打印出包含在一个文件中,但不包含在其他指定文件中的行. 语法 comm(选项)(参数) 选项 -1 :不显示在第一个文件出现的内容: -2 :不显示在第二个文件中出现的内容: -3 :不显示同时在两个文件中都出现的内容. ? 参数

Linux文件的特殊属性

Linux文件的特殊属性chattr对于一些特殊的文件,为防止用户误操作,可以加特殊属性,示例如下:+i:锁定示例文件:[[email protected] data]#ll test.txt-rw-r--r--. 1 root root 48 Mar 12 19:30 test.txt +i锁定文件 [[email protected] data]#chattr +i test.txt 查看文件属性,发现与之前一样 [[email protected] data]#ll test.txt -r

【RL-TCPnet网络教程】第35章 FTP文件传输协议基础知识

第35章      FTP文件传输协议基础知识 本章节为大家讲解FTP(File Transfer Protocol,文件传输协议)的基础知识,方便后面章节的实战操作. (本章的知识点主要整理自网络) 35.1  初学者重要提示 35.2  FTP基础知识参考资料 35.3  FTP基础知识点 35.4  总结 35.1  初学者重要提示 FTP文件传输协议在实际项目中有比较重要的实用价值,需要初学者对FTP的基础知识也有个认识. 35.2  FTP基础知识参考资料 大家可以从以下地址获得FTP