55.2. CLI를 사용하여 IdM 클라이언트의 IdM 사용자에게 sudo 액세스 권한 부여
IdM(Identity Management)에서는 특정 IdM 호스트의 IdM 사용자 계정에 대한 sudo
액세스 권한을 특정 명령에 부여할 수 있습니다. 먼저 sudo
명령을 추가한 다음 하나 이상의 명령에 대한 sudo
규칙을 만듭니다.
예를 들어 idm_user _reboot sudo
규칙을 생성하여 idmclient 시스템에서 /usr/sbin/reboot
명령을 실행할 수 있는 권한을 부여합니다.
사전 요구 사항
- IdM 관리자로 로그인했습니다.
- IdM에 idm_user 의 사용자 계정을 생성하고 사용자 암호를 생성하여 계정 잠금을 해제합니다. CLI를 사용하여 새 IdM 사용자를 추가하는 방법에 대한 자세한 내용은 명령줄을 사용하여 사용자 추가를 참조하십시오.
-
idmclient 호스트에 로컬 idm_user 계정이 없습니다. idm_user 사용자는 로컬
/etc/passwd
파일에 나열되지 않습니다.
절차
IdM
관리자로
Kerberos 티켓을 검색합니다.[root@idmclient ~]# kinit admin
/usr/sbin/reboot
명령을sudo
명령의 IdM 데이터베이스에 추가합니다.[root@idmclient ~]# ipa sudocmd-add /usr/sbin/reboot ------------------------------------- Added Sudo Command "/usr/sbin/reboot" ------------------------------------- Sudo Command: /usr/sbin/reboot
idm_user_reboot:라는
sudo
규칙을 만듭니다.[root@idmclient ~]# ipa sudorule-add idm_user_reboot --------------------------------- Added Sudo Rule "idm_user_reboot" --------------------------------- Rule name: idm_user_reboot Enabled: TRUE
/usr/sbin/reboot
명령을 idm_user_reboot 규칙에 추가합니다.[root@idmclient ~]# ipa sudorule-add-allow-command idm_user_reboot --sudocmds '/usr/sbin/reboot' Rule name: idm_user_reboot Enabled: TRUE Sudo Allow Commands: /usr/sbin/reboot ------------------------- Number of members added 1 -------------------------
IdM idmclient 호스트에 idm_user_reboot 규칙을 적용합니다.
[root@idmclient ~]# ipa sudorule-add-host idm_user_reboot --hosts idmclient.idm.example.com Rule name: idm_user_reboot Enabled: TRUE Hosts: idmclient.idm.example.com Sudo Allow Commands: /usr/sbin/reboot ------------------------- Number of members added 1 -------------------------
idm_user 계정을 idm_user_reboot 규칙에 추가합니다.
[root@idmclient ~]# ipa sudorule-add-user idm_user_reboot --users idm_user Rule name: idm_user_reboot Enabled: TRUE Users: idm_user Hosts: idmclient.idm.example.com Sudo Allow Commands: /usr/sbin/reboot ------------------------- Number of members added 1 -------------------------
선택적으로 idm_user_reboot 규칙의 유효성을 정의합니다.
sudo 규칙이 유효한 시간을 정의하려면
ipa
명령과sudo
rule-mod sudo_rule_name--setattr sudonotbefore=DATE
옵션을 사용합니다. DATE 값은 yyyymmddHHMMSSZ 형식을 따라야 하며, 초는 명시적으로 지정해야 합니다. 예를 들어, idm_user_reboot 규칙의 유효성 시작을 2025년 12월 31일 12:34:00으로 설정하려면 다음을 입력합니다.[root@idmclient ~]# ipa sudorule-mod idm_user_reboot --setattr sudonotbefore=20251231123400Z
sudo 규칙이 유효한 중지 시간을 정의하려면
--setattr sudonotafter=DATE
옵션을 사용합니다. 예를 들어, idm_user_reboot 규칙 유효 기간을 2026년 12월 31일 12:34:00으로 설정하려면 다음을 입력합니다.[root@idmclient ~]# ipa sudorule-mod idm_user_reboot --setattr sudonotafter=20261231123400Z
서버에서 클라이언트로 변경 사항을 전파하는 데 몇 분이 걸릴 수 있습니다.
검증 단계
- idmclient 호스트에 idm_user 계정으로 로그인합니다.
idm_user 계정에서 수행할 수 있는
sudo
규칙을 표시합니다.[idm_user@idmclient ~]$ sudo -l Matching Defaults entries for idm_user on idmclient: !visiblepw, always_set_home, match_group_by_gid, always_query_group_plugin, env_reset, env_keep="COLORS DISPLAY HOSTNAME HISTSIZE KDEDIR LS_COLORS", env_keep+="MAIL PS1 PS2 QTDIR USERNAME LANG LC_ADDRESS LC_CTYPE", env_keep+="LC_COLLATE LC_IDENTIFICATION LC_MEASUREMENT LC_MESSAGES", env_keep+="LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER LC_TELEPHONE", env_keep+="LC_TIME LC_ALL LANGUAGE LINGUAS _XKB_CHARSET XAUTHORITY KRB5CCNAME", secure_path=/sbin\:/bin\:/usr/sbin\:/usr/bin User idm_user may run the following commands on idmclient: (root) /usr/sbin/reboot
sudo
를 사용하여 시스템을 재부팅합니다. 메시지가 표시되면 idm_user 의 암호를 입력합니다.[idm_user@idmclient ~]$ sudo /usr/sbin/reboot [sudo] password for idm_user: