另一种添加 ssh-key 到 authorized_keys 的方案。 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
InDom
V2EX    分享创造

另一种添加 ssh-key 到 authorized_keys 的方案。

  •  
  •   InDom 2024-01-11 14:55:20 +08:00 2904 次点击
    这是一个创建于 717 天前的主题,其中的信息可能已经有所发展或是发生改变。

    前几天那个利用 Github 进行加密聊天的,看到这个接口后,找到了一种新的应用。

    执行以下命令获取使用帮助:

    curl -s keys.qs5.org | sh

    本来是 OSS+CDN 的,考虑到 V2EX 上有一群小可爱,所以目前是放在 Github Pages 上,可能不是很快。

    简单来说,就是 curl https://github.com/{USER_ID}.keys >> ~/.ssh/authorized_keys 的封装。

    15 条回复    2024-01-13 11:13:08 +08:00
    totoro625
        1
    totoro625  
       2024-01-11 15:12:40 +08:00
    国外的很多云服务都支持 cloudinit 的
    你可以编辑一个新机器通用脚本,一键设置机器
    就算不支持 cloudinit ,你也可以复制粘贴执行
    selca
        2
    selca  
       2024-01-11 15:26:48 +08:00
    https://github.com/selcarpa/mountain/blob/master/scripts/init_pub_ssh.sh

    我也早就打包成一行来添加 key 了,还包含了检查文件是否存在
    hash
        3
    hash  
       2024-01-11 15:27:56 +08:00
    虽然很多时候 SSH 和 Git 使用不同 Key,
    但够用了
    weijancc
        4
    weijancc  
       2024-01-11 15:54:01 +08:00
    有点意思, 不过我自己是将公钥上传到 OSS, 然后 curl 复制 key, 用不上
    AirCrusher
        5
    AirCrusher  
       2024-01-11 19:51:42 +08:00
    请问一下,`https://github.com/{USER_ID}.keys`对应的私钥是哪个?
    SHF
        6
    SHF  
       2024-01-11 20:34:15 +08:00
    SHF
        7
    SHF  
       2024-01-11 20:37:00 +08:00   1
    加上这几个选项比较有用
    -s: 静默模式
    -S: 在发生错误时显示错误信息
    -L: 自动跟随重定向
    -f: 或 --fail 用于在发生 HTTP 错误时使 curl 终止执行,并返回非零的退出代码
    SHF
        8
    SHF  
       2024-01-11 20:39:08 +08:00
    @selca 添加 authorized_keys 不需要重启 sshd 服务吧?
    SHF
        9
    SHF  
       2024-01-11 20:40:06 +08:00
    类似还有一条命令安装 node.js 的

    curl -fsS https://shenhongfei.com/files/nodejs.sh | bash
    ratazzi
        10
    ratazzi  
       2024-01-11 21:53:45 +08:00 via iPhone
    ssh-import-id gh:github 用户名就好了
    imzcc
        11
    imzcc  
       2024-01-11 22:16:26 +08:00   3
    我是直接放 dns txt 记录上,然后用 dig 解析后面就类似了
    zhaojun1998
        12
    zhaojun1998  
       2024-01-12 08:48:58 +08:00
    看看这个,更全面:

    bash <(curl -fsSL git.io/key.sh) [选项...] <参数>

    -o - 覆盖模式,必须写在最前面才会生效
    -g - 从 GitHub 获取公钥,参数为 GitHub 用户名
    -u - 从 URL 获取公钥,参数为 URL
    -f - 从本地文件获取公钥,参数为本地文件路径
    -p - 修改 SSH 端口,参数为端口号
    -d - 禁用密码登录


    如下面的命令将禁止密码登录,拉取 github 用户公钥,修改 ssh 端口:
    bash <(curl -fsSL git.io/key.sh) -og zhaojun1998 -d -p 2233


    作者博客(不是我): https://p3terx.com/archives/ssh-key-installer.html
    duzhuo
        13
    duzhuo  
       2024-01-12 09:01:16 +08:00 via Android
    学习一个
    headwindx
        14
    headwindx  
       2024-01-13 10:47:37 +08:00
    ssh-copy-id 不够用吗?
    selca
        15
    selca  
       2024-01-13 11:13:08 +08:00
    @SHF #8 确实,我是让 ai 写的,所以,也没去详细调整
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5399 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 37ms UTC 01:41 PVG 09:41 LAX 17:41 JFK 20:41
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86