如何在CentOS的7加`cap_sys_admin`权限的用户?

Win*_*tor 11 linux pam permissions

我尝试向cap_sys_admin用户 myroot添加权限。

为此,我将这些行添加到/etc/security/capabilities

cap_sys_admin myroot
none *
Run Code Online (Sandbox Code Playgroud)

这条线到/etc/pam.d/su

auth            required        pam_cap.so
Run Code Online (Sandbox Code Playgroud)

但是用户 myroot 没有这些权限。

我该怎么做才能将这些权限添加到我的用户?

slm*_*slm 12

我相信该文件被称为/etc/security/capability.confnot /etc/security/capabilities。我能够像这样工作:

$ cat /etc/security/capability.conf
cap_sys_admin   user1
Run Code Online (Sandbox Code Playgroud)

然后添加pam_cap.so到 PAM。注意:必须在行pam_cap.so之前pam_rootok.so

$ cat /etc/pam.d/su
#%PAM-1.0
auth        optional    pam_cap.so
auth        sufficient  pam_rootok.so
...
...
Run Code Online (Sandbox Code Playgroud)

例子

如果我运行以下su命令,则上述内容已到位:

$ su - user1
Run Code Online (Sandbox Code Playgroud)

我可以验证这个用户的能力:

$ capsh --print
Current: = cap_sys_admin+i
Bounding set =cap_chown,cap_dac_override,cap_dac_read_search,cap_fowner,cap_fsetid,cap_kill,cap_setgid,cap_setuid,cap_setpcap,cap_linux_immutable,cap_net_bind_service,cap_net_broadcast,cap_net_admin,cap_net_raw,cap_ipc_lock,cap_ipc_owner,cap_sys_module,cap_sys_rawio,cap_sys_chroot,cap_sys_ptrace,cap_sys_pacct,cap_sys_admin,cap_sys_boot,cap_sys_nice,cap_sys_resource,cap_sys_time,cap_sys_tty_config,cap_mknod,cap_lease,cap_audit_write,cap_audit_control,cap_setfcap,cap_mac_override,cap_mac_admin,cap_syslog,35,36
Securebits: 00/0x0/1'b0
 secure-noroot: no (unlocked)
 secure-no-suid-fixup: no (unlocked)
 secure-keep-caps: no (unlocked)
uid=1001(user1)
gid=1001(user1)
groups=1001(user1)
Run Code Online (Sandbox Code Playgroud)

该输出中的关键行:

当前:= cap_sys_admin+i

套餐

这是在 CentOS 7.x 机器上完成的。我安装了这些与功能有关的软件包:

$ rpm -qa | grep libcap
libcap-ng-utils-0.7.5-4.el7.x86_64
libcap-2.22-9.el7.x86_64
libcap-ng-0.7.5-4.el7.x86_64
Run Code Online (Sandbox Code Playgroud)

它们在处理功能时提供了以下有用的工具:

$ rpm -ql libcap-ng-utils | grep /bin/
/usr/bin/captest
/usr/bin/filecap
/usr/bin/netcap
/usr/bin/pscap

$ rpm -ql libcap | grep /sbin/
/usr/sbin/capsh
/usr/sbin/getcap
/usr/sbin/getpcaps
/usr/sbin/setcap
Run Code Online (Sandbox Code Playgroud)

注意:如果您需要有关它们使用的更多信息,请参阅这些工具的相应手册页。

参考