Linux权限解析

linux系统中,shell命令及其运行原理是用户与操作系统交互的关键机制。以下是关于shell命令以及其运行原理的详细介绍:

Shell命令及其运行原理

什么是Shell?

linux严格意义上说是一个操作系统内核(kernel),但用户不能直接与内核进行交互。用户通过称为Shell的“外壳”程序与内核沟通。Shell可以理解为命令行解释器(Command Interpreter),它负责将用户的命令翻译给内核处理,并将内核的处理结果翻译给用户。

为什么不能直接使用内核?

内核是操作系统的核心部分,直接管理硬件资源和提供基本服务。如果用户直接操作内核,可能会导致系统崩溃或安全漏洞。Shell作为中间层,提供了安全且用户友好的交互方式。

Shell的功能

Shell的主要功能包括:

  1. 命令解析:将用户输入的命令解析并转换为内核可以理解的指令。
  2. 结果反馈:将内核处理后的结果解析并展示给用户。

windows的GUI(图形用户界面)类似,用户通过点击图形界面进行操作,而在Linux中,用户通过Shell输入命令进行操作。

Linux权限解析

简而言之,Shell是用户与内核交互的媒介,类似于通过编程语言与计算机进行交互。

Linux权限概念

权限分类

  1. 超级用户(root):可以随意操作系统,制定规则但不受规则约束。
  2. 普通用户:必须遵守使用规则,某些命令需要超级用户权限,例如使用yum命令安装软件。普通用户可以申请相应权限。
  3. 每个用户的密码:每个用户都应有独特的密码,避免重复。

用户切换和权限管理

在Linux中,权限管理涉及文件访问者的分类:

  • 拥有者 > 所属组 > 其他用户
  • 普通用户属于“其他用户”类别,而拥有者和所属组是同一阵营。

所属组的作用

在工作中,通常以小组为单位提高效率。小组成员需要对系统进行操作,但不应被视为“其他人”。因此,所属组的权限介于拥有者和其他用户之间,防止其他小组的抄袭,同时允许小组成员访问内容。这种权限分类有利于公司内部的竞争和秩序维护。

文件类型和访问权限

Linux权限解析

在Linux中,文件后缀没有实际意义,但某些操作需要特定后缀。例如,zip和unzip命令只能识别.zip文件。编译后的文件(如a.out)可以随意重命名并执行。

文件权限值的表示方法

  1. 字符表示法

    Linux权限解析

  2. 八进制表示法

    每种角色的权限占3位,可以用0和1表示,最大权限为111,即7。

    Linux权限解析

    选择哪种表示方法取决于用户的习惯和喜好。

文件访问权限的相关设置方法

  1. chmod:用于修改文件权限。

    格式:

    • 字符表示法
    • 三位八进制数字

    Linux权限解析

  2. chown:用于更改文件拥有者。

  3. chgrp:用于更改文件所属组。

文件掩码(umask)

功能

  • 查看或修改文件掩码。
  • 新建文件默认权限为0666,新建目录默认权限为0777。
  • 实际创建的文件和目录权限受到umask的影响,计算公式为:mask & (~umask)。

格式

  • umask 权限值

说明

  • 将现有权限减去权限掩码后,产生建立文件时的默认权限。
  • 超级用户默认掩码值为0022,普通用户默认为0002。

目录权限

如果用户拥有目录的写权限,可以删除目录下的文件。但如果其他人也有写权限,是否意味着他们也可以删除新建的文件?

为了解决这个问题,Linux引入了粘滞位(sticky bit)。

Linux权限解析

验证

[root@localhost ~]# chmod 0777 /home/ [root@localhost ~]# ls /home/ -ld drwxrwxrwx. 3 root root 4096 9月 19 15:58 /home/ [root@localhost ~]# touch /home/root.c [root@localhost ~]# ls -l /home/ 总用量 4 -rw-r--r--. 1 root root 0 9月 19 15:58 abc.c drwxr-xr-x. 27 litao litao 4096 9月 19 15:53 litao -rw-r--r--. 1 root root 0 9月 19 15:59 root.c [root@localhost ~]# su - litao [litao@localhost ~]$ rm /home/root.c #litao可以删除root创建的文件 rm:是否删除有写保护的普通空文件 "/home/root.c"?y [litao@localhost ~]$ exit logout

目录权限总结

通过以上内容,我们了解了Shell命令的运行原理和Linux权限管理的基本概念。

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享