博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【linux is not Unix】linux账户管理和用户组管理
阅读量:2242 次
发布时间:2019-05-09

本文共 12392 字,大约阅读时间需要 41 分钟。

概要:

Linux是个多用户多任务的分时操作系统,所有一个要使用系统资源的用户都必须先向系统管理员申请一个账号,然后以这个账号的身份进入系统。用户的账号一方面能帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也能帮助用户组织文件,并为用户提供安全性保护。每个用户账号都拥有一个惟一的用户名和用户口令。用户在登录时键入正确的用户名和口令后,才能进入系统和自己的主目录。

 

实现用户账号的管理,要完成的工作主要有如下几个方面:

a.用户账号的添加、删除和修改。

b.用户口令的管理。

c.用户组的管理。

一、Linux用户账号的管理

 

用户账号的管理主要涉及到用户账号的添加、删除和修改。

1、添加用户账号

就是在系统中创建一个新账号,然后为新账号分配用户号、用户组、主目录和登录Shell等资源。刚添加的账号是被锁定的,无法使用。

语法格式:

语法:useradd选项用户名

1)其中各选项含义如下:

-c comment指定一段注释性描述。

-d目录指定用户主目录,如果此目录不存在,则同时使用-m选项,能创建主目录。

-g用户组指定用户所属的用户组。

-G用户组,用户组指定用户所属的附加组。

-s Shell文件指定用户的登录Shell

-u用户号指定用户的用户号,如果同时有-o选项,则能重复使用其他用户的标识号。

-p这个命令是需求提供md5码的加密口令,普通数字是不行的。

 

2)用户名的解释:指定新账号的登陆名

 

    

举例说明:     

1

# useradd -d /usr/cheng -m cheng

 

此命令创建了一个用户cheng,其中-d-m选项用来为登录名cheng产生一个主目录/usr/cheng/usr为默认的用户主目录所在的父目录)。

2

# useradd -s /bin/sh -g group -G adm,root jin

 

此命令新建了一个用户jin,该用户的登录Shell/bin/sh,他属于group用户组,同时又属于admroot用户组,其中group用户组是其主组。

 

PsLinux提供了集成的系统管理工具userconf,他能用来对用户账号进行统一管理。增加用户账号其实就是在/etc/passwd文件中为新用户增加一条记录,同时更新其他系统文件,如/etc/shadow/etc/group等。另外用户帐户本身在 /etc/passwd 中定义。但是linux用户都可以查看/etc/passwd文件。因此,如果把此账号的密码也放到/etc/passwd文件中的话,就有可能泄密,为了解决此问题Linux系统包含一个 /etc/passwd的同伴文件,叫做 /etc/shadow。该文件不像 /etc/passwd,只有对于 root 用户来说是可读的,并且包含加密的密码信息。

我们来看一看 /etc/shadow的一个样本行:

admin:$6$ RFOgtPTDq1R7SKQkScoYKXpb5owB6iZkSpQMdLSRoIJ.Zhr7i/:17384:0:99999:7:::

每一行给一个特别帐户定义密码信息,同样的,每个字段用“:”隔开。

 

  字段 1定义和这个shadow条目相关联的特别用户帐户。

  字段 2包含一个加密的密码。

   字段 3 1/1/1970起,密码被修改的天数

   字段 4密码将被允许修改之前的天数(0表示“可在所有时间修改”)

   字段 5系统将强制用户修改为新密码之前的天数(1表示“永远都不能修改”)

   字段 6密码过期之前,用户将被警告过期的天数(-1表示“没有警告”)

   字段 7密码过期之后,系统自动禁用帐户的天数(-1表示“永远不会禁用”)

   字段 8该帐户被禁用的天数(-1表示“该帐户被启用”)字段9保留供将来使用

2、删除帐号

如果一个用户账号不再使用,能从系统中删除。删除用户账号就是要将/etc/passwd等系统文件中的该用户记录删除,必要时还要删除用户的主目录。删除一个已有的用户账号使用userdel命令。

语法格式:

userdel选项用户名

常用的选项是-r,他的作用是把用户的主目录一起删除。其中选项可以省略,表示仅仅删除用户,不删除用户目录。

 

举例说明:

# userdel -r cheng

此命令删除用户cheng在系统文件(主要是/etc/passwd/etc/shadow/etc/group等)中的记录,同时删除用户的主目录。

3、修改帐号

修改用户账号就是根据实际情况更改用户的有关属性,如用户号、主目录、用户组、登录Shell等。

修改已有用户的信息使用usermod命令。

语法格式:

usermod选项用户名

 

常用的选项包括-c,-d,-m,-g,-G,-s,-u,-o等,这些选项的意义和useradd命令中的相同,能为用户指定新的资源值

-c comment指定一段注释性描述。

-d目录指定用户主目录,如果此目录不存在,则同时使用-m选项,能创建主目录。

-g用户组指定用户所属的用户组。

-G用户组,用户组指定用户所属的附加组。

-s Shell文件指定用户的登录Shell

-u用户号指定用户的用户号,如果同时有-o选项,则能重复使用其他用户的标识号。

-p这个命令是需求提供md5码的加密口令,普通数字是不行的。

-l 这个选项指定一个新的账号,即将原来的用户名改为新的用户名。

Ps:只有终极管理员才有权限修改帐号名,如果用sudo命令来对普通帐号授权也行

举例说明:

1

# usermod -s /bin/ksh -d /home/z -gdeveloper cheng

此命令将用户cheng的登录Shell修改为ksh,主目录改为/home/z,用户组改为developer

2

#usermod zte1 -g cheng

#此命令是改动用户zte1所属的组为cheng这个组

4、查看帐号属性

语法格式:

id user1 显示user1uidgid ,缺省为当前用户的id信息

举例说明:

1

#Id zte

uid=1011(zte)gid=100(users) groups=100(users),14 (uucp),16(dialout),17(audio),33(video)

groupsuser1 显示用户user1所在的组,缺省为当前用户所在的组信息

2

 groups users

uucp dialout audio video(缺省)

二、Linux用户口令的管理

用户管理的一项重要内容是用户口令的管理。用户账号刚创建时没有口令,是被系统锁定的,无法使用,必须为其指定口令后才能使用,即使是空口令也可以。

指定和修改用户口令的Shell命令是passwdroot用户能为自己和其他用户指定口令,普通用户只能修改自己的口令。

语法格式:

passwd选项用户名

可使用的选项:

-l锁定口令,即禁用账号。

-u口令解锁。

-d使账号无口令。

-f强迫用户下次登录时修改口令。

举例说明:

1

假设当前用户是cheng,则下面的命令修改该用户自己的口令:

$ passwd

Old password:******

New password:*******

Re-enter new password:*******

如果是root用户,能用下列形式指定任意用户的口令:

# passwd cheng

New password:*******

Re-enter new password:*******

解释:

普通用户修改自己的口令时,passwd命令会先询问原口令,验证后再需求用户输入两遍新口令,如果两次输入的口令一致,则将这个口令指定给用户;而root用户为用户指定口令时,就不必知道原口令。为了安全起见,用户应该选择比较复杂的口令,最佳使用不少于8位的口令,口令中包含有大写、小写字母和数字,并且应该和姓名、生日等不相同。

为用户指定空口令时,执行下列形式的命令:

2

# passwd -d cheng

解释:

此命令将用户cheng的口令删除,这样用户cheng下一次登录时,系统就不再询问口令。

3

# passwd -l cheng

解释:

passwd命令用-l(lock)选项锁定某一用户,使其不能登录。

 

补充1/etc/passwd文件

/etc/passwd文件是用户管理工作涉及的最重要的一个文件。Linux系统中的每个用户都在/etc/passwd文件中有一个对应的记录行,他记录了这个用户的一些基本属性。这个文件对所有用户都是可读的。他的内容类似下面的例子:

cat /etc/passwd

root:x:0:0:Superuser:/:

daemon:x:1:1:System daemons:/etc:

bin:x:2:2:Owner of system commands:/bin:

sys:x:3:3:Owner of system files:/usr/sys:

adm:x:4:4:System accounting:/usr/adm:

uucp:x:5:5:UUCP administrator:/usr/lib/uucp:

auth:x:7:21:Authentication administrator:/tcb/files/auth:

cron:x:9:16:Cron daemon:/usr/spool/cron:

listen:x:37:4:Network daemon:/usr/net/nls:

lp:x:71:18rinter administrator:/usr/spool/lp:

cheng:x:200:50:Cheng san:/usr/cheng:/bin/sh

 

从上面的例子我们能看到,/etc/passwd中一行记录对应着一个用户,每行记录又被冒号分隔为7个字段,

七个字段表示含义如下:

用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录Shell

解释:

用户名

1)“用户名”是代表用户账号的字符串。通常长度不超过8个字符,并且由大小写字母和/或数字组成。登录名中不能有冒号,因为冒号在这里是分隔符。为了兼容起见,登录名中最佳不要包含点字符“.”,并且不使用连字符“-”和加号“+”打头。

口令

2“口令”,一些系统中存放着加密后的用户口令,虽然这个字段存放的只是用户口令的加密串,不是明文,不过由于/etc/passwd文件对所有用户都可读,所以这仍是个安全隐患。因此,目前许多Linux系统都使用了shadow技术,把真正的加密后的用户口令字存放到/etc/shadow文件中,而在/etc/passwd文件的口令字段中只存放一个特别的字符,例如“x”或“*”。

用户标识号

3)“用户标识号”是个整数,系统内部用他来标识用户。一般情况下他和用户名是一一对应的。如果几个用户名对应的用户标识号是相同的,系统内部将把他们视为同一个用户,不过他们能有不同的口令、不同的主目录及不同的登录Shell等。通常用户标识号的取值范围是 0655350是终极用户root的标识号,199由系统保留,作为管理账号,普通用户的标识号从100开始。在Linux系统中,这个界限是 500

组标识号

4)“组标识号”字段记录的是用户所属的用户组。他对应着/etc/group文件中的一条记录。

注释性描述

5“注释性描述”字段记录着用户的一些个人情况,例如用户的真实姓名、电话、地址等,这个字段并没有什么实际的用途。在不同的Linux系统中,这个字段的格式并没有统一。在许多Linux系统中,这个字段存放的是一段任意的注释性描述文字,用做finger命令的输出。

主目录

6)“主目录”,也就是用户的起始工作目录,他是用户在登录到系统之后所处的目录。在大多数系统中,各用户的主目录都被组织在同一个特定的目录下,而用户主目录的名称就是该用户的登录名。各用户对自己的主目录有读、写、执行(搜索)权限,其他用户对此目录的访问权限则根据具体情况设置。

登录shell

7)用户登录后,要启动一个进程,负责将用户的操作传给内核,这个进程是用户登录到系统后运行的命令解释器或某个特定的程式,即ShellShell是用户和Linux系统之间的接口。 LinuxShell有许多种,每种都有不同的特点。常用的有sh(Bourne Shell),csh(C Shell),ksh(Korn Shell),tcsh(TENEX/TOPS-20 type C Shell),bash(Bourne Again Shell)等。系统管理员能根据系统情况和用户习惯为用户指定某个Shell。如果不指定Shell,那么系统使用sh为默认的登录Shell,即这个字段的值为/bin/sh

补充2/etc/shadow文件

由于 /etc/passwd文件是所有用户都可读的,如果用户的密码太简单或规律比较明显的话,一台普通的计算机就能够非常容易地将他破解,因此对安全性需求较高的Linux系统都把加密后的口令字分离出来,独立存放在一个文件中,这个文件是/etc/shadow文件。只有终极用户才拥有该文件读权限,这就确保了用户密码的安全性。

/etc/shadow中的记录行和/etc/passwd中的一一对应,他由pwconv命令根据/etc/passwd中的数据自动产生。他的文件格式和/etc/passwd类似,由若干个字段组成,字段之间用“:”隔开。这些字段含义如下:

登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

 

 

登录名

“登录名”是和/etc/passwd文件中的登录名相一致的用户账号

口令

“口令”字段存放的是加密后的用户口令字,长度为13个字符。如果为空,则对应用户没有口令,登录时不必口令;如果含有不属于集合{ ./0-9A-Za-z }中的字符,则对应的用户不能登录。

 

最后一次修改时间

“最后一次修改时间”表示的是从某个时刻起,到用户最后一次修改口令时的天数。时间起点对不同的系统可能不相同。例如在SCO Linux中,这个时间起点是197011日。

 

最小时间间隔

“最小时间间隔”指的是两次修改口令之间所需的最小天数。

最大时间间隔

“最大时间间隔”指的是口令保持有效的最大天数。

警告时间

“警告时间”字段表示的是从系统开始警告用户到用户密码正式失效之间的天数。

不活动时间

“不活动时间”表示的是用户没有登录活动但账号仍能保持有效的最大天数。

失效时间

“失效时间”字段给出的是个绝对的天数,如果使用了这个字段,那么就给出相应账号的生存期。期满后,该账号就不再是个合法的账号,也就不能再用来登录了。

 

下面是/etc/shadow的一个例子:

cat /etc/shadow

rootnakfw28zf38w:8764:0:168:7:::

daemon:*::0:0::::

bin:*::0:0::::

sys:*::0:0::::

adm:*::0:0::::

uucp:*::0:0::::

nuucp:*::0:0::::

auth:*::0:0::::

cron:*::0:0::::

listen:*::0:0::::

lp:*::0:0::::

cheng:EkdiSECLWPdSa:9740:0:0::::

 

三、Linux用户组的管理

每个用户都有一个用户组,系统能对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同,如Linux下的用户属于和他同名的用户组,这个用户组在创建用户时同时创建。用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就对/etc/group文件的更新。

用户组(group)就是具有相同特征的用户(user)的集合体;比如有时我们要让多个用户具有相同的权限,比如查看、修改某一文件或执行某个命令,这时我们需要用户组,我们把用户都定义到同一用户组,我们通过修改文件或目录的权限,让用户组具有一定的操作权限,这样用户组下的用户对该文件或目录都具有相同的权限,这是我们通过定义组和修改文件的权限来实现的。

举例说明:

我们为了让一些用户有权限查看某一文件,比如是个时间表,而编写时间表的人要具有读写执行的权限,我们想让一些用户知道这个时间表的内容,而不让他们修改,所以我们能把这些用户都划到一个组(用chgrp命令),然后来修改这个文件(用chmod命令)的权限,让用户组可读(用chgrp命令将此文件归属于这个组),这样用户组下面的每个用户都是可读的,其他用户是无法访问的。

1、增加用户组

语法格式:

groupadd选项用户组[用户组添加后,将用户进行组赋予用chownchgrp指令]

选项有:

-g GID指定新用户组的组标识号(GID)。

-o一般和-g选项同时使用,表示新用户组的GID能和系统已有用户组的GID相同。

举例说明:

1

# groupadd group1

解释:

此命令向系统中增加了一个新组group1,新组的组标识号是在当前已有的最大组标识号的基础上加1

2

# groupadd -g 101 group2

解释:

此命令向系统中增加了一个新组group2,同时指定新组的组标识号是101

2、删除用户组

语法格式:

groupdel用户组

例如:

# groupdel group1

此命令从系统中删除组group1

3、修改用户组属性

语法格式:

groupmod选项用户组

