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

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

相关推荐
2401_892070981 天前
【Linux C++ 日志系统实战】LogFile 日志文件管理核心:滚动策略、线程安全与方法全解析
linux·c++·日志系统·日志滚动
雪可问春风1 天前
docker环境部署
运维·docker·容器
lwx9148521 天前
Linux-Shell算术运算
linux·运维·服务器
翻斗包菜1 天前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
somi71 天前
ARM-驱动-02-Linux 内核开发环境搭建与编译
linux·运维·arm开发
双份浓缩馥芮白1 天前
【Docker】Linux 迁移 docker 目录(软链接)
linux·docker
海的透彻1 天前
nginx启动进程对文件的权限掌控
运维·chrome·nginx
黄昏晓x1 天前
Linux ---- UDP和TCP
linux·tcp/ip·udp
路溪非溪1 天前
Linux驱动开发中的常用接口总结(一)
linux·运维·驱动开发
此刻觐神1 天前
IMX6ULL开发板学习-01(Linux文件目录和目录相关命令)
linux·服务器·学习