Linux 严格意义上说的是一个操作系统,我们称之为 “核心(kernel)“ ,但我们一般用户,不能直接使用 kernel。而是通过 kernel 的“外壳” 程序,也就是所谓的 shell,来与 kernel 沟通。
从技术角度,Shell 的最简单定义:命令行解释器(command Interpreter)主要包含:
将使用者的命令翻译给核心(kernel)处理。
同时,将核心的处理结果翻译给使用者。
注意:shell 是所有外壳程序的统称,bash 是一种具体的 shell。例如:centos 7 外壳程序 :bash
shell是做命令行解释的
对系统有危害性的命令会被阻止从而保护操作系统
其好处为子进程出现任何问题都不会影响父进程shell
例如,要从 root 用户切换到普通用户 user,则使用 su user。要从普通用户 user 切换到 root 用户则使用 suroot(root 可以省略),此时系统会提示输入 root 用户的口令。
权限本质上是决定某件事情,某人能否做。
文件受人的影响和文件受本身自身特点 (事物属性) 的影响 所以文件权限 = 人 + 事物属性
使用命令 ls -l (ll) 显示的多列属性的第一列对应的字符来区分它的文件类型。
不需要列出 other,因为不是拥有者和所属组的就是 other 了
我们举个简单的例子,在一家公司内部,两个项目组,要完成同样的代码任务,他们之间彼此是互相竞争的关系,但是公司给他们提供的服务器只有一个,他们完成的代码要提交上去,这是你写的代码,肯定只是想让你和你的组员组长能看到,不想你的竞争对手组看到,这就产生了所属组的概念。
$ chmod 777 text.c
$ chmod 000 text.c
$ chmod 640 text.c
注意:chmod 可以给拥有者,所属组,其他用户同时修改权限,中间用逗号隔开
如果要修改不是自己的文件的时候需要 sudo 临时权限提升或者直接切成 root 身份
$ sudo chown root test.c// 修改拥有者
$ sudo chown lighthouse test.c// 修改拥有者
$ sudo chown :lighthouse test.c// 修改所属组
$ sudo chown lighthouse:lighthouse test.c// 可以将拥有者、所属组同时修改
$ sudo chown root:root test.c// 可以将拥有者、所属组同时修改
$ sudo chgrp root text.c
$ sudo chgrp lighthouse text.c
但是我们观察到,新建的文件和目录并不是默认的起始权限,这里是什么原因呢?
原因就是创建文件或目录的时候还要受到 umask 的影响。假设默认权限是 mask,则实际创建的出来的文件权限是:umask & ~umask
x
r
w
就是只要用户具有目录的写权限, 用户就可以删除目录中的文件, 而不论这个用户是否有这个文件的写权限.我创建的一个文件, 凭什么被你一个外人可以删掉
我们的需求:other 可以在特定的目录下创建文件并写入,但是不想让任何人删除掉自己的文件
只能对目录设置,一般是限制 other权限的,对设置粘滞位的目录,在该目录下,只能有文件的拥有者和 root 用户可以删除,其他人不能删除
有多个人或者系统会有很多的临时数据,所有的临时文件都放在系统的 /tmp
目录下。所有的权限需要放开,但是只想让文件的拥有者删除自己的文件,这需要设置粘滞位
推荐阅读