# 前言
如果你想在本地的电脑上通过 ssh 命令连接云服务器,每次又懒得输入命令和服务器密码,希望能直接执行一个 shell 命令即可,那么本文可能会对你有些帮助
# 客户端生成公钥和私钥
在客户端运行命令
ssh-keygen -t rsa |
rsa 是一种常用的加密算法,还有一种加密算法是 dsa。
当在客户端执行这条命令时,会在 home 目录下的 .ssh 目录生成两把密钥,分别是私钥(id_rsa)和公钥(id_rsa.pub)。
私钥存在客户端,公钥存放在任何想要连接的服务器上。
在执行这条命令时,另一个需要设置的就是私钥的密码。如果想为了更加安全,这里需要设置一个妥当的密码,通过该密码来解开私钥连接服务器(目的就是防止黑客直接窃走私钥连接服务器)。但如果想图方便,这里可以直接回车默认,不设置私钥密码,出事了别找我呀嘿嘿
# 公钥保存至服务器
可以在客户端执行 scp 命令将公钥上传到服务器上
scp ~/.ssh/id_rsa.pub username@<ssh_server_ip>:~ |
然后通过 ssh 登录服务器
ssh username@<ssh_server_ip> |
在服务器上执行以下操作
cat id_rsa.pub >> ~/.ssh/authorized_keys |
完成配置。至此,在客户端执行 ssh 和 scp 命令时就无需输入服务器密码了(未设置私钥密码的情况下)。如果前面设置了私钥密码,在连接时还必须要输入私钥密码才能连接成功。
# ssh 命令
ssh -i ~/.ssh/id_rsa username@<ssh_server_ip> |
# scp 命令
scp -i ~/.ssh/id_rsa filename username@<ssh_server_ip>:~ |
如果将私钥放在 home 目录下的 .ssh 目录(默认就是),以上命令就可以省略 -i ~/.ssh/id_rsa