Linux_文件权限

修改文件的权限一般修改不同身份的对文件使用权限和修改权限

对于前面的一串字符分为4部分,文件类型,创建者权限(三个字符),同组者权限(三个字符),其他人权限(三个字符)。

对于文件类型:

d:文件夹 _:普通文件 l:软链接文件 p:管道文件 ...............

三个权限

r:读权限 w:写权限 x:执行权限

可读权限: 如果目录没有可读权限, 则无法用ls等命令查看目录中的文件内容.

可写权限: 如果目录没有可写权限, 则无法在目录中创建文件, 也无法在目录中删除文件 可执行权限: 如果目录没有可执行权限, 则无法cd到目录中

chmod修改权限

修改文件权限的可以是文件创建者,root超级用户

R -> 递归修改目录文件的权限

+:向权限范围增加权限代号所表示的权限

-:向权限范围取消权限代号所表示的权限

=:向权限范围赋予权限代号所表示的权限

用户符号:

u:拥有者

g:拥有者同组用

o:其它用户

a:所有用户

cpp 复制代码
$ 命令行
$ chmod u+rwx filename   // 使用者添加读写执行权限
$ chmod g-wx  filename   //  组成员删除写和执行权限
$ chmod  g+rw,o-rwx     // 组合使用
$ chmod  -R 777 filename

也可以使用二进制修改权限rwx权限,有就设置为1,没有就设置为0,对于rwxrw-r--的权限可以设置为111 110 100(764),chmod 764 filename。

chown/chgup修改文件user和group

cpp 复制代码
$ chown newuser filename
$ chgrp newgroup filename

umask文件掩码

默认掩码是0022,可以修改掩码。

umask的作用决定文件的最终权限

最终权限=起始权限&(~umask)

cpp 复制代码
起始权限 // 普通文件默认0666  文件夹默认0777(需要进入,就需要执行权限)
umask      root默认0022  普通用户默认0002
最终权限 // 文件创建的最终权限
0666--->0 110 110 110
0002--->0 000 000 010
~0002-->1 111 111 101

0666&(~0002)
     -->0 110 110 100
即:umask为1的位去除

粘滞位

背景:对于root创建了一个文件夹,需要被多个其他用户共同使用

cpp 复制代码
   ------>  file1
   ------>  file2
dir------>  file3
   ------>  file4
   ------>  file5 

每个人都可以修改自己文件的权限,但对于dir这个文件夹,所有用户都必须有读写执行的权限,所以dir-->rwxrwx000 ,对于同组的成员就可以删除其他人的文件(因为有写的权限),就引入了粘滞位,不允许删除其他人的文件。

cpp 复制代码
chmod +t dirname

添加粘滞位后,不允许删除其他人的文件。

相关推荐
zfxwasaboy5 小时前
DRM KMS 子系统(4)Planes/Encoder/Connector
linux·c语言
暮色_年华6 小时前
随想 2:对比 linux内核侵入式链表和 STL 非侵入链表
linux·c++·链表
好学且牛逼的马6 小时前
【工具配置|docker】
运维·docker·容器
dnncool6 小时前
【Linux】操作系统发展
linux
文言一心6 小时前
LINUX离线升级 Python 至 3.11.9 操作手册
linux·运维·python
北邮刘老师7 小时前
A3C Network:智能体互联网的层次化视图
运维·服务器·网络
XRJ040618xrj7 小时前
如何在Linux中根据物理网卡建立虚拟网卡
linux·服务器·网络
空中楼阁,梦幻泡影8 小时前
LoRA 详细解析,使用LoRA 方式对模型进行微调详细操作指南
运维·服务器·人工智能·机器学习·语言模型
码农水水8 小时前
蚂蚁Java面试被问:混沌工程在分布式系统中的应用
java·linux·开发语言·面试·职场和发展·php