博客
关于我
github ssh密钥配置
阅读量:704 次
发布时间:2019-03-17

本文共 1205 字,大约阅读时间需要 4 分钟。

GitHub SSH 配置指南

在使用GitHub时,如果你经常通过命令行操作项目,使用HTTPS克隆仓库确实非常方便。但如果你更喜欢使用SSH协议,配置一个SSH密钥可以让你避免每次都输入账号密码,这会大大提升工作效率。

为什么选择SSH协议

很多开发者都在问,为什么不是所有人都用SSH克隆GitHub仓库?这主要是因为:

  • 对于初学者而言:HTTPS URL直接复制到git bash中使用clone命令,操作简单直观。
  • 配置门槛:使用SSH协议前需要先生成并添加SSH密钥,虽然这可能会让部分用户感到麻烦,但对于习惯命令行操作的开发者来说,这是一条值得走的路。

需要注意的是,只有仓库的拥有者或拥有push权限的用户才能添加SSH密钥。


HTTPS和SSH的区别

  • 克隆权限

    • HTTPS可以被任何用户使用,无需权限。
    • SSH协议需要你是仓库的拥有者或管理员,且必须预先添加SSH密钥。
  • 密码输入

    • HTTPS在push时需要输入GitHub账号和密码。
    • SSH协议不需要输入账号,但如果在生成SSH密钥时设置了密码,push时仍需输入该密码。

  • 设置Git用户信息

    在开始SSH配置之前,建议先配置Git的用户名和邮箱。这样可以让你的 commit 记录更清晰。

    # 查看当前配置
    git config --list
    # 配置用户名和邮箱(推荐使用全局配置)
    git config --global user.name "你的名字"
    git config --global user.email "你的邮箱"

    SSH密钥配置步骤

    1. 检查现有SSH密钥

    cd ~/.ssh

    检查是否存在 id_rsaid_rsa.pub 文件。如果没有,可以继续下一步。

    2. 生成新的SSH密钥

    ssh-keygen -t rsa -C "你的邮箱"
    • -t rsa:生成RSA类型的密钥(常用且安全)。
    • -C:指定密钥注释,建议填写你的GitHub邮箱。

    生成完成后,.ssh 目录下会有两个文件:

    • id_rsa:私有密钥,安全地存放在本地。
    • id_rsa.pub:公开密钥,用于GitHub添加。

    3. 获取SSH公钥内容

    cat ~/.ssh/id_rsa.pub

    复制这行内容即可。

    4. 将SSH公钥添加到GitHub

    登录GitHub后,点击右上角的头像,选择 Settings

    • 在左侧菜单中选择 SSH and GPG settings
    • 点击 Add a new SSH key,然后粘贴公钥内容。

    5. 验证配置

    ssh -T git@github.com
    • 如果是第一次连接,系统会提示验证host密钥是否可信。输入 yes 确认。
    • 成功登录后,GitHub会显示欢迎信息,表明身份验证成功。

    通过以上步骤,你已经成功配置了GitHub的SSH密钥,接下来就可以无需输入账号密码直接克隆仓库了!

    转载地址:http://yapez.baihongyu.com/

    你可能感兴趣的文章
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>
    MySQL 数据库备份种类以及常用备份工具汇总
    查看>>