Linux权限管理命令详解

   2016-11-22 0
核心提示:在说权限管理命令前,我无意中发现了一个命令 ll,验证了一下,发现跟ls -al效果是一样的,这个确实方便些,好了,接下来看下几个权限管理的命令: 一 chmod:改变文件或目录的权限 第一种用法chmod [{ugoa} {+-=} {rwx}] [文件或目录] u代表user g代表group

在说权限管理命令前,我无意中发现了一个命令 ll,验证了一下,发现跟ls -al效果是一样的,这个确实方便些,好了,接下来看下几个权限管理的命令:

一 chmod:改变文件或目录的权限

第一种用法chmod [{ugoa} {+-=} {rwx}] [文件或目录]

u代表user g代表group o代表other a代表all

+代表增加权限 -代表减少权限 =代表赋予权限

下面看个例子,创建目录 /tmp/fuqiang/fuqiang1

查看/tmp/fuqiang/fuqiang1目录的权限

Linux权限管理命令详解

我们看到权限是rwxr-xr-x,现在我们增加用户所在组的可写权限chmod g+w /tmp/fuqiang/fuqiang1

Linux权限管理命令详解

发现成功了,我们把用户权限,所在组权限和其他人权限全部改成rwx,chmod a=rwx /tmp/fuqiang/fuqiang1

Linux权限管理命令详解

我们把user去掉执行权限,所在组去掉执行权限

chmod u-x,g-x /tmp/fuqiang/fuqiang1

Linux权限管理命令详解

,好了第一种用法就是这样,我们发现每次加u g o a的很麻烦,有没有简单点的用法呢

第二种用法,数字表示法,我们把rwx分别用数字4 2 1来代替,那么如果三个权限全有,就是4+2+1=7,如果只有读和写权限就是4+2=6,如果只有读和执行权限就是4+1=5,如果只有写和执行权限就是2+1=3,很简单吧,下面我们把刚才的目录权限设定为所有权限都有,也就是777,chmod 777 /tmp/fuqiang/fuqiang1,来看下

Linux权限管理命令详解

我们发现成功了,用法很简单不多说了,下面来看一个很简单的问题,现在我们的目录/tmp/fuqiang/fuqiang1的权限是777了,也就是所有权限都有,我们在这个路径下创建一个文件fq.list,并且把这个文件的权限设置为770,也就是其他人对这个文件没有任何权限

Linux权限管理命令详解

好了,设置完了,接下来我们用useradd来添加一个f1的用户,属于是其他人了,然后su切换到f1用户,我用这个f1的其他人来删除我刚才创建的文件fq.list,看看能否成功

Linux权限管理命令详解

我们发现竟然成功了,这个文件对其他人明明是没有权限的啊,怎么会成功呢,好了,根本原因在于这个文件所在的目录的权限是777,我们都明白r是读权限,w是写权限,x是执行权限,那么这个rwx对于文件或者目录到底意味着什么呢

Linux权限管理命令详解

我们看这个表就会发现,这些权限对于目录和普文件的作用是不同的,对于普通文件,我们可以分别理解为读取文件的,修改文件和可执行文件,但是对于目录来说,就分别是可以列出目录的内容,可以在目录中创建或删除问题,可以进入目录,那么刚才的问题就很清晰了,由于文件所在路径具体777权限,所以其他人也可以在这个路径下创建和删除文件。

对于chmod命令,还有一点忘记说了,就是加选项-R 的话,就是递归修改目录下的所有目录或文件的权限

好了,第一个命令说到这,看第二个

二 chown:修改文件或目录的所有者

语法:chown [用户] [文件或目录]

注意,必须是root用户才有chown的权限

我们把/tmp/fuqiang/fuqiang1/fq.list的所有者修改为root,如下:

Linux权限管理命令详解

我们发现成功了,这个命令很简单,没什么好说的,下面看第三个命令

三 chgrp:修改文件或目录的所属组

语法:chown [用户组] [文件或目录]

注意,必须是root用户才有chgrp的权限

同样,我们把/tmp/fuqiang/fuqiang1/fq.list的所属组改为root,如下:

Linux权限管理命令详解

好了,很简单,我们看最后一个命令

四 umask:显示,设置文件或目录的缺省权限

umask -S 显示我们一般创建目录的权限,来看一下

Linux权限管理命令详解

也就是说我们创建一个目录的默认权限就是u=rwx,g=rx,0=rx,下面我们创建一个目录看一下

Linux权限管理命令详解

好了,果然是这样的,下面我们再创建一个文件看一下

Linux权限管理命令详解

我们发现文件的用户权限,所属组权限和其他人权限都少了一个x执行权限,这是linux的一种保护,因为x权限比较敏感,病毒什么的可以执行,除了x权限之外,其他权限都是跟umask默认是一样的

那么如果我们直接执行umask呢

Linux权限管理命令详解

