Linux中國
如何實現 ssh 無密碼登錄
首先,你需要以用戶「aliceA」的身份登錄到hostA上。
然後,使用ssh-keygen生成一對rsa公私鑰,生成的密鑰對會存放在~/.ssh目錄下。
$ ssh-keygen -t rsa
接下來,使用下面的命令在目標主機hostB上的aliceB用戶目錄下創建~/.ssh目錄。如果在aliceB@hostB上已經存在.ssh目錄,這一步會被略過。
$ ssh aliceB@hostB mkdir -p .ssh
最後,將hostA上用戶「aliceA」的公鑰拷貝到aliceB@hostB上,來實現無密碼ssh。
$ cat .ssh/id_rsa.pub | ssh aliceB@hostB 'cat >> .ssh/authorized_keys'
自此以後,從aliceA@hostA上ssh到aliceB@hostB上再也不需要輸入密碼。(LCTT 譯註:上述的創建目錄並複製的操作也可以通過一個 ssh-copy-id 命令一步完成:ssh-copy-id -i ~/.ssh/id_rsa.pub aliceB@hostB
)
疑難解答
- 即使在密鑰認證生效後,你可能仍然需要輸入SSH密碼。如果遇到這種情況,請檢查系統日誌(如/var/log/secure)以查看是否出現下面的異常。
Authentication refused: bad ownership or modes for file /home/aliceB/.ssh/authorized_keys
在這種情況下,密鑰認證的失敗是由於~/.ssh/authorized_keys文件的許可權或擁有者不正確。一般情況,如果這個文件對除了你之外的所有用戶都可讀,就會出現這個錯誤。用下面的方式改變文件的許可權以修正錯誤。
$ chmod 700 ~/.ssh/authorized_keys
via: http://xmodulo.com/how-to-enable-ssh-login-without.html
作者:Dan Nanni 譯者:KayGuoWhu 校對:wxy
本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive
對這篇文章感覺如何?
太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
More in:Linux中國
如何通過 VLC 使用字幕
使用 VLC 媒體播放器播放和管理字幕的新手指南。
Unix 桌面:在 Linux 問世之前
僅僅開源還不足以實現開放,還需開放標準和建立共識。
Valve 對於 Ubuntu 的 Snap 版本的 Steam 並不滿意:原因何在
你可能會發現,Snap 版本的 Steam 並不如你期待的那樣好,你怎麼看?
Wine 9.0 發布,實驗性地加入了 Wayland 驅動
Wine 的這個新版本正在為未來做好準備!