Linux常用基本命令(chmod)
chmod命令用来改变文件或者目录的权限,只有文件的属主和超级用户才能够执行这个命令
格式:
chmod [option] [mode] [file]
>常用参数选项 -R : 递归修改目录以及子目录下面的所有文件权限
>模式有两种格式,一种采用字母方式的表达式,另外一种是数字
1,首先需要了解文件的权限和属主和属组。
ghostwu@dev:~/linux/chown$ ls -l total 4 -rw-rw-r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
-rw-rw-r-- 这个就是文件的权限, 除去第一位, 一共有9位组成
第一位表示文件类型,- 表示这个是一个常规文件
后面9位,每3位一组. 第一个3位rw-表示属主权限, 第二个3位rw-表示属组权限,第三个3位r--表示其他用户权限,
后面有2个ghostwu, 第一个ghostwu, 表示属主, 也就是这个test.txt文件的拥有者是ghostwu
第二个ghostwu,表示属组,也就是这个test.txt文件可以被ghostwu这个组的用户 rw-( 可读,可写)
2,修改文件权限
>增加权限( + )
ghostwu@dev:~/linux/chown$ chmod a+x test.txt ghostwu@dev:~/linux/chown$ ls test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxr-x 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
a等价于 用户(u)+组(g)+其他组( o )。 a+x 就是给用户,组,其他组都加上x(可执行)权限
>去掉权限( - )
ghostwu@dev:~/linux/chown$ chmod a-x test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rw-rw-r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>设置权限( = )
ghostwu@dev:~/linux/chown$ chmod a=r-- test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -r--r--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>给属主加上w( 可写 ), x( 可执行 ) 权限
ghostwu@dev:~/linux/chown$ chmod u+wx test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>给组加上wx权限
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod g+wx test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxr-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>给其他组加上wx权限
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxr-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod o+wx test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxrwx 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>r( 4 ), w( 2 ), x( 1 )
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxrwx 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod 444 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -r--r--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
ghostwu@dev:~/linux/chown$ ls -l total 4 -r--r--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod 755 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr-xr-x 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
权限详解:
一、普通文件
可读r: 读取/阅读文件内容的权限
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr-xr-x 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod 000 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 ---------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ cat test.txt cat: test.txt: Permission denied ghostwu@dev:~/linux/chown$ chmod 400 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -r-------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ cat test.txt this is a test file
可写(w):具有新增,修改文件内容的权限
ghostwu@dev:~/linux/chown$ ls -l test.txt -r-------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ echo 'aaa' > test.txt bash: test.txt: Permission denied ghostwu@dev:~/linux/chown$ chmod u+w test.txt ghostwu@dev:~/linux/chown$ ls -l test.txt -rw------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ echo 'ghostwu' >> 'test.txt' ghostwu@dev:~/linux/chown$ cat test.txt this is a test file ghostwu
可执行( x )
1,文件本身要用x权限
ghostwu@dev:~/linux/chown$ ls -l test.txt -rw------- 1 ghostwu ghostwu 28 5月 9 23:20 test.txt ghostwu@dev:~/linux/chown$ ./test.txt bash: ./test.txt: Permission denied ghostwu@dev:~/linux/chown$ chmod u+x test.txt ghostwu@dev:~/linux/chown$ ls -l test.txt -rwx------ 1 ghostwu ghostwu 28 5月 9 23:20 test.txt ghostwu@dev:~/linux/chown$ ./test.txt ./test.txt: line 1: this: command not found ./test.txt: line 2: ghostwu: command not found
ghostwu@dev:~/linux/chown$ echo 'ls /' > test.sh ghostwu@dev:~/linux/chown$ ls -l total 8 -rw-rw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh -rwx------ 1 ghostwu ghostwu 28 5月 9 23:20 test.txt ghostwu@dev:~/linux/chown$ ./test.sh bash: ./test.sh: Permission denied ghostwu@dev:~/linux/chown$ chmod u+x test.sh ghostwu@dev:~/linux/chown$ ls -l test.sh -rwxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh ghostwu@dev:~/linux/chown$ ./test.sh bin dev initrd.img lost+found opt run srv usr boot etc lib media proc sbin sys var cdrom home lib64 mnt root snap tmp vmlinuz
普通用户需要拥有r权限, 然后x权限 才能执行
ghostwu@dev:~/linux/chown$ ls -l test.sh -rwxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh ghostwu@dev:~/linux/chown$ chmod u-r test.sh ghostwu@dev:~/linux/chown$ ls -l test. ls: cannot access 'test.': No such file or directory ghostwu@dev:~/linux/chown$ ls -l test.sh --wxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh ghostwu@dev:~/linux/chown$ ./test.sh bash: ./test.sh: Permission denied
root用户不需要r权限,只要有x权限就能执行
root@dev:/home/ghostwu/linux/chown# ls -l test.sh --wxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh root@dev:/home/ghostwu/linux/chown# ./test.sh bin dev initrd.img lost+found opt run srv usr boot etc lib media proc sbin sys var cdrom home lib64 mnt root snap tmp vmlinuz root@dev:/home/ghostwu/linux/chown# chmod a-x test.sh root@dev:/home/ghostwu/linux/chown# ls -l test.sh --w-rw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh root@dev:/home/ghostwu/linux/chown# ./test.sh -su: ./test.sh: Permission denied root@dev:/home/ghostwu/linux/chown# chmod o+x test.sh root@dev:/home/ghostwu/linux/chown# ls -l test.sh --w-rw-r-x 1 ghostwu ghostwu 5 5月 9 23:22 test.sh root@dev:/home/ghostwu/linux/chown# ./test.sh bin dev initrd.img lost+found opt run srv usr boot etc lib media proc sbin sys var cdrom home lib64 mnt root snap tmp vmlinuz
二、目录权限
可读r: 具有浏览目录下面文件及其子目录的权限,即:ls 目录
ghostwu@dev:~/linux$ ls -l total 12 drwxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ ls chown test.sh test.txt ghostwu@dev:~/linux$ chmod u-r chown ghostwu@dev:~/linux$ ls -l chown ls: cannot open directory 'chown': Permission denied ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown
没有x权限,不能cd切换到目录
ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown ghostwu@dev:~/linux/chown$ ls ls: cannot open directory '.': Permission denied
ghostwu@dev:~/linux/chown$ cd .. ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ chmod u-x chown ghostwu@dev:~/linux$ ls -l total 12 d-w-rwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown -su: cd: chown: Permission denied
w: 具有增加,删除或者修改目录内文件名的权限,需要x权限配合
ghostwu@dev:~/linux$ ls -l total 12 d-w-rwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown -su: cd: chown: Permission denied ghostwu@dev:~/linux$ chmod u+x chown ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown ghostwu@dev:~/linux/chown$ ls -l ls: cannot open directory '.': Permission denied ghostwu@dev:~/linux/chown$ touch a.txt ghostwu@dev:~/linux/chown$ ls -l . ls: cannot open directory '.': Permission denied ghostwu@dev:~/linux/chown$ ls -l a.txt -rw-rw-r-- 1 ghostwu ghostwu 0 5月 9 23:34 a.txt
如果父目录没有w权限,是不能删除目录下面的文件的
ghostwu@dev:~/linux/chown$ ls -l a.txt -rw-rw-r-- 1 ghostwu ghostwu 0 5月 9 23:34 a.txt ghostwu@dev:~/linux/chown$ rm -f a.txt ghostwu@dev:~/linux/chown$ ls -l a.txt ls: cannot access 'a.txt': No such file or directory ghostwu@dev:~/linux/chown$ touch a.txt ghostwu@dev:~/linux/chown$ cd .. ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:35 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ chmod u-w chown ghostwu@dev:~/linux$ ls -l chown/a.txt -rw-rw-r-- 1 ghostwu ghostwu 0 5月 9 23:35 chown/a.txt ghostwu@dev:~/linux$ rm -f chown/a.txt rm: cannot remove 'chown/a.txt': Permission denied
x: 具有进入目录的权限:如cd dir
>没有r无法列表
>没有w无法新建文件