在Ubuntu系統中實現SSH無密碼登錄,通常需要使用SSH密鑰對進行身份驗證。以下是詳細步驟:
首先,在本地機器上生成SSH密鑰對。打開終端并運行以下命令:
ssh-keygen -t rsa -b 4096
-t rsa 指定使用RSA算法。-b 4096 指定密鑰長度為4096位。運行上述命令后,系統會提示你輸入保存密鑰的位置和文件名。默認情況下,密鑰會保存在 ~/.ssh/id_rsa(私鑰)和 ~/.ssh/id_rsa.pub(公鑰)。
你可以直接按回車鍵接受默認位置和文件名,或者指定其他位置和文件名。
接下來,將生成的公鑰復制到遠程服務器的 ~/.ssh/authorized_keys 文件中。你可以使用 ssh-copy-id 命令來完成這一操作:
ssh-copy-id user@remote_host
其中:
user 是你在遠程服務器上的用戶名。remote_host 是遠程服務器的IP地址或域名。運行上述命令后,系統會提示你輸入遠程服務器用戶的密碼。輸入密碼后,公鑰會被復制到遠程服務器的 ~/.ssh/authorized_keys 文件中。
確保遠程服務器的SSH配置允許使用公鑰認證。編輯遠程服務器上的 /etc/ssh/sshd_config 文件:
sudo nano /etc/ssh/sshd_config
找到并確保以下行沒有被注釋掉(即沒有以 # 開頭):
PubkeyAuthentication yes
保存并退出編輯器,然后重啟SSH服務以應用更改:
sudo systemctl restart sshd
現在,你應該可以從本地機器無密碼登錄到遠程服務器了。嘗試以下命令:
ssh user@remote_host
如果一切配置正確,你應該能夠直接登錄到遠程服務器,而不需要輸入密碼。
~/.ssh 目錄和 ~/.ssh/authorized_keys 文件的權限正確。通常,~/.ssh 目錄的權限應為 700,~/.ssh/authorized_keys 文件的權限應為 600。chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys
通過以上步驟,你應該能夠在Ubuntu系統中實現SSH無密碼登錄。