前言
对于新入手或重装后的 VPS 配置密钥登录需要创建~/.ssh
目录、把公钥写入到~/.ssh/authorized_keys
、设置权限、禁用密码登录等操作,虽然都是很简单的基础操作,但过程麻烦且枯燥:
mkdir -p ~/.ssh
curl -fsSL https://github.com/P3TERX.keys >> ~/.ssh/authorized_keys
chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys
sudo sed -i "s@.*\(PasswordAuthentication \).*@\1no@" /etc/ssh/sshd_config
sudo service sshd restart
SSH 密钥一键配置脚本是一套用于简化 SSH 密钥配置过程的解决方案。使用它以上操作只需要一行命令:
bash <(curl -fsSL git.io/key.sh) -g P3TERX -d
语法及选项说明
bash <(curl -fsSL git.io/key.sh) [选项...] <参数>
-o
- 覆盖模式,必须写在最前面才会生效-g
- 从 GitHub 获取公钥,参数为 GitHub 用户名-u
- 从 URL 获取公钥,参数为 URL-f
- 从本地文件获取公钥,参数为本地文件路径-p
- 修改 SSH 端口,参数为端口号-d
- 禁用密码登录
使用方法
生成 SSH 密钥对
如果没有密钥需要先生成,执行以下命令后一路回车即可。
ssh-keygen -t ecdsa -b 521
TIPS: 此方法适用于 Windows 10 (1803后)的 PowerShell 或 WSL,Linux 发行版和 macOS 自带的终端,但不仅限于这些环境。科普: 521位的 ECDSA 密钥比起 RSA 密钥更安全且验证速度更快。
操作完后会在~/.ssh
目录中生两个密钥文件,id_ecdsa
为私钥,id_ecdsa.pub
为公钥。公钥就是我们需要安装在远程主机上的。
科普:~
符号代表用户主目录,俗称家目录。其路径与当前登陆的用户有关,在 Linux 中普通用户家目录的路径是/home/用户名
,而 root 用户是/root
。Windows 10 中路径是C:\Users\用户名
。在 macOS 中路径是/Users/用户名
。
安装公钥
从 GitHub 获取公钥
在 GitHub 密钥管理页面 添加公钥,比如我的用户名是P3TERX
,那么在主机上输入以下命令即可:
bash <(curl -fsSL git.io/key.sh) -g P3TERX
从 URL 获取公钥
把公钥上传到网盘,通过网盘链接获取公钥:
bash <(curl -fsSL git.io/key.sh) -u https://p3terx.com/key.pub
从本地文件获取公钥
通过 FTP 的方式把公钥传到 VPS 上,然后指定公钥路径:
bash <(curl -fsSL git.io/key.sh) -f ~/key.pub
覆盖模式
使用覆盖模式(-o
)将覆盖/.ssh/authorized_keys
文件,之前的密钥会被完全替换掉,选项必须写在最前面才会生效,比如:
bash <(curl -fsSL git.io/key.sh) -o -g P3TERX
或者
bash <(curl -fsSL git.io/key.sh) -og P3TERX
禁用密码登录
在确定使用密钥能正常登录后禁用密码登录:
bash <(curl -fsSL git.io/key.sh) -d
修改 SSH 端口
把 SSH 端口修改为2222
:
bash <(curl -fsSL git.io/key.sh) -p 2222
一键操作
安装密钥、修改端口、禁用密码登录一键操作:
bash <(curl -fsSL git.io/key.sh) -og P3TERX -p 2222 -d
本文作者:P3TERX
本文链接:https://p3terx.com/archives/ssh-key-installer.html
版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。非商业转载及引用请注明出处(作者、原文链接),商业转载请联系作者获得授权。
为啥我在服务器上生成了ECDSA 密钥,然后把它上传到onedrive上,通过网盘链接获取公钥,禁用密码登录,最后不能连上了耶
https://images.weserv.nl/?url=https://article.biliimg.com/bfs/article/f6bbc0bf589ea193e3ca89e53f96e9dfa9eecd23.png
目前脚本是没毛病的。你这个情况两种可能:一是你公钥和私钥搞混了,二是通过网盘链接获取到的内容不是公钥。
好像没有兼容 Alpine 系统
博主很感谢你的脚本,很好用, 想问下怎么修改其他设置,比如我的key文件名称不是默认的authorized_keys,好比是001.pub ,还有禁用UseDNS、GSSAPIAuthentication、 ,修改ClientAliveInterval值等,再次感谢博主的分享!
你说的这些设置要自己手动改,这个脚本没有涉及到这些。
另外是不是要把这个脚本(key.sh)上传到服务器上然后加参数执行
可以不用上传,示例中的命令是直接通过网络调用脚本。
l - 从本地文件获取公钥,参数为本地文件路径
"从本地文件获取公钥
通过 FTP 的方式把公钥传到 VPS 上,然后指定公钥路径:
bash <(curl -fsSL git.io/key.sh) -f ~/key.pub"
到底是-f还是-l呢 (。•ˇ‸ˇ•。)
-f
,上面选项说明写错了,下面示例是对的。大佬牛逼.