Ssh
pam_ssh_agent_auth:sudo 要求 ssh user@host 輸入密碼,但 ssh user@host ‘bash’ 不是
我使用 gpg-agent 來管理 ssh-agent。
在我的 PC 上:
ssh-add -L
列印我在伺服器上使用的公鑰。ForwardAgent
開了。pam.d/sudo
並sudoers
進行了配置。之後
ssh user@host
,echo $SSH_AUTH_SOCK
列印 gpg-agent 之一。如果執行sudo -i
或其他命令帶有sudo
,它會詢問密碼。如果使用
ssh user@host 'bash'
或其他shell,則sudo
無需詢問密碼即可執行。順便說一下,這個方法不會列印任何shell的提示,比如$
.設置
pam.d/sudo
,auth ... debug
並獲取日誌:Nov 10 16:46:23 nixos sudo[30150]: pam_ssh_agent_auth: Beginning pam_ssh_agent_auth for user vonfry Nov 10 16:46:23 nixos sudo[30150]: pam_ssh_agent_auth: Attempting authentication: `vonfry' as `vonfry' using ~/.ssh/authorized_keys:~/.ssh/authorized_keys2:/etc/ssh/authorized_keys.d/%u Nov 10 16:46:23 nixos sudo[30150]: pam_ssh_agent_auth: Contacted ssh-agent of user vonfry (1000) Nov 10 16:46:23 nixos gpg-agent[4022]: scdaemon[4022]: pcsc_establish_context failed: no service (0x8010001d) Nov 10 16:46:23 nixos sudo[30150]: pam_ssh_agent_auth: Failed Authentication: `vonfry' as `vonfry' using ~/.ssh/authorized_keys:~/.ssh/authorized_keys2:/etc/ssh/authorized_keys.d/%u
在伺服器上,
gpg-agent
在我的 ssh 登錄使用者擁有的 htop 中列出並且gpg-connect-agent
可以工作。TTY
並且GPG_TTY
是相同的。
htop
顯示gpg-agent
有一個子程序scdaemon --multi-server
我試圖四處搜尋
gpg-agent[4022]: scdaemon[4022]: pcsc_establish_context failed: no service (0x8010001d)
,但沒有任何用處。EDIT1:如果我殺死 ssh 登錄使用者的 gpg-agent 守護程序,sudo 可以在沒有密碼的情況下工作。
我找到原因了。我的互動式 shell 腳本從 sshd 重新導出
SSH_AUTH_SOCK
覆蓋原始變數的變數。