常用的选项有:

-g GID为用户组指定新的组标识号。

-o-g选项同时使用,用户组的新GID能和系统已有用户组的GID相同。

-n新用户组将用户组的名字改为新名字

举例说明:

1

# groupmod -g 102 group2

此命令将组group2的组标识号修改为102

2

# groupmod -g 10000 -n group3 group2

此命令将组group2的标识号改为10000,组名修改为group3

4、用户组切换

如果一个用户同时属于多个用户组,那么用户能在用户组之间转换,以便具有其他用户组的权限。用户能在登录后,使用命令newgrp转换到其他用户组,这个命令的参数就是目的用户组。

语法格式:

Newgrp用户组

举例说明:

例如:

$ newgrp root

这条命令将当前用户转换到root用户组,前提条件是root用户组确实是该用户的主组或附加组。

补充1/etc/group文件

用户组的所有信息都存放在/etc/group文件中。

将用户分组是Linux系统中对用户进行管理及控制访问权限的一种手段。每个用户都属于某个用户组;一个组中能有多个用户,一个用户也能属于不同的组。当一个用户同时是多个组中的成员时,在/etc/passwd文件中记录的是用户所属的主组,也就是登录时所属的默认组,而其他组称为附加组。用户要访问属于附加组的文件时,必须首先使用newgrp命令使自己成为所要访问的组中的成员。用户组的所有信息都存放在/etc/group文件中。此文件的格式也类似于/etc/passwd文件,由冒号隔开若干个字段,这些字段有:

组名:口令:组标识号:组内用户列表

 

解释:

组名

“组名”是用户组的名称,由字母或数字构成。和/etc/passwd中的登录名相同,组名不应重复。

口令

“口令”字段存放的是用户组加密后的口令字。一般Linux系统的用户组都没有口令,即这个字段一般为空,或是*

 

组标识号

“组标识号”和用户标识号类似,也是个整数,被系统内部用来标识组。

组内用户列表

“组内用户列表”是属于这个组的所有用户的列表,不同用户之间用逗号“,”分隔。这个用户组可能是用户的主组,也可能是附加组。

 

/etc/group文件的一个例子如下:

# cat /etc/group

root::0:root

bin::2:root,bin

sys::3:root,uucp

adm::4:root,adm

daemon::5:root,daemon

lp::7:root,lp

users::20:root,cheng

 

四、伪账户

系统中有一类用户称为伪用户(psuedousers),这些用户在/etc/passwd文件中也占有一条记录,不过不能登录,因为他们的登录Shell为空。他们的存在主要是方便系统管理,满足相应的系统进程对文件属主的需求。常见的伪用户如下所示。

bin拥有可执行的用户命令文件

sys拥有系统文件

adm拥有帐户文件

uucp UUCP使用

lp lplpd子系统使用

nobody NFS使用

除了上面列出的伪用户外,更有许多标准的伪用户,例如:audit,cron,mail,usenet等,他们也都各自为相关的进程和文件所需要。

五、赋予普通用户特别权限

Linux系统中,管理员往往不止一人,若每位管理员都用root身份进行管理工作,根本无法弄清晰谁该做什么。所以最佳的方式是:管理员创建一些普通用户,分配一部分系统管理工作给他们。

由于su对转换到终极权限用户root后,权限的无限制性,所以su并不能担任多个管理员所管理的系统。如果用su来转换到终极用户来管理系统,也不能明确哪些工作是由哪个管理员进行的操作。特别是对于服务器的管理有多人参和管理时,最佳是针对每个管理员的技术特长和管理范围,并且有针对性的下放给权限,并且约定其使用哪些工具来完成和其相关的工作,这时我们就有必要用到 sudo

