本文将介绍Linux中的文件权限管理相关内容
data:image/s3,"s3://crabby-images/38ffe/38ffe43b8254e9e853daae027641adbe70bb9144" alt="abstract.png"
用户管理
创建用户
在使用root用户创建完用户后,可通过paswwd命令设置新用户的密码。值得一提的是,非root用户执行passwd命令时不可指定用户名,即只能修改当前用户的密码
data:image/s3,"s3://crabby-images/306a8/306a81d15378a512ce7a11f397fce8c2edaaa888" alt="figure 1.png"
删除用户
data:image/s3,"s3://crabby-images/2aefd/2aefd164306961eed602e045ae4ddc08e989140e" alt="figure 2.png"
通过添加-r选项,则会同时删除相应的HOME用户目录
data:image/s3,"s3://crabby-images/d50c9/d50c9840d7483b11c00b72aa359e7a8c123c579b" alt="figure 3.png"
用户组管理
创建组
data:image/s3,"s3://crabby-images/bd570/bd570e5198316622fea6534f050162fdbd0bdcb6" alt="figure 4.png"
修改组名
1 2
| groupmod -n <新组名> <旧组名>
|
data:image/s3,"s3://crabby-images/362c8/362c82dc933a602f29c9d72dd940958add81d858" alt="figure 5.png"
删除组
data:image/s3,"s3://crabby-images/fa37a/fa37a855c04cc70cf044f12ae862fee745484313" alt="figure 6.png"
修改用户所属组
Linux当中,一个用户有且只有一个主要组,但可以有若干个(含0个)次要组
1. 修改用户的主要组
1 2 3 4 5
| usermod -g <组名> <用户名>
id <用户名>
|
data:image/s3,"s3://crabby-images/81511/8151131e41191ff9086038405cec9a709638f99a" alt="figure 7.png"
2. 修改用户的次要组
1 2
| usermod -G <组名1>[,<组名2>,<组名3>,...] <用户名>
|
data:image/s3,"s3://crabby-images/e8350/e8350156ffe3a8275dfc8490eaee8955b17b7ad1" alt="figure 8.png"
3. 追加组到用户的次要组当中
1 2
| usermod -a -G <组名1>[,<组名2>,<组名3>,...] <用户名>
|
data:image/s3,"s3://crabby-images/12d3e/12d3e79b058ea22278112e7251e916dee6c73187" alt="figure 9.png"
4. 从用户的次要组中删除指定组
data:image/s3,"s3://crabby-images/2e7b8/2e7b84b93774e3e19802e6e03e44155b882e01e4" alt="figure 10.png"
文件所有权、权限
修改文件所有者、所属组
chown命令可以修改文件的文件所有者、所属组。但普通用户无权执行该命令,只有root账户才可以。在chown命令中,所有者与所属组之间可以使用 点(.)或 冒号(:) 两种方式进行连接。但会产生一个问题,如果用户的账号中包含数点(例如 aaron.com)会造成系统误判。故推荐使用冒号(:)连接所有者和所属组
1 2 3 4 5 6 7 8 9 10 11 12 13
| chown [用户名] readme.txt
chown .[组名] readme.txt
chown :[组名] readme.txt
chown [用户名].[组名] readme.txt
chown [用户名]:[组名] readme.txt
|
data:image/s3,"s3://crabby-images/08adc/08adc478345184b6f600705916aa729596283926" alt="figure 11.png"
使用-R选项可递归修改文件、目录的所有者、所属组
data:image/s3,"s3://crabby-images/ba0cb/ba0cb94c371ac5e5c0608373e0794e013c17718a" alt="figure 12.png"
修改文件所属组
与chown命令不同,chgrp命令允许普通用户修改文件所属组。但该用户必须同时是原属组和新属组的成员。使用 -R选项 即可对指定目录下的所有文件及子目录进行递归处理
1 2 3 4 5 6 7 8
| chgrp [组名] [文件名]
chgrp G4 a.txt
chgrp -R G2 work
|
data:image/s3,"s3://crabby-images/5fc55/5fc5570b49f47025b0f5ec92e3093ef389e3ae14" alt="figure 13.png"
修改文件权限
可通过chmod命令修改文件权限,命令形式如下
1
| chmod [option] <mode> <file>
|
mode参数支持直接使用3位八进制数字来设置文件权限
data:image/s3,"s3://crabby-images/4e179/4e1794f7e1c30d7d034cef59f6c75cfc0248bd3c" alt="figure 14.png"
使用-R选项可递归修改文件、目录权限
data:image/s3,"s3://crabby-images/1b139/1b1393fbd1d788bd365614cb9cfb0b3f1fbcdf55" alt="figure 15.png"
此外,mod参数还支持使用符号模式
其中:
- u、g、o、a :分别代表文件所有者user、文件的所属组group、其它用户other、所有用户all(相当于ugo的并集)
- +、-、= :分别表示对指定的用户在现有权限的基础上增加权限(+)、移除权限(-)、设置权限(=)
- r、w、x :分别表示读权限、写权限、执行权限
data:image/s3,"s3://crabby-images/c6cb9/c6cb97617d9baad038f90bb8c79fbc7e4ed425c3" alt="figure 16.png"
data:image/s3,"s3://crabby-images/83e78/83e785e67c9bb0baaa7563797785760e775669d8" alt="figure 17.png"
参考文献
- Linux命令行与shell脚本编程大全·第4版 Richard Blum、Christine Bresnahan著