GitHub - 使用SSH进行连接

这篇具有很好参考价值的文章主要介绍了GitHub - 使用SSH进行连接。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


前言

有一个SSH密钥跟了我很多年,更换电脑也不曾更换它。它不需要额外输入密码就能用,我将它的公钥用在了诸多平台。虽然很方便,但是安全性差(指没有密码)和匿名性差(指同一公钥在不同平台可能被关联)。

于是,计划在保留已有SSH密钥的情况下,先新创建一个SSH密钥专门用于GitHub,并加上密码增加安全性,后续再逐步为其他平台创建。在实际操作过程中,遇到了一些问题并进行研究,在此记录一番,希望对你有所帮助。

注意,以下内容均是以GitHub使用SSH连接为例,分别讨论单个或多个SSH密钥的使用等问题。可能存在不完善或少许错误,欢迎留言评论补充或指正。

开发环境

  • MacOS: 14.3.1
  • SSH: OpenSSH_9.4p1

单个SSH密钥

如果不考虑匿名性,每台设备只维护单个SSH密钥用于各个平台是很轻松的,加上密码安全性也有一定的保障。GitHub使用SSH进行连接的步骤如下:

1.1. 生成SSH密钥

  1. 执行密钥创建命令
# 这是使用RSA算法生成
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
# 现在一般推荐使用安全性更高的Ed25519算法生成
ssh-keygen -t ed25519 -C "your_email@example.com"

your_email@example.com一般是GitHub上账号的电子邮件地址(来自GitHub官方文档的说法)。不过,这有个问题,一台设备上如果只管理一个SSH密钥,然后不同平台上的电子邮件地址又不一样,那该填什么?

先不管GitHub的说法,我们可以通过使用手册命令看看-C选项的含义:

man ssh-keygen

输出很长,这里只展示关于-C-c选项的内容(补充:-t选项是指定密钥类型):

...
-C comment
        Provides a new comment.
        
-c      Requests changing the comment in the private and public key
        files.  The program will prompt for the file containing the
        private keys, for the passphrase if the key has one, and for the
        new comment.
...

可见-C选项后面跟的只是注释,方便你标识这个密钥(标识用途或所有者等)。实测,直接填your_email@example.com也一切正常!而且这个注释是可以通过-c选项修改的,修改命令参考如下:

ssh-keygen -c -f ~/.ssh/id_ed25519

实测能修改成功,并且不需要更新已经添加到GitHub的公钥,注释信息并不会影响身份验证。所以,填什么请随意。

  1. 设置密钥存放路径
# RSA算法生成
Enter file in which to save the key (/Users/xxx/.ssh/id_rsa):
# Ed25519算法生成
Enter file in which to save the key (/Users/xxx/.ssh/id_ed25519):

建议直接按Enter键使用它已经给出的默认文件路径,具体原因请看后面无密码密钥部分的内容。

  1. 设置密钥密码
Enter passphrase (empty for no passphrase):

如果不使用密码可以直接按Enter键,不过建议使用密码。生成密钥成功后,可以参考以下命令新增/修改/删除密码:

ssh-keygen -p -f ~/.ssh/id_ed25519
  1. 生成密钥成功
Your identification has been saved in /Users/xxx/.ssh/id_rsa(或id_ed25519)
Your public key has been saved in /Users/xxx/.ssh/id_rsa.pub(或id_ed25519.pub)
The key fingerprint is: xxx your_email@example.com
The key's randomart image is: xxx

参考文档:

  • GitHub - 生成新SSH密钥

1.2. 添加SSH密钥

打开SSH and GPG keys页面,如果没有登录请先登录。点击[New SSH key]按钮添加SSH密钥:

githubssh,开发记录,github,ssh

  • Title:给密钥设置描述性标签,可以用于区分设备。当某个设备的私钥泄漏时,方便快速找到该设备的SSH密钥并删除
  • Key type:密钥类型,分为Authentication Key(身份验证)和Signing Key(提交签名),使用默认的身份验证类型即可
  • Key:前面生成的公钥,可以通过以下命令将公钥复制到剪贴板,也可以找到公钥文件(.pub扩展名)用文本程序打开复制
