zoukankan      html  css  js  c++  java
  • Linux基本权限学习

    概念

    权限就是用户对资源所能进行的操作 -- 这里涉及到三个重要的概念:用户、资源、操作。

    首先,Linux中用户分为:u、g、o,就是用户、用户组、其他用户。--这里的用户是指拥有者!!!务必记住!

    其次,Linux中一切皆文件,所以Linux中的资源就是文件。(姑且这么说吧)

    最后,Linux中文件的权限分三种:r、w、x,就是读、写、执行。

    另外,二进制权限,r、w、x分别对应4、2、1,所以权限可以使用数字表示或者赋予。例如,读权限对应4;读写权限对应6;读执行权限对应5;读写执行权限对应7。

    Linux中文件默认权限为666,即可读写,但不能执行,但还有一个umask值,所以实际的默认权限是由二者结合而成。

    部分资料认为是666-umask,这不对,因为umask可能含有666没有含有的值。举个例子,666-0033=633,这不对,因为默认不能含有x权限!如果非要相减,需要将umask-0011才可以,就是去掉可执行权限。

    最直接的计算方法是,将666和umask转成rwx形式,然后相减即可。

    Linux中目录默认权限为777,可读写可执行,同样需要结合umask才能得出实际的默认权限!!!

    umask 可以临时修改值,永久更改需要在环境变量中设置:/etc/profile

    查看

    通过 ls -l 命令就可以查看某个文件的权限信息:

    [root@localhost ~]# ls -l
    总用量 60
    -rw-------.  1 root root  1289 12月  7 21:15 anaconda-ks.cfg
    -rw-r--r--.  1 root root 28250 12月  7 21:15 install.log
    -rw-r--r--.  1 root root  7572 12月  7 21:14 install.log.syslog

    解析

    以上面的 install.log 文件的信息为例,其权限部分  -rw-r--r--. 。长度12,可以这样划分 1 + 3 + 3 + 3 + 1。

    第一位代表文件类型:-代表文件,d代表目录,l代表连接,等等。

    之后的三组三位分别对应用户、用户组、其他用户的读写执行权限;

    最后一位与ACL有关,暂略。

    更改权限

    chmod命令

    有多种形式:

    chmod u+rwx,g+r,o+r  file
    chmod u=rwx,g=r,o=r  file
    chmod a=rx file
    
    chmod 755  file

    熟练之后推荐使用数字形式!

    另外,-r 选项表示递归,用于设定目录下面的所有文件的权限。

    特殊

    对于文件(与目录相对)来说,读写执行权限很好理解;但对于目录来说,则不那么容易理解。

    举个例子,假定有一个目录 ~/dir/,给你的权限是w写权限,那么你无法删除该目录、以及目录下的文件!

    原因涉及到底层知识,暂略。

    总之,Linux中,对文件来说最重要的是x权限,但对目录来说,最重要的是w权限。

    就是说,对目录来说,只有0、5(rx)、7(rwx)才有效。

  • 相关阅读:
    解决cron不执行的问题
    查看crontab运行状态
    php_network_getaddresses: getaddrinfo failed 原因
    UPdate语句
    重磅邀请函来了!首届“腾讯云+社区开发者大会”免费报名!
    Node 框架接入 ELK 实践总结
    只知道ajax?你已经out了
    深入理解苹果系统(Unicode)字符串的排序方法
    附实例!实现iframe父窗体与子窗体的通信
    vue.js的项目实战
  • 原文地址:https://www.cnblogs.com/larryzeal/p/6259611.html
Copyright © 2011-2022 走看看