20.5. IdM 클라이언트에서 서비스 계정으로 명령을 실행하는 CLI에서 sudo 규칙 생성
IdM에서 RunAs 별칭 을 사용하여 sudo 규칙을 구성하여 다른 사용자 또는 그룹으로 sudo 명령을 실행할 수 있습니다. 예를 들어 데이터베이스 애플리케이션을 호스팅하는 IdM 클라이언트가 있을 수 있으며 해당 애플리케이션에 해당하는 로컬 서비스 계정으로 명령을 실행해야 합니다.
이 예제를 사용하여 run_ third-party-app_report 라는 명령줄에 sudo 규칙을 생성하여 호스트에서 idm client/opt/ third-party-app/bin/report 명령을 사용하여 /opt/ third-party-app /report 명령을 실행할 수 있습니다.
사전 요구 사항
- IdM 관리자로 로그인되어 있습니다.
-
IdM에
idm_user사용자 계정을 생성하고 사용자의 암호를 생성하여 계정 잠금을 해제했습니다. CLI를 사용하여 새 IdM 사용자를 추가하는 방법에 대한 자세한 내용은 명령줄을 사용하여 사용자 추가를 참조하십시오. -
idmclient호스트에 로컬idm_user계정이 없습니다.idm_user사용자는 로컬/etc/passwd파일에 나열되지 않습니다. -
idmclient호스트에타사-app이라는 사용자 지정 애플리케이션이 설치되어 있어야 합니다. -
타사-앱 애플리케이션의
보고서명령은/opt/디렉터리에 설치됩니다.third-party-app/bin/report -
third-party-app애플리케이션에 대한 명령을 실행하기 위해thirdpartyapp이라는 로컬 서비스 계정을 생성했습니다.
프로세스
IdM
관리자로Kerberos 티켓을 검색합니다.[root@idmclient ~]# kinit adminsudo명령의 IdM 데이터베이스에/opt/ third-party-app/bin/report명령을 추가합니다.[root@idmclient ~]# ipa sudocmd-add /opt/third-party-app/bin/report ---------------------------------------------------- Added Sudo Command "/opt/third-party-app/bin/report" ---------------------------------------------------- Sudo Command: /opt/third-party-app/bin/reportrun_ third-party-app_report라는sudo규칙을 만듭니다.[root@idmclient ~]# ipa sudorule-add run_third-party-app_report -------------------------------------------- Added Sudo Rule "run_third-party-app_report" -------------------------------------------- Rule name: run_third-party-app_report Enabled: TRUE--users= <user> 옵션을 사용하여sudorule-add-runasuser명령에 대해 RunAs 사용자를 지정합니다.[root@idmclient ~]# ipa sudorule-add-runasuser run_third-party-app_report --users=thirdpartyapp Rule name: run_third-party-app_report Enabled: TRUE RunAs External User: thirdpartyapp ------------------------- Number of members added 1 -------------------------로컬 서비스 계정 또는 Active Directory 사용자와 같이 IdM 외부에 있는 사용자(또는
--groups=*옵션으로 지정된 그룹)가 될 수 있습니다. 그룹 이름에%접두사를 추가하지 마십시오.run_/ third-party-app/report 명령을 추가합니다.third-party-app_report규칙에 /opt[root@idmclient ~]# ipa sudorule-add-allow-command run_third-party-app_report --sudocmds '/opt/third-party-app/bin/report' Rule name: run_third-party-app_report Enabled: TRUE Sudo Allow Commands: /opt/third-party-app/bin/report RunAs External User: thirdpartyapp ------------------------- Number of members added 1 -------------------------run_ third-party-app_report규칙을 IdMidmclient호스트에 적용합니다.[root@idmclient ~]# ipa sudorule-add-host run_third-party-app_report --hosts idmclient.idm.example.com Rule name: run_third-party-app_report Enabled: TRUE Hosts: idmclient.idm.example.com Sudo Allow Commands: /opt/third-party-app/bin/report RunAs External User: thirdpartyapp ------------------------- Number of members added 1 -------------------------run_ third-party-app_report규칙에idm_user계정을 추가합니다.[root@idmclient ~]# ipa sudorule-add-user run_third-party-app_report --users idm_user Rule name: run_third-party-app_report Enabled: TRUE Users: idm_user Hosts: idmclient.idm.example.com Sudo Allow Commands: /opt/third-party-app/bin/report RunAs External User: thirdpartyapp ------------------------- Number of members added 1
서버에서 클라이언트로 변경 사항을 전파하는 데 몇 분이 걸릴 수 있습니다.
검증
-
idmclient호스트에idm_user계정으로 로그인합니다. 새 sudo 규칙을 테스트합니다.
idm_user계정에서 수행할 수 있는sudo규칙을 표시합니다.[idm_user@idmclient ~]$ sudo -l Matching Defaults entries for idm_user@idm.example.com 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@idm.example.com may run the following commands on idmclient: (thirdpartyapp) /opt/third-party-app/bin/reportreport명령을타사app서비스 계정으로 실행합니다.[idm_user@idmclient ~]$ sudo -u thirdpartyapp /opt/third-party-app/bin/report [sudo] password for idm_user@idm.example.com: Executing report... Report successful.