通过sudo,我们能把某些终极权限有针对性的下放,并且不必普通用户知道root密码,所以sudo相对于权限无限制性的su来说,还是比较安全的,所以sudo也能被称为受限制的su;另外sudo是需要授权许可的,所以也被称为授权许可的susudo执行命令的流程是当前用户转换到root(或其他指定转换到的用户),然后以root(或其他指定的转换到的用户)身份执行命令,执行完成后,直接退回到当前用户;而这些的前提是要通过sudo的设置文件/etc/sudoers来进行授权;

我们不能使用su让他们直接变成root,因为这些用户都必须知道root的密码,这种方法非常不安全,而且也不符合我们的分工需求。一般的做法是利用权限的设置,依工作性质分类,让特别身份的用户成为同一个工作组,并设置工作组权限。例如:要wwwadm这位用户负责管理网站数据,一般Apache Web Server的进程httpd的所有者是www,你能设置用户wwwadmwww为同一工作组,并设置Apache默认存放网页录 /usr/local/httpd/htdocs的工作组权限为可读、可写、可执行,这样属于此工作组的每位用户就能进行网页的管理了。

但这并不是最佳的解决办法,例如管理员想授予一个普通用户关机的权限,这时使用上述的办法就不是非常最佳。这时你也许会想,我只让这个用户能以root身份执行 shutdown命令就行了。完全没错,可惜在通常的Linux系统中无法实现这一功能,不过已有了工具能实现这样的功能。

sudo通过维护一个特权到用户名映射的数据库将特权分配给不同的用户,这些特权可由数据库中所列的一些不同的命令来识别。为了获得某一特权项,有资格的用户只需简单地在命令行输入sudo和命令名之后,按照提示再次输入口令。例如,sudo允许普通用户格式化磁盘,不过却没有赋予其他的root用户特权。

注:sudo的初衷是:为了让一个普通用户执行root的命令。当第一次使用sudo的时候会提示输入密码。这个密码是用户自己的密码。

sudo的语法;

授权用户主机=[(转换到哪些用户或用户组)][是否需要密码验证]命令1,[(转换到哪些用户或用户组)] [是否需要密码验证] [命令2],[(转换到哪些用户或用户组)] [是否需要密码验证] [命令3]......

注:

凡是[ ]中的内容,是能省略;命令和命令之间用,号分隔。在[(转换到哪些用户或用户组)],如果省略,则默认为root用户;如果是ALL,则代表能转换到所有用户;注意要转换到的目的用户必须用()号括起来,比如(ALL)(beinan)

1sudo工具由文件/etc/sudoers进行设置,该文件包含所有能访问sudo工具的用户列表并定义了他们的特权。一个典型的/etc/sudoers条目如下:

zte ALL=(ALL) ALL

这个条目使得用户zte作为终极用户访问所有应用程式,如用户zte需要作为终极用户运行命令,他只需简单地在命令前加上前缀sudo。因此,要以root用户的身份执行命令ifconfigzte能输入如下命令:

# sudo /usr/sbin/ifconfig

注意:执行的ifconfig命令要写绝对路径/usr/sbin/ifconfig/usr/sbin默认不在普通用户的搜索路径中,或加入此路径:PATH=$PATH:/usr/sbin;export PATH。另外,不同系统命令的路径不尽相同。能使用命令“whereis命令名”来查找其路径。ex : zte@SMPS-WEB1:/home> whereis usermod

usermod: /usr/sbin/usermod /usr/share/man/man8/usermod.8.gz ,这里搜索到2个路径,取第一个.表示在zte用户登录下查看usermod命令的具体路径

这时会显示下面的输出结果:

We trust you have received the usuallecture from the local System

Administrator. It usually boils down tothese two things:

#1) Respect the privacy of others.

#2) Think before you type.

Password:

如果zte正确地输入了他的口令,命令ifconfig将会以root用户身份执行。

注意:设置文件/etc/sudoers必须使用命令Visudo来编辑。

只要把相应的用户名、主机名和许可的命令列表以标准的格式加入到文件/etc/sudoers,并保存就能生效,再看一个例子。

举例说明:

[1]管理员需要允许jin用户在主机sun上执行rebootshutdown命令,在/etc/sudoers中加入:

jin sun=/usr/sbin/reboot/usr/sbin/shutdown

注意:命令一定要使用绝对路径,以避免其他目录的同名命令被执行,从而造成安全隐患。

然后保存退出,jin用户想执行reboot命令时,只要在提示符下运行下列命令:

$ sudo /usr/sbin/reboot

输入正确的密码,就能重启服务器了。

[2]beinan ALL=(root) /bin/chown, /bin/chmod

表示的是beinan能在所有可能出现的主机名的主机中,能转换到root下执行 /bin/chown,能转换到所有用户招执行/bin/chmod命令,通过sudo -l来查看beinan在这台主机上允许和禁止运行的命令。

[3]beinan ALL=(root) NOPASSWD:/bin/chown,/bin/chmod

表示的是beinan能在所有可能出现的主机名的主机中,能转换到root下执行 /bin/chown,不必输入beinan用户的密码;并且能转换到所有用户下执行/bin/chmod命令,但执行chmod时需要beinan输入自己的密码;通过sudo -l 来查看beinan在这台主机上允许和禁止运行的命令;

关于一个命令动作是不是需要密码,我们能发目前系统在默认的情况下是需要用户密码的,除非特加指出不必用户需要输入自己密码,所以要在执行动作之前加入NOPASSWD:参数;

[4]取消程式某类程式的执行,要在命令动作前面加上!号;在本例中也出现了通配符的*的用法;

beinanALL=/usr/sbin/*,/sbin/*,!/usr/sbin/fdisk注:把这行规则加入到/etc/sudoers中;但你得有beinan这个用户组,并且beinan也是这个组中的才行;本规则表示beinan用户在所有可能存在的主机名的主机上运行/usr/sbin/sbin下所有的程式,但fdisk程式除外;

[beinan@localhost ~]$ sudo -l

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

User beinan may run the following commandson this host:

(root) /usr/sbin/*

(root) /sbin/*

(root) !/sbin/fdisk

[beinan@localhost ~]$ sudo /sbin/fdisk -l

Sorry, user beinan is not allowed toexecute ’/sbin/fdisk -l’ as root on localhost.

注:不能转换到root用户下运行fdisk程式;

[5]如果你想对一组用户进行定义,能在组名前加上%,对其进行设置,如:

%cuug ALL=(ALL) ALL

那么属于cuug这个组的所有成员都能sudo来执行特定的任务

3sudo命令还能加上一些参数,完成一些辅助的功能,如:

$ sudo -l

会显示出类似这样的信息:

User liming may run the following commandson this host:

(root) /usr/sbin/reboot

说明root允许用户liming执行/usr/sbin/reboot命令。这个参数能使用户查看自己目前能在sudo中执行哪些命令。

 



转载地址:http://nshbb.baihongyu.com/

你可能感兴趣的文章
一文了解强化学习
查看>>
CART 分类与回归树
查看>>
seq2seq 的 keras 实现
查看>>
seq2seq 入门
查看>>
什么是 Dropout
查看>>
用 LSTM 做时间序列预测的一个小例子
查看>>
用 LSTM 来做一个分类小问题
查看>>
详解 LSTM
查看>>
按时间轴简述九大卷积神经网络
查看>>
详解循环神经网络(Recurrent Neural Network)
查看>>
为什么要用交叉验证
查看>>
用学习曲线 learning curve 来判别过拟合问题
查看>>
用验证曲线 validation curve 选择超参数
查看>>
用 Grid Search 对 SVM 进行调参
查看>>
用 Pipeline 将训练集参数重复应用到测试集
查看>>
PCA 的数学原理和可视化效果
查看>>
机器学习中常用评估指标汇总
查看>>
什么是 ROC AUC
查看>>
Bagging 简述
查看>>
详解 Stacking 的 python 实现
查看>>