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

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

相关推荐
毒爪的小新20 小时前
Linux 环境极速部署 vLLM:从零搭建生产级大模型推理服务
linux·人工智能·ai·语言模型·vllm
鹤落晴春20 小时前
RH124问答3:从命令行管理文件
linux·运维·服务器
凡人叶枫20 小时前
Effective C++ 条款30:透彻了解 inlining 的里里外外
linux·开发语言·c++·嵌入式开发·effective c++
guslegend20 小时前
大模型驱动大数据SRE智能运维
大数据·运维
遇见火星20 小时前
Docker Compose 完全入门:一键启动所有容器
运维·docker·容器·docker compose
火山上的企鹅21 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)
服务器·网络·数据库·oracle·qgc
Net_Walke21 小时前
【Linux系统】静态链接库与动态链接库
linux·嵌入式硬件
小啊曼21 小时前
CIO实战方法论_11_组织变革打破部门墙
运维
syc789012321 小时前
中文语境下AI编码工具实战对比:从迭代体验看日常开发选择
linux·人工智能·ubuntu
❀搜不到21 小时前
远程服务器codex使用本地cc-switch的deepseek api
运维·服务器