# 复制RSA算法生成的密钥
pbcopy < ~/.ssh/id_rsa.pub
# 复制Ed25519算法生成的密钥
pbcopy < ~/.ssh/id_ed25519.pub

由于添加密钥是敏感操作,GitHub一般会让你再次验证身份,参考Sudo 模式。

参考文档:

  • GitHub - 向你的帐户添加新的SSH密钥

1.3. 测试SSH连接

通过执行以下命令测试:

ssh -T git@github.com

一般会得到这样的输出:

The authenticity of host 'github.com (20.205.243.166)' can't be established.
ED25519 key fingerprint is SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU.
This key is not known by any other names.
Are you sure you want to continue connecting (yes/no/[fingerprint])? 

其中SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU是服务器的公钥指纹,用于验证服务器的身份。GitHub的SSH密钥指纹:

SHA256:uNiVztksCsDhcc0u9e8BujQXVUpKZIDTMczCvj3tD2s (RSA)
SHA256:p2QAMXNIC1TJYWeIOttrVc98/R1BUFWu3/LiyKgUfQM (ECDSA)
SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU (Ed25519)

确认公钥匹配后,输入yes完成身份验证,会自动在~/.ssh/known_hosts文件中保存已验证服务器信息,后续无需再次验证,除非服务器信息有变化。

如果密钥有密码,需要输入密码完成连接测试。

参考文档:

  • GitHub - 向你的帐户添加新的SSH密钥

2.1. 简化密钥密码输入

如果你的SSH密钥有设置密码,那么你会发现每次使用(例如执行git pull命令)都需要输入一遍密码,相当麻烦。那么有什么办法可以解决这个问题呢?

这就不得不提到SSH代理,将密钥添加到代理,只需要输一次密码,后续无需重复输入密码。先在~/.ssh路径下创建config文件(如果该文件不存在):

touch ~/.ssh/config

然后往里面添加配置:

Host github.com
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_ed25519
  • AddKeysToAgent:将密钥加入代理
  • UseKeychain:将密码存储在钥匙串
  • IdentityFile:指定密钥文件路径

配置后,只需要输入一次密码,密码会自动保存到钥匙串,打开钥匙串应用搜索SSH关键词可以找到存储记录。通过以下命令可以查看已经添加到SSH代理中的密钥:

ssh-add -l

当重启电脑后(也可以通过killall ssh-agent命令终止代理,在需要时会自动重启)马上查看SSH代理中的密钥,你会发现没有加载任何密钥:

The agent has no identities.

这时使用SSH连接(例如执行git pull命令),会自动添加密钥,也无需再输入密码。

关于配置中的Host,这里引出另一个问题,现在只维护单个密钥用于多个平台,按前面的配置,只有连接GitHub时能简化密码输入,其他平台还是每次都需要输入密码。

这很好解决,在config文件中参考前面的配置修改Host给其他平台也增加配置即可。需要注意一点,有些平台的Host可能类似这样的git.github.com,这时你要么完全按照这个配置,要么使用通配符*.github.com

如果平台多了,配置也挺麻烦的,本来只维护单个密钥就为了省事,那还有没有更省事的方法呢?肯定是有的,参考如下配置:

Host *
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_ed25519

参考文档:

  • GitHub - 将SSH密钥添加到ssh-agent

多个SSH密钥

1.1. 生成/添加/测试SSH密钥

参考前面单个SSH密钥的生成/添加/测试,除了设置密钥存放路径时需要重新命名区分已有的密钥文件外,操作基本一样。

我一般按照这个格式id_aaa.bbb命名,aaa是密钥类型(例如ed25519),bbb是平台标识(例如github)。按自己喜好命名,方便自己标识就行。

2.1. 简化密钥密码输入

参考前面单个SSH密钥的简化密码输入,可以针对不同平台配置不同的密钥文件:

Host github.com
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_ed25519.github
  
Host xxx.com
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_rsa.xxx

或者更简单点(不过都维护多个密钥了,应该很少这么做了吧):

Host *
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_ed25519
  
Host *
  AddKeysToAgent yes
  UseKeychain yes
  IdentityFile ~/.ssh/id_rsa

如果按照上方示例中的配置,会根据先后顺序匹配。例如id_ed25519密钥会被优先匹配,只有当匹配失败或密码错误,才会继续往下匹配。

无密码密钥

前面着重讲设有密码的密钥,那如果密钥不设置密码还需要配置吗?

这里先引出一个默认密钥文件的说法,默认密钥文件指使用默认名称命名并放在默认路径下的密钥。默认路径默认名称分别指:

  • 默认路径~/.ssh
  • 默认名称id_dsa | id_ecdsa | id_ecdsa_sk | id_ed25519 | id_ed25519_sk | id_rsa

进而引出:

  • 对于单个无密码密钥,只要属于默认密钥文件SSH会自动添加,无需再额外配置
  • 对于多个无密码密钥,不属于默认密钥文件的需要在config文件中配置,参考配置如下:
Host github.com
  IdentityFile ~/.ssh/id_ed25519.github

或许你会疑问,默认密钥文件的说法是怎么来的?

在已有密钥的情况下创建新密钥时,我发现自定义命名的密钥无法直接使用,同时将密钥名称改为默认名称后又可以了,所以合理猜测存在一些默认密钥文件会被SSH自动添加(无论密钥是否有密码,有密码的密钥不配置也能正常使用,只是需要输入密码)。

关于猜测的具体验证过程请看续篇:GitHub - 使用SSH进行连接(续)。

补充内容

除了通过配置config文件简化密码输入,还可以通过以下方法。

~/.bash_profile~/.zshrc文件末尾加上:

if ! ssh-add -l | grep -q "your_email@example.com"; then
    ssh-add --apple-use-keychain ~/.ssh/id_ed25519.github
fi

其中your_email@example.com是创建密钥时的注释(参考前面的密钥创建),~/.ssh/id_ed25519.github是密钥文件路径,请根据实际情况替换。

追加内容保存后,重新打开终端或用source命令使其生效。根据提示,首次输入密码后,后续无需再输入密码。

这个原理很简单,每当打开终端时,首先通过ssh-add -l命令获取已经添加到SSH代理中的密钥信息,然后根据密钥信息搜索是否包含特定注释信息,以此判断密钥是否已经被添加到SSH代理中,最后如果没添加则通过ssh-add --apple-use-keychain命令添加。

--apple-use-keychain的作用是将首次输入的密码存储到钥匙串中。补充一点,以前是用-K,现在已经被弃用。

注意,这个方法有个缺点,如果重启电脑后你没先打开终端触发自动加载密钥,那就不会加载。

例如重启电脑后,直接用Sourcetree软件执行Git相关操作,会报错。不过,Android Studio是例外,猜测可能是因为它启动时也启动了shell进程,触发了密钥加载。

简单验证一下猜测:删除钥匙串中保存的密钥密码,并且通过killall ssh-agent命令终止代理(清除已添加的密钥),重新启动Android Studio,随意打开一个项目,结果卡住了一会儿,还弹了警告:

githubssh,开发记录,github,ssh

Learn more按钮指向Shell Environment Loading文章。

同时内置终端卡在密钥密码输入。结合Learn more按钮指向的文章可知,Android Studio果然启动了shell进程,当遇到首次加载密钥需要输入密码时,会因为等待密码输入而卡住,直到等待超时。

最后

如果这篇文章对你有所帮助,点赞👍收藏🌟支持一下吧,谢谢~


本篇文章由@crasowas发布于CSDN。文章来源地址https://www.toymoban.com/news/detail-855885.html

到了这里,关于GitHub - 使用SSH进行连接的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vscode通过ssh连接github仓库(git+ssh+github+vscode详细步骤)

    首先我们先来了解一下什么是 ssh 和 github SSH(Secure Shell)是一种网络协议,用于在不安全的网络中安全地传输数据和执行远程命令。它提供了加密的通信通道,使得数据传输过程中不容易被窃听或篡改。 SSH 使用公钥加密和私钥解密的方式进行身份验证和数据传输。用户生成

    2024年01月25日
    浏览(59)
  • 在 GitHub 上设置 SSH 公钥连接

    最终效果图 在终端中执行以下命令,生成 SSH 密钥对: 在这里,替换 your_email@example.com 为您的 GitHub 关联邮箱。 运行以下命令将 SSH 密钥添加到 SSH 代理: 执行以下命令,将 SSH 公钥的内容复制到剪贴板: 1、登录到 GitHub 帐户。 2、转到您的 GitHub 主页。 3、点击右上角的用户

    2024年02月03日
    浏览(43)
  • mac本地创建ssh key连接github

    今天克隆自己github上面的笔记到新电脑上,用http连接进行克隆,然后要我输入账号密码,输入完报了个提示“remote: Support for password authentication was removed on August 13, 2021. Please use a personal access token instead.”,说是密码验证于2021年8月13日不再支持,那么就只能用ssh key的方式来连

    2024年02月13日
    浏览(43)
  • 如何在Ubuntu上进行GitHub ssh连接

    要在 Ubuntu 上使用 SSH 连接到 GitHub,您需要进行以下步骤: 生成 SSH 密钥对 :首先在您的本地机器上生成一个 SSH 密钥对。打开终端并运行以下命令: 上述命令将为您生成一个新的 ed25519 SSH 密钥对。当提示您输入要保存密钥的位置时,按 Enter 接受默认位置。然后,您将被提

    2024年02月10日
    浏览(42)
  • 解决git在使用代理时进行HTTPS操作时的无法连接github的解决办法

    问题如下: 在使用git clone 无法连接github的443端口。 解决问题: 首先查看自己的代理服务器使用的端口号(我这里的端口号是7890。) 使用指令 这条命令是在配置 Git 使用代理服务器进行 HTTPS 连接。具体来说,它设置了 Git 在进行 HTTPS 操作时(如 clone, fetch, pull 或 push 到使用

    2024年01月25日
    浏览(39)
  • github与idea连接及ssh秘钥生成

    (1)安装完git后,在开始菜单里面可以,看到如下,选择git cmd (2)按如下步骤生成秘钥,在打开的cmd中输入 ssh-keygen -t rsa -C \\\"your_email@example.com\\\" ,把邮箱换成你自己github注册用的邮箱,按回车,就会看到下面的步骤 输入密码后,显示如下图,就是成功了,这里的密码要牢记

    2024年02月12日
    浏览(44)
  • 搭建github-ssh连接时,Could not resolve hostname github的解决方案(无法ping通github)

    测试平台:Windows 10 测试时间: 2022年3月4日 问题描述: ​ 笔者在进行搭建本地 git 时,需要通过 ssh 建立与 github 的连接,在进行ssh连接验证时,出现如下提示 ​ 此时对目标地址进行 ping 操作如下 出现如下错误提示(git bash) windows的cmd 我没复制,但大致提示无法访问远程主机

    2023年04月08日
    浏览(40)
  • 14.(开发工具篇github)如何在Github配置ssh key

    上图表示已存在。跳第三步 拷贝第三步内容,保存

    2024年02月07日
    浏览(44)
  • git通过ssh代理连接github(gitee不支持),并更改端口

    需求 git clone github/gitee远程仓库,使用ssh协议,并且走本地的http代理(端口3128)。 运行环境是Ubuntu 20.04。 github使用ssh代理的方案 修改 ~/.ssh/config 文件: Hostname ssh.github.com 和 ProxyCommand nc -X connect -x 127.0.0.1:3128 %h %p 定义对服务器 github.com 的 ssh 调用应该重新路由到端口 3128 上的代

    2024年02月17日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包