su和sudo命令的区别与使用技巧4

上一篇 / 下一篇  2008-12-11 21:31:32 / 个人分类:Lunix 点滴

  • 文件版本: V1.0
  • 开发商: 本站原创
  • 文件来源: 本地
  • 界面语言: 简体中文
  • 授权方式: 免费
  • 运行平台: Win9X/Win2000/WinXP

实例五:练习用户组在/etc/sudoers中写法;

@d3qg$` Hp/P0

  如果用户组出现在/etc/sudoers中,前面要加%号,比如%beinan,中间不能有空格;%beinan ALL=/usr/sbin/*,/sbin/*51Testing软件测试网&?/q5F {4M3d*k

如果我们在/etc/sudoers中加上如上一行,表示beinan用户组下的所有成员,在所有可能的出现的主机名下,都能切换到root用户下运行/usr/sbin/sbin目录下的所有命令;51Testing软件测试网-W$M&S g'q#QI

  实例六:练习取消某类程序的执行:51Testing软件测试网d2a&ZJ(OS7s#E$P

  取消程序某类程序的执行,要在命令动作前面加上!号;在本例中也出现了通配符的*的用法;51Testing软件测试网_#sq"rYWM

  beinan ALL=/usr/sbin/*,/sbin/*,!/usr/sbin/fdisk注:把这行规则加入到/etc/sudoers中;但您得有beinan这个用户组,并且beinan也是这个组中的才行;51Testing软件测试网1baBk#iX r

  本规则表示beinan用户在所有可能存在的主机名的主机上运行/usr/sbin/sbin下所有的程序,但fdisk程序除外;51Testing软件测试网Vj ?Dr0m q

$ sudo  -l  [beinan@localhost ~]

!T"W w2ANS'~~0

  Password:注:在这里输入beinan用户的密码;

u{&`X&J4m.U6vIE6`0

  User beinan may run the /usr/sbin/*(root) /sbin/*(root) following commands on this host:(root) $ sudo !/sbin/fdisk[beinan@localhost ~] /sbin/fdisk -lSorry, user beinan is not allowed to execute '/sbin/fdisk -l' as root on localhost.51Testing软件测试网N'n_4w[*S

  注:不能切换到root用户下运行fdisk程序;

1C:I#dl3?,x0

  实例七:别名的运用实践;51Testing软件测试网]my OV:X.S(?O

  假如我们就一台主机localhost,能通过hostname来查看,我们在这里就不定义主机别名了,用ALL来匹配所有可能出现的主机名;并且有beinanlinuxsirlanhaitun用户;主要是通过小例子能更好理解;sudo虽然简单好用,但能把说的明白的确是件难事;最好的办法是多看例子和man soduers

_ z Vr*VFL!iU0

  User_Alias SYSADER=beinan,linuxsir,%beinan51Testing软件测试网fyx'RC

  User_Alias DISKADER=lanhaitunRunas_Alias ōP=rootCmnd_Alias SYDCMD=/bin/chown,/bin/chmod,/usr/sbin/adduser,/usr/bin/passwd [A-Za-z]*,!/usr/bin/passwd rootCmnd_Alias DSKCMD=/sbin/parted,/sbin/fdisk注:定义命令别名DSKCMD,下有成员partedfdiskSYSADER ALL= SYDCMD,DSKCMDDISKADER ALL=(OP) DSKCMD

9e"lH K+xBa0

注解:

yB'U{ E:UG0

  第一行:定义用户别名SYSADER下有成员beinanlinuxsirbeinan用户组下的成员,用户组前面必须加%号;51Testing软件测试网 Sn%k1YB/y1{@l

  第二行:定义用户别名DISKADER,成员有lanhaitun

*[0A:Y9N lL0

  第三行:定义Runas用户,也就是目标用户的别名为OP,下有成员root51Testing软件测试网 i3K|!H%W%o,]3j"W

  第四行:定义SYSCMD命令别名,成员之间用,号分隔,最后的!/usr/bin/passwd root表示不能通过passwd来更改root密码;

)M3vI:S4h\_kI0

  第五行:定义命令别名DSKCMD,下有成员partedfdisk

v7x rK)N-Q-t/E0

  第六行:表示授权SYSADER下的所有成员,在所有可能存在的主机名的主机下运行或禁止SYDCMDDSKCMD下定义的命令。更为明确遥说,beinanlinuxsirbeinan用户组下的成员能以root身份运行chownchmodadduserpasswd,但不能更改root的密码;也可以以root身份运行partedfdisk,本条规则的等价规则是;51Testing软件测试网!~q6H9H!M7\-~

  beinan,linuxsir,%beinan ALL=/bin/chown,/bin/chmod,/usr/sbin/adduser,/usr/bin/passwd [A-Za-z]*,!/usr/bin/passwd root,/sbin/parted,/sbin/fdisk51Testing软件测试网i6v"k$MY6Y X+L

  第七行:表示授权DISKADER下的所有成员,能以OP的身份,来运行DSKCMD,不需要密码;更为明确的说lanhaitun能以root身份运行partedfdisk命令;其等价规则是:51Testing软件测试网%`-gIZr9W

  lanhaitun ALL=(root) /sbin/parted,/sbin/fdisk51Testing软件测试网jJ e7g,g'V#A?

  可能有的弟兄会说我想不输入用户的密码就能切换到root并运行SYDCMDDSKCMD下的命令,那应该把把NOPASSWD:加在哪里为好?理解下面的例子吧,能明白的;

/A7K1Bu|O2|?[%f0

  SYSADER ALL= NOPASSWD: SYDCMD, NOPASSWD: DSKCMD51Testing软件测试网FX0TV:kRK[f+b

  5/etc/sudoers其它的未尽事项;51Testing软件测试网5~4U.?!i8v,};B-w

  在授权规则中,还有NOEXEC:EXEC的用法,自己查man sudoers了解;还有关于在规则中通配符的用法,也是需要了解的。这些内容不多说了,毕竟只是一个入门性的文档。soduers配置文件要多简单就有多简单,要多难就有多难,就看自己的应用了。

TAG:

 

评分:0

我来说两句

Open Toolbar