shell基础一:文件安全与权限

本文主要有以下内容:

文件权限位
基本命令
chmod
suid/guid
chown
chgrp
umask
算法和用法
符号链接

当创建一个文件的时候,系统保存了有关该文件的全部信息,包括:
"
文件的位置。
"
文件类型。
"
文件长度。
"
哪位用户拥有该文件,哪些用户可以访问该文件。
" i
节点。
"
文件的修改时间。
"
文件的权限位。

让我们用touch命令创建一个文件:

$ touch temp

创建了一个空文件,现在用ls -l命令查看该目录下文件的属性(我这里用中文版)
如下:

[root@Linux_chenwy temp]# ls -l
总用量 36
-rw-r--r-- 1 root root 34890 10
19 20:17 httpd.conf
-rw-r--r-- 1 root root 0 10
19 20:16 temp

总用量 36:是ls所列出的入口占用空间的字节数(K为单位)
1
该文件硬链接的数目。
root
:文件属主。
root
:文件属组(一般是文件属主所在的缺省组。)
34890
:字节来表示的文件长度,记住,不是K字节!
10
19 20:17:件的更新时间。
temp or httd.conf
:件名。

BTW:要检查该目录所有文件占用的空间应该用这个命令:du
譬如说前面说的36是如何计算出来:
首先我们要先了解你所用的文件系统的IO BLOCK(中文叫作簇)为多少,在你所使用的这个文件系统的IO BLOCK大小是4096 Bytes

他意义是文件系统最小的读写及分配单位,每次读写操作你都不能小于这个尺寸。即使你的文件是只有一个字节。而且文件在硬盘上的存储也是以这个为单位,就是说如果文件尺寸小于这个值,那么它在磁盘上占用的空间就是4096字节。

占用空间的具体算法是:(进一(文件尺寸/4096))×4096。根据这个你就可以计算出你所列举的例子中的文件的空间使用状况:34890除以4096,大约等于8.5,进一法取得为9,就是说文件在磁盘上占用了9BLOCk,每个BLOCK4K,所以这两个文件占用的空间就是36K

这个规则也适合于目录,不过不会出现为0的目录,即使是空目录

-rw-r--r-- :这是该文件的权限位。

第一个横杠:指定文件类型,表示该文件是一个普通文件。(所创建的文件绝大多数都是普通文件或符号链接文件)

除去最前面的横杠,一共是9个字符,他们分别对应9个权限位。通过这些权限位,可以设定用户对文件的访问权限。对这两个文件的精确解释是:

rw-:前三位,文件属主可读、写
r--
:中间三位,组用户可读
r--
:最后三位,其他用户只可读

在创建的时候并未给属主赋予执行权限,在用户创建文件时,系统不会自动地设置执行权限位。这是出于加强系统安全的考虑

BTW
:文件的属主组并不一定就是所有者所在的缺省组,而可以是任何一个跟该文件所有者无关的用户组。为了方便,还是统称属主,属组和其它

现在分开详细说明:

文件类型

前面提到的第一条横杠,表示该文件是普通文件型
文件类型有七种,它可以从ls -l命令所列出的结果的第一位看出.

七种类型:

d 目录。
l
符号链接(指向另一个文件)
s
套接字文件。
b
块设备文件。
c
字符设备文件。
p
命名管道文件。
-
普通文件,或者更准确地说,不属于以上几种类型的文件。

文件的权限位中中每一组字符中含有三个权限位:

r 读权限
w
/更改权限
x
执行该脚本或程序的权限

如:

r-- --- --- 文文件属主可读,但不能写或执行
r-- r-- ---
文文件属主和属组用户(一般来说,是文件属主所在的缺省组)可读
r-- r-- r- -
文任何用户都可读,但不能写或执行
rwx r-- r- -
文文件属主可读、写、执行,属组用户和其他用户只可读
rwx r-x ---
文文件属主可读、写、执行,属组用户可读、执
rwx r-x r- x
文文件属主可读、写、执行,属组用户和其他用户可读、执行
rw- rw- ---
文文件属主和属组用户可读、写
rw- rw- r- -
文文件属主和属组用户可读、写,其他用户可读
rw- rw- ---
文文件属主和属组用户及其他用户读可以读、写,慎用这种权限
设置,因为任何用户都可以写入该文件

使用chmod来改变权限位

这一命令有符号模式和绝对模式。

符号模式

chmod
命令的一般格式为:

chmod [who] operator [permission] filename

