如何在客户端实现ssh的免密登录?

我受够了记 IP 和密码,于是用 Rust 写了一个 SSH 管家

管理 10 台服务器后,我终于把 ssh user@10.0.0.1 -p 2222 -i ~/.ssh/some_key 缩减成了 sk prod


你每天在重复什么?

bash 复制代码
ssh root@192.168.1.100 -p 2222
# 输入密码...
# 密码错了,再来
ssh root@192.168.1.100 -p 2222 -i ~/.ssh/keys/prod_key
# 等等,这个服务器是哪个 key 来着?
cat ~/.ssh/config
# ...

管理 5 台以上的服务器,每次连接都要回忆 IP、端口、用户名、密钥文件路径。更别提换电脑后重新配置的噩梦。

sk:一条命令解决

bash 复制代码
# 添加一次
sk add prod -H 192.168.1.100 -u root -p MyPassword

# 之后每天只需
sk prod

没了。就这两个命令。

它做了什么?

sk add 做了 5 件事:

  1. 测试连接(连不上直接拒绝,不写入无效配置)
  2. 写入标准 ~/.ssh/config(你仍然可以用 ssh prod
  3. 加密存储密码到系统钥匙串
  4. 记住你的 IP、端口、用户名
  5. 下次 sk prod 自动使用存储的凭据

sk prod 做了 1 件事:

把你连到服务器。不提示密码,不要求记 IP,不让你选密钥文件。就一个字:快。

不只是密码

如果你的服务器已经配置了免密登录:

bash 复制代码
# 用已有密钥
sk add prod -H 10.0.0.1 -u root -i ~/.ssh/prod_key

# 或者让 sk 帮你生成密钥并推送到服务器
sk add prod -H 10.0.0.1 -u root -k

日常管理

bash 复制代码
sk list                    # 所有服务器一览
sk test prod               # 测试连通性
sk remove prod staging     # 批量删除
sk doctor                  # 健康检查
sk completion install      # 一键开启 Tab 补全

安全吗?

  • 密码存储在系统钥匙串(macOS Keychain / Windows Credential Manager / Linux Secret Service)
  • 降级方案使用 AES-256-GCM + Argon2id(19MB 内存成本防暴力破解)
  • 密钥绑定到机器指纹------密码文件复制到其他机器无法解密
  • 纯 ssh2 协议实现,不依赖外部 ssh 二进制

安装

bash 复制代码
cargo install --git https://github.com/scliangx/sk.git

需要 Rust 1.70+ 和 OpenSSH 客户端。macOS / Linux / Windows 全平台支持。

10 秒 vs 3 秒

复制代码
传统方式:
  $ ssh root@192.168.1.100 -p 2222 -i ~/.ssh/prod_key
  (回忆 IP → 回忆端口 → 回忆密钥路径 → 总共 10+ 秒)

sk 方式:
  $ sk prod
  (3 秒,包括 SSH 握手时间)

每天连接 20 次服务器,一个月省下 20 * 7 * 30 = 4200 秒 ≈ 70 分钟 。一年省下 14 小时

这还只是连接。算上添加、删除、测试、检查配置的时间,sk 省下的更多。

项目状态

sk 目前处于 v0.1.0 早期开发阶段。核心功能稳定(156 个测试覆盖),计划中的 sync 等功能还在开发。

欢迎 Star, Issue, PR。

GitHub: https://github.com/scliangx/sk

相关推荐
大树8818 小时前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠18 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质18 小时前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
开发者联盟league18 小时前
安装pnpm
ssh
Inhand陈工19 小时前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
星栈19 小时前
10 分钟跑起第一个 Dioxus 应用:`dx` CLI、`rsx!` 和热更新好不好用
前端·rust·前端框架
酣大智19 小时前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_20 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉20 小时前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
AC赳赳老秦21 小时前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw