28.linux文件权限讨论

一:普通权限

1.umask查看缺省权限,一般默认为0022

根据缺省权限来配置件的权限,777-022=755。

1.1所以,创建目录的默认权限是755,rwxr_xr_x;

ls -ld aaa  //查看当前目录aaa的信息

ls -i   //查看节点号iNode

1.2创建文件的默认权限是644,rw_r__r__;(为安全考虑,默认文件不具有可执行权限)

1.3如何来理解这几种读写权限呢?r意味着对文件具有读权限,w意味着对文件具有写权限,x意味着对文件具有执行权限。所以对文件和目录分别来说,具体可执行的命令如下:

对文件来说,

r: cat  /more  /head  /tail  /less

w: vim

x: script  command

对目录来说,

r: ls

w: touch  /mkdir  /rmdir  /rm

x: cd

2.关于权限几个小问题

问:某用户建立的文件,另一个用户可不可以对其进行删除呢?

答:可以的,删除一个文件的前提是,对这个文件所在的目录具有写权限,如果一个目录的权限是777,那么任何用户都对当前目录下的文件进行删除操作。


问:某用户创建一个文件后,想将其所有者改为root,可不可以?

答:不可以,只有root可以改变文件的所有者,文件的创建者都不可以。

如下例,dazhutizi建立的abcd文件,只有root才可以将所有者改为root

切换到root下,将刚刚普通用户创建的文件abcd的所有者改为root。


删除一个非空目录时,虽然被终止了删除操作,但是终止之前的操作已经完成了,所以如下图我们可以看到文件a3和目录a4已经被删除了。



二:特殊权限:ACL权限

用处:身份不够用时(身份包括,所有者所属组合其他人三种),需用ACL权限

1.查看acl权限是否开启

2.可以看到本系统是默认开启的,如果没有开启,有两种方式来开启ACL权限

2.1.mount -o remount,acl //用mount命令将根分区重新挂载,挂载的时候开启ACL权限,这种方法是临时生效的

2.2.vi /etc/fstab  //在根分区的挂载行,defaults后面加,acl

mount -o remount  //重新挂载文件系统或重启,使修改生效。


3.设置acl权限

实验:

3.1新建两个普通用户,一个组,然后将这两个用户加入到新组里

3.2创建本次测试的目录,观察其初始权限为755,将其权限改为770,此时作为当前目录的所有者root对目录具有7的权限,所属组root有7的权限,其他人没有任何权限

3.3修改/tmp/project的所有者和所属组,使得刚刚新建的用户user1和user2(在组aclgroup里)能够拥有7的权限,此时其他人仍没有权限

3.4新建一个其他人用户,因为他对这个/tmp/project目录没有任何权限。但其需要对目录进行读和执行的访问,所以为他设定acl权限。

3.5查看/tmp/project目录的权限,可以看到所有者root具有7,普通用户dazhutizi有5,所属组aclgroup有7的权限,其他人没有权限。

4.删除acl权限

setfacl -b +目录 //删除当前目录的所有acl权限

setfacl -x +目录 //删除当前目录的指定用户acl权限

setfacl -g +目录 //删除当前目录的指定组acl权限

5.递归与默认ACL权限

setfacl -m u:user:rx -R /tmp/project  //递归,对子文件和子目录也生效

setfacl -m d:u:user:rx /tmp/project  //设置默认参数,目录内的子文件继承父文件的acl权限

6.mask:最大有效权限,一般设为rwx

上图中出现了mask权限,mask为最大有效权限,它限制其他用户的权限

acl与所属组对当前文件设定的权限,与mask相与之后,才是真正的权限。



三:特殊权限:SetUID,SetGID...

SetUID设置chmod 4755 xx,4表示SetUID

只针对可执行文件,

执行者需要有x的权限

比如passwd命令,passwd命令修改密码时,会修改/etc/shadow文件,可以看到shadow文件的权限是000,只有root能对其进行读写执行操作,

但是有passwd权限下suid,所以passwd命令在普通用户下执行时,普通用户相当于暂时变成超级用户,故能修改/etc/shadow文件。

但cat命令是不具有suid的,所以它在普通用户下都不能查看/etc/shadow。

给它加一个suid,那么普通用户在使用cat命令时会变身超级用户,此时可以查看/etc/shadow文件了。

结束后删除suid权限

定期查看系统中有哪些SUID和SGID文件:

find / -type f \( -perm -4000 -o -perm -2000 \) -ls


四、特殊权限:文件系统属性权限Chattr,用+-=来设置

-i  ——文件,只能查看文件,不能删除修改重命名

        ——目录,不能在目录下建立和删除文件,但可以修改目录中的文件

-a ——文件,可以用echo追加文件内容,不能删除和修改文件内容

    ——目录,可以在目录中建立和修改文件,不允许删除

查看文件的chattr权限,用lsattr命令


五、特殊权限:sudo+操作命令

visudo  //通过配置/etc/sudoers文件,来实现sudo命令

sudo+操作命令

特殊用法:可以授权普通用户有重启服务器的权限,visudo命令在文件内写入

user1  ALL=/sbin/shutdown -r now

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容