我们得到了一个0022,第一个0我们先不管,后面三个022跟u=rwx,g=rx,0=rx刚好是777-022=755的结果,所以这个得到的结果是777-默认权限的结果,那么如果我们要修改一下默认权限,改为u=rw,g=rx,0=rx,那么就是655,用777-655=122,我们执行umask 122

Linux权限管理命令详解

接着我们再创建一个目录来验证下

Linux权限管理命令详解

发现跟我们要改成的权限655一致了,那么我们再创建一个文件呢

Linux权限管理命令详解

发现只是少了x执行权限,跟我们刚才说的对上了。

好了,linux常用的权限管理命令就说到这里,如果有问题,欢迎执行,谢谢!

本文永久更新链接地址 http://www.linuxidc.com/Linux/2016-11/137268.htm

 
标签: Linux命令
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 每天一条linux命令——halt
    halt命令用来关闭正在运行的Linux操作系统。halt命令会先检测系统的runlevel,若runlevel为0或6,则关闭系统,否则即调用shutdown来关闭系统。 语法:halt(选项)选项:-d:不要在wtmp中记录;-f:不论目前的runlevel为何,不调用shutdown即强制关闭系统;-i:
    02-10
  • 几个linux命令查看堆栈内存问题 几个linux命令
      公司编写代码,发现整个在程序里面调用system时候总是失败,原因是can't allocate memory ,根本原因不是内存不足,而是堆栈内存不够。使用ulimit -s 2048后有所好转但是发现一旦系统进程开启多了后仍然会挂。后来使用objdump -x 后发现了原因有个动态库
    02-09
  • Linux命令总结--rm命令 linux的rmp命令
    (来源于http://www.cnblogs.com/xqzt/p/5398919.html)1、命令简介rm(Remove file 删除目录或文件)删除文件,对于链接文件,只是删除整个链接文件,而原有文件保持不变。新手在删除文件之前一定要知道这些:很重要1.可以用mv代替rm的绝对不要用rm,不要着急
    02-09
  • Linux命令行批量创建目录详解 linux创建目录
    以前一直用-p创建目录链,觉得很方便了。在空目录/opt/app/myapp里创建src,再创建main,再创建javamkdir -p /opt/app/myapp/src/main/java没想到还可以这样玩##¥%……*(root@vm1:~/tmp# mkdir -p src/{{main,test}/{java,resources},main/webapp}root@vm1:
    02-09
  • Linux命令之乐--script和scriptplay
    script和scriptplay可以把终端会话记录到一个文件中,可以用来制作命令行教学视屏。 开始录制会话[root@new test]# script -t 2timing.log -a output.sessionScript started, file is output.session[root@new test]# echo hellohello[root@new test]# echo
    02-09
  • java 开发常用的Linux命令
    1.查找文件 find / -name filename.txt 根据名称查找/目录下的filename.txt文件。find . -name "*.xml" 递归查找所有的xml文件find . -name "*.xml" |xargs grep "hello world" 递归查找所有文件内容中包含hello world的xml文件grep -H 'spring' *.xml 查找所
    02-09
  • 常用Linux命令整理 Linux常用命令总结
    常用Linux命令整理常见系统命令export 查看或修改环境变量# 例:临时修改命令提示符为字符串$export PS1=$# 例:临时修改命令提示符显示系统时间 时间使用\t 表示export PS1="[\u@\h \t \W]\$"man 查看linux系统的手册# 例:查看ls命令如何使用man ls # 回车
    02-09 Linux
  • linux命令行—《命令行快速入门》 linux常用命令csdn
    linux命令行—《命令行快速入门》 linux常用命
    pwd print working directory 打印工作目录hostname my computer's network name 电脑在网络中的名称mkdir make directory 创建路径cd change directory 改变路径ls list directory 列出路径下的内容rmdir remove directory 删除路径pushd push directory 推
    02-09
  • Linux命令(五) 五个常用的linux命令
    Linux命令(五) 五个常用的linux命令
    jenkins触发钉钉报警机制1、安装钉钉插件钉钉报警需要安装Ding Talk插件,支持钉钉报警2、打开钉钉创建钉钉机器人2.1选择机器人类型——自定义2.2添加机器人2.3填写机器人信息填写机器人姓名—设置安全设置为加密类型,并复制出来加密值2.4创建完成保持webhoo
    02-09
  • 03_Linux基础-文件类型-主辅提示符-第1提示符-Linux命令-内外部命令-快捷键-改为英文编码-3个时间-stat-其他基础命令
    03_Linux基础-文件类型-主辅提示符-第1提示符-L
    03_Linux基础-文件类型-主辅提示符-第1提示符-Linux命令-内外部命令-快捷键-改为英文编码-3个时间-stat-{1..100}-du-cd-cp-file-mv-echo-id-shell-ln-env-set-which-rpm-/usr-/与/root-hostname-vim-cat-pwd-alias-unalias-ls-ASCII-wc-chmod博客
    02-09
点击排行