博客
关于我
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/

    你可能感兴趣的文章
    mysql5.7安装
    查看>>
    mysql5.7性能调优my.ini
    查看>>
    MySQL5.7新增Performance Schema表
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Webpack 之 basic chunk graph
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>