w h o
的含义是:

现在已经使文件属主对temp文件具有读、写执行的权限,属组用户真有读写权限,其它用户没有权限了。

绝对模式

chmod
命令绝对模式的一般形式为:

chmod [mode] file

其中m o d e是一个八进制数。
在绝对模式中,权限部分有着不同的含义。每一个权限位用一个八进制数来代表,如

0 4 0 0 文件属主可读
0 2 0 0
文件属主可写
0 1 0 0
文件属主可执行

0 0 4 0
属组用户可读
0 0 2 0
属组用户可写
0 0 1 0
属组用户可执行

0 0 0 4
其他用户可读
0 0 0 2
其他用户可写
0 0 0 1
其他用户可执行

在设定权限的时候,只需按照上面查出与文件属主、属组用户和其他用户所具有的权限相对应的数字,并把它们加起来,就是相应的权限表示。
可以看出,文件属主、属组用户和其他用户分别所能够具有的最大权限值就是7

再来看看前面举的例子:

-rwxr--r--1 root 0 10 19 20:16 temp

相应的权限是:

rwx-0400 + 0200 +0100 (文件属主可读、写、执行) = 0 7 0 0
r--
0 0 4 0 (属组用户可读) = 0 0 4 0
r--
0 0 4 0 (属组用户可读) = 0 0 4 0
0 7 4 4

有一个计算八进制权限表示的更好办法,如下:

文件属主:r w x4 + 2 + 1
属组用户:r w x4 + 2 + 1
其他用户:r w x4 + 2 + 1

这上面这相,更容易地计算出相应的权限值,只要分别针对文件属主、属组用户和其他用户把相应权限下面的数字加在一起就可以了。

temp
文件具有这样的权限:

r w x r - - r - -
4+2+14 4

把相应权限位所对应的值加在一起,就是7 4 4

如:

chmod 666 rw- rw- rw- 赋予所有用户读和写的权限
chmod 644 rw- r-- r- -
赋予所有文件属主读和写的权限,所有其他用户读权限
chmod 744 rwx r-- r- -
赋予文件属主读、写和执行的权限,所有其他用户读的权限
chmod 664 rw- rw- r- -
赋予文件属主和属组用户读和写的权限,其他用户读权限
chmod 700 rwx --- ---
赋予文件属主读、写和执行的权限
chmod 444 r-- r-- r- -
赋予所有用户读权限

下面举一个例子,假定有一个名为temp的文件,具有如下权限:

-rw-rw-r--1 root 0 10 19 20:16 test1

现在希望对该文件可读、写和执行, root组用户对该文件只读,可以键入:

$chmod 740 test1
$ls -l
-rwxr-----1 root 0 10
19 20:16 test1

如果文件可读、写和执行,对其他所有用户只读,用:

$chmod 744 test1
$ls -l
-rwxr--r--1 root 0 10
19 20:16 test1

如果希望一次设置目录下所有文件的权限,可以用:

$chmod 664*
$ls -l
-rw-r--r--1 root 0 10
19 20:16 test1

这将使文件属主和属组用户都具有读和写的权限,其他用户只具有读权限。

还可以通过使用- R选项连同子目录下的文件一起设置:

chmod -R 664 /temp/*

这样就可以一次将/ temp目录下的所有文件连同各个子目录下的文件的权限全部设置为文件属主和属组用户可读和写,其他用户只读。使用- R选项一定要谨慎,只有在需要改变目录树下全部文件权限时才可以使用。
目录

目录的权限位和文件有所不同。目录的读权限位意味着可以列出其中的内容。写权限位意味着可以在该目录中创建文件,如果不希望其他用户在你的目录中创建文件,可以取消相应的写权限位。执行权限位则意味着搜索和访问该目录.

r :可以列出该目录中的文件
w:
可以在该目录中创建或删除文件
x:
可以搜索或进入该目录

权限文件属主属组用户其他用户

drwx rwx r- x ( 775 ) 属主读、写、执行,属组读、写、执行,其它组读、执行
drwx r-x r- - ( 754 )
属主读、写、执行,属组读、执行,其它组读
drwx r-x r- x ( 755 )
属主读、写、执行,属组读、执行,其它组读、执行

如果把属组用户或其他用户针对某一目录的权限设置为- - x,那么他们将无法列出该目录中的文件。如果该目录中有一个执行位置位的脚本或程序,只要用户知道它的路径和文件名,仍然可以执行它。用户不能够进入该目录并不妨碍他的执行。

目录的权限将会覆盖该目录中文件的权限。例如,如果目录temp具有如下的权限:

drwxr--r--1 admin 0 10 19 20:16 temp

而目录下的文件myfile的权限为:

-rwxrwxrwx1 admin 0 10 19 20:16 myfile

那么admin组的用户将无法编辑该文件,因为它所属的目录不具有这样的权限。

该文件对任何用户都可读,但由于它所在的目录并未给admin组的用户赋予执行权限,所以该组的用户都将无法访问该目录,他们将会得到访问受限的错误消息。

-rwxrwxrwx

9
个权限位换成这样是不是更容易理解呢?

如:

-rwxrw-r-- 1 root admin 34890 10 19 20:17 httpd.conf

前三位:rwx:它的所有者是root,即就是文件所有者,它对httpd.conf这个文件的权限是读写执行;
中间三位:rw-:表示admin组对这个文件的权限是读写
后面位:r--:就是即不是所有者,也不是属组的对文件的权限是读


suid/guid


1
、为什么要使用这种类型的脚本?

例如有几个着几个大型的数据库系统,对它们进行备份需要有系统管理权限。可以写几个脚本,并设置了它们的g u i d,这样就可以指定的一些用户来执行这些脚本就能够完成相应的工作,而无须以数据库管理员的身份登录,以免不小心破坏了数据库服务器。通过执行这些脚本,他们可以完成数据库备份及其他管理任务,但是在这些脚本运行结束之后,他们就又回复到他们作为普通用户的权限。


2
、查找suid/guid命令

有相当一些U N I X命令也设置了s u i dg u i d。如果想找出这些命令,可以进入/ b i n/ s b i n目录,执行下面的命令:

$ ls -l | grep '^...s'

上面的命令是用来查找s u i d文件的;

$ ls -l | grep '^...s..s'

上面的命令是用来查找s u i dg u i d的。


3
、设置UID

设置s u i d:将相应的权限位之前的那一位设置为4
设置g u i d:将相应的权限位之前的那一位设置为2
两者都置位:将相应的权限位之前的那一位设置为4+2=6

设置了这一位后x的位置将由s代替。
记住:在设置s u i dg u i d的同时,相应的执行权限位必须要被设置。
例如,如果希望设置g u i d,那么必须要让该用户组具有执行权限。

如果想要对文件l o g i n[它当前所具有的权限为rwx rw- r-- (741)]设置s u i d,,可在使用c h m o d命令时在该权限数字的前面加上一个4,即chmod 4741,这将使该文件的权限变为r w s rw- r - -

$ chmod 4741 login

设置suid/guid的例子

命令 结果 含义
chmod 4755 rws r-x r- x
文件被设置了s u i d,文件属主具有读、写和执行的权限,其他用户具有读和执行的权限
chmod 6711 rws --s --x
文件被设置了s u i dg u i d,文件属主具有读、写和执行的权限,其他用户具有执行的权限
chmod 4764 rws rw- r- -
文件被设置了s u i d,文件属主具有读、写和执行的权限,属组用户具有读和执行的权限,用户具有读权限

4、还可以使用符号方式来设置s u i d / g u i d如果某个文件具有这样的权限: rwx r-x r- x,那么可以这样设置其s u i d

chmod u+s <filename>;

于是该文件的权限将变为: rws r-x r-x

在查找设置了s u i d的文件时,没准会看到具有这样权限的文件:rwS r-x r- x,其中S为大写。
它表示相应的执行权限位并未被设置,这是一种没有什么用处的s u i d设置,可以忽略它的存在。

注意,c h m o d命令不进行必要的完整性检查,可以给某一个没用的文件赋予任何权限,但chmod 命令并不会对所设置的权限组合做什么检查。因此,不要看到一个文件具有执行权限,就认为它一定是一个程序或脚本。
chown
chgrp

当你创建一个文件时,你就是该文件的属主。一旦你拥有某个文件,就可以改变它的所有权,把它的所有权交给另外一个/ e t c / p a s s w d文件中存在的合法用户。可以使用用户名或用户I D号来完成这一操作。

在改变一个文件的所有权时,相应的s u i d也将被清除,这是出于安全性的考虑。只有文件的属主和系统管理员可以改变文件的所有权。一旦将文件的所有权交给另外一个用户,就无法再重新收回它的所有权。如果真的需要这样做,那么就只有求助于系统管理员了。

1
c h o w n命令的一般形式为:

chmod -R -h owner file

QUOTE:

- R选项意味着对所有子目录下的文件也都进行同样的操作。
- h
选项意味着在改变符号链接文件的属主时不影响该链接所指向的目标文件。

2chown举例

如:
# ls -l
drwxrwxr-x 2 sam sam 4096 10
26 19:48 sam
# chown gem sam
# ls -l
drwxrwxr-x 2 gem sam 4096 10
26 19:48 sam

文件sam的所有权现在由用户sam交给了用户gem


3
chgrp举例

c h g r p
命令和c h o w n命令的格式差不多,下面给出一个例子。

# ls -l
drwxrwxr-x 2 gem sam 4096 10
26 19:48 sam
# chgrp group sam
# ls -l
drwxrwxr-x 2 gem group 4096 10
26 19:48 sam

现在把该文件sam所属的组由sam变为group


4
、找出你所属于的用户组

如果你希望知道自己属于哪些用户组,可以用ID这个命令:

# su sam
$ id
uid=506(sam) gid=4(adm) groups=4(adm)

5、找出其他用户所属于的组

# id
uid=0(root) gid=0(root) groups=0(root),1(bin),2(daemon),3(sys),4(adm),6(disk),10(wheel)
查看当前用户所属组

# id gem
uid=507(gem) gid=507(group) groups=507(group),0(root),4(adm)
查看其它用户所用组:#id 用户名

# su sam
$ id gem
uid=507(gem) gid=507(group) groups=507(group),0(root),4(adm)
查看其它用户所属组

这里书上用group,但我试过不能使
BTW
:可以用#cat /etc/passwd#cat /etc/group直接查看用户和组

umask

当最初登录到系统中时, u m a s k命令确定了你创建文件的缺省模式。这一命令实际上和c h m o d命令正好相反。你的系统管理员必须要为你设置一个合理的u m a s k值,以确保你创建的文件具有所希望的缺省权限,防止其他非同组用户对你的文件具有写权限。

在已经登录之后,可以按照个人的偏好使用u m a s k命令来改变文件创建的缺省权限。相应的改变直到退出该s h e l l或使用另外的u m a s k命令之前一直有效。

一般来说,u m a s k命令是在/ e t c / p r o f i l e文件中设置的,每个用户在登录时都会引用这个文件,所以如果希望改变所有用户的u m a s k,可以在该文件中加入相应的条目。如果希望永久性地设置自己的u m a s k值,那么就把它放在自己$ H O M E目录下的. p r o f i l e. b a s h _ p r o f i l e文件中。

如何计算umask


u m a s k
命令允许你设定文件创建时的缺省模式,对应每一类用户(文件属主、属组、其他用户)存在一个相应的u m a s k值中的数字。对于文件来说,这一数字的最大值分别是6。系统不允许你在创建一个文本文件时就赋予它执行权限,必须在创建后用c h m o d命令增加这一权限。目录则允许设置执行权限,这样针对目录来说, u m a s k中各个数字最大可以到7
该命令的一般形式为:

umask nnn

其中n n nu m a s k0 0 0 - 7 7 7

计算u m a s k值:

可以有几种计算u m a s k值的方法,通过设置u m a s k值,可以为新创建的文件和目录设置缺省权限。

与权限位相对应的u m a s k值。

umask 文件 目录
0 6 7
1 6 6
2 4 5
3 4 4
4 2 3
5 2 2
6 0 1
7 0 0

在计算u m a s k值时,可以针对各类用户分别按上面那张表中按照所需要的文件/目录创建缺省权限查找对应的u m a s k值。
例如,u m a s k

0 6 7
0 6 7
2 4 5

所以002所对应的文件和目录创建缺省权限分别为6 6 47 7 5

还有另外一种计算u m a s k值的方法。我们只要记住u m a s k是从权限中拿走相应的位即可。

umask 文件 目录
0 6 7
1 6 6
2 4 5
3 4 4
4 2 3
5 2 2
6 0 1
7 0 0

例如,对于u m a s k0 0 2,相应的文件和目录缺省创建权限是什么呢?

QUOTE:

第一步,我们首先写下具有全部权限的模式,即7 7 7 (所有用户都具有读、写和执行权限)
第二步,在下面一行按照u m a s k值写下相应的位,在本例中是0 0 2
第三步,在接下来的一行中记下上面两行中没有匹配的位。这就是目录的缺省创建权限。
稍加练习就能够记住这种方法。
第四步,对于文件来说,在创建时不能具有文件权限,只要拿掉相应的执行权限比特即可。

这就是上面的例子,其中u m a s k值为0 0 2

QUOTE:

1) 文件的最大权限rwx rwx rwx (777)
2) umask
值为0 0 2 - - - - - - -w-
3)
目录权限rwx rwx r-x (775) 这就是目录创建缺省权限
4)
文件权限rw- rw- r-- (664) 这就是文件创建缺省权限

下面是另外一个例子,假设这次u m a s k值为0 2 2

QUOTE:

1) 文件的最大权限rwx rwx rwx (777)
2 ) u m a s k
值为0 2 2 - - - -w- -w-
3)
目录权限rwx r-x r-x (755) 这就是目录创建缺省权限
4)
文件权限rw- r-- r-- (644) 这就是文件创建缺省权限

如果想知道当前的umask 值,可以使用u m a s k命令:

#su sam /*切换到sam用户玩境下
#umask /*
查看samumask
0022
前面多了个0,是suid/guid

$ touch file1
$ mkdir file2
$ ls -l
总用量 8
-rw-r--r-- 1 sam adm 0 10
30 19:27 file1
drwxr-xr-x 2 sam adm 4096 10
30 19:28 file2

QUOTE:

新建文件file1和目录file2,查看新建文件和目录的默认权限,umask022
目录权限rwx r-x r-x (755)
文件权限rw- r-- r-- (644)

更改umask默认值由022002

$ umask 002
$ touch file3
$ ls -l
总用量 12
-rw-r--r-- 1 sam adm 0 10
30 19:27 file1
drwxr-xr-x 2 sam adm 4096 10
30 19:28 file2
-rw-rw-r-- 1 sam adm 0 10
30 19:34 file3
drwxrwxr-x 2 sam adm 4096 10
30 19:34 file4

QUOTE:

可以看到,新建文件和目录的默认权限改变了,umask002
目录权限rwx rwx r-x (775)
文件权限rw- rw- r-- (664)

可以看见,$ umask 002已生效

补充umask的另一种用法,书上没有的,我觉得这个比较方便

先说一下umask在不同玩境下的不同

1bash
umask [-p] [-S] [mode]

2
tcsh
umask [value]

说明

当新增文件或目录时,预设的使用权限,由 umask 这个内设值所规定的。
一般情况下,umask 会被设定在 shell 的启始档案中。

QUOTE:

bash 的使用者来说,个人的启始档案是 $HOME/.bashrc,使用者可以将 umask 设定在其中。像 RedHat 9 是放 /etc 之下,档名为 bashrc
当使用者没有自行设定,umask 设定值便来自于此系统的默认设定。

tcsh
的个人启始档案为 ~/.tcshrc,系统设定文件在 /etc/csh.cshrc

linux 操作系统的角度,完整的权限设定值是四位数字。
第一位数,代表档案或目录的特殊属性。 4 代表 "suid"2 代表 "sgid"1 代表 "粘滞位 - save text image"
后三位数,依序代表 "user-档案拥有者""group-群组""other-其它"
每一位数,代表三种权限的叠加,4-(r)2-(w)1-执行(x)
被禁止的权限则以 0 带入。

QUOTE:

umask 来说,有效的设定值只有后三位数。在 bash 中,虽然可带入四位数字,但第一个数字,必须为 0。这点请注意。

指令 umask 的设定值以三个八进位的数字“nnn”代表。
第一个设定数字给使用者自己(owner user),
第二个则是设定给用使用者所属的群体(group),
第三个给不属于同群体的其它使用者(other)。
每一位数字的设定值都是三项不同权限的数值加总,read 权限数值为 4write 权限数值为 2execute 权限数值为 1
结合了前三者的权限数值,单一的数字可设定的范围是 0 ~ 7;整体的可设定范围是 000 ~ 777

umask 的设定值,对目录,与对档案的实质作用是有差别的。

注意:

当我们设定为 000 时,会得到完全开放的目录权限 777,以及文件权限 666。为何文件只得到 666 呢?因为文件权限中的 execute 权限已被程序移除,因此,不管你设定什么 umask 数值,文件都不会出现 execute 权限。

umask 语法如下:

umask who operator permissions

其中,参数的含义如下:

who:表示下列字符中的一个、两个或全部:

u
(表示用户权限)
g
(表示组用户权限)
o
(表示其他用户权限)
a
ugo 的缩写形式)

你可能感兴趣的:(linux,算法,中间件,脚本,bash)