SSSD
外观
SSSD 是一个系统守护进程。其主要功能是通过一个通用框架提供对身份和身份验证远程资源的访问,该框架可以为系统提供缓存和离线支持。它提供 PAM 和 NSS 模块,未来还将提供基于 D-BUS 的接口以获取扩展的用户信息。它还提供了一个更好的数据库来存储本地用户以及扩展的用户数据。
安装
配置
LDAP
请参阅 LDAP authentication#SSSD configuration。
PAM 代理
如果您希望以非 root 用户身份运行的软件能够使用 pam_unix.so 进行身份验证,则可以通过创建以下文件,将 SSSD 配置为 PAM 代理来实现此目的。
/etc/sssd/sssd.conf
[sssd] services = pam domains = local [domain/local] id_provider = proxy proxy_lib_name = files proxy_pam_target = sssd-shadowutils
/etc/pam.d/sssd
#%PAM-1.0 auth required pam_sss.so account required pam_sss.so password required pam_sss.so session required pam_sss.so
现在,在您的软件配置中将 sssd 指定为 PAM 服务名。
以 root 身份运行 SSSD
注意 有关覆盖的负面影响,请参阅 archlinux/packaging/packages/sssd/#5。
SSSD 2.10 及更高版本默认以非 root 用户身份运行,但在此处需要以 root 身份运行才能访问 /etc/shadow。请按此方式 覆盖单元 sssd.service:
[Service]
Environment=DEBUG_LOGGER=--logger=files
EnvironmentFile=-/etc/sysconfig/sssd
ExecStartPre=+-/bin/chown -f root:sssd /etc/sssd
ExecStartPre=+-/bin/chown -f root:sssd /etc/sssd/sssd.conf
ExecStartPre=+-/bin/chown -f -R root:sssd /etc/sssd/conf.d
ExecStartPre=+-/bin/chown -f -R root:sssd /etc/sssd/pki
ExecStartPre=+-/bin/sh -c "/bin/chown -f root:sssd /var/lib/sss/db/*.ldb"
ExecStartPre=+-/bin/sh -c "/bin/chown -f root:sssd /var/lib/sss/gpo_cache/*"
ExecStartPre=+-/bin/sh -c "/bin/chown -f root:sssd /var/log/sssd/*.log"
ExecStart=/usr/bin/sssd -i ${DEBUG_LOGGER}
Type=notify
NotifyAccess=main
Restart=on-abnormal
CapabilityBoundingSet= CAP_CHOWN CAP_DAC_OVERRIDE CAP_SETGID CAP_SETUID CAP_DAC_READ_SEARCH
#SecureBits=noroot noroot-locked
User=root
Group=sssd
# If service configured to be run under "root", uncomment "SupplementaryGroups"
#SupplementaryGroups=sssd
请注意,SSSD 希望其文件(如 /var/log/sssd 和 /etc/sssd)具有与运行 SSSD 的用户相同的属主,因此您必须使用 chown 将这些文件改为 root 属主。此外,在 /etc/pacman.conf 中删除并添加 /usr/lib/tmpfiles.d/sssd-perms.conf 到 NoExtract,以防止 systemd-tmpfiles 恢复 SSSD 文件的权限。
最后,启用/启动 sssd.service。
技巧与提示
阻止空密码登录
如果使用 SSSD 作为 PAM 代理,默认情况下它允许使用空密码登录账户,这可能不理想。要解决此问题,请从 /etc/pam.d/sssd-shadowutils 中删除 nullok。
/etc/pam.d/sssd-shadowutils
#%PAM-1.0 auth [success=done ignore=ignore default=die] pam_unix.so try_first_pass auth required pam_deny.so account required pam_unix.so account required pam_permit.so
然后将该文件添加到 /etc/pacman.conf 的 NoUpgrade 中。