前言
之前用云服务器和GitHub的时候,因为比较懒一直没有配置过ssh。随着最近项目的迫在眉睫,通过Vs Code链接服务器和从GitHub白嫖代码的频率的大幅增加,拒绝接触新事物鼠鼠我只好转求ssh。此篇文章记录了我自己创建ssh密钥、配置ssh密钥的步骤。作为一个矫情的程序猿,主要目的是想记录自己的“幸福”技术生涯,但如果也能帮到看到此篇文章的同行者解决了问题,不胜荣幸!
什么是SSH
SSH(Secure Shell,安全外壳)是一种网络安全协议,通过加密和认证机制实现安全的访问和文件传输等业务。SSH协议通过对网络数据进行加密和验证,在不安全的网络环境中提供了安全的网络服务。有关SSH的具体介绍可以点击:什么是SSH?SSH是如何工作的? - 华为
直白来讲:SSH是一种协议,用来网络传输(如传输文件),安全。
GitHub克隆仓库
GitHub每次pull / push代码时要求推送代码的用户是合法的,所以每次推送时候都要输入账号密码用以验证用户是否为合法用户,而ssh是一种安全的传输模式,它会生成一组公钥和私钥,公钥配置在GitHub,私钥保存在自己电脑或服务器。每次pull / push时可以通过这组公钥/私钥的匹配来代替用户的这一“输入账号密码”的行为。
在GitHub上,我们通常有两种方式嫖代码:
-
https协议
可以随意克隆GitHub上的项目,而不管是谁的;在pull/push的时候是需要验证用户名和密码的。
-
ssh协议
在pull/push的时候不再是验证用户名和密码,而是通过验证ssh的方式来验证用户。
创建SSH
首先,我们需要确认自己是否已经拥有密钥。 默认情况下,用户的 SSH 密钥存储在其 ~/.ssh
目录下。 进入该目录并列出其中内容,便可以快速确认自己是否已拥有密钥:
Linux或类Linux系统下执行以下两句指令
cd ~/.ssh
ls
windows系统下执行以下两句命令
cd %USERPROFILE%\.ssh
dir
如果有如图两个文件,则说明已经拥有了ssh公钥/私钥对,文件后带.pub的是公钥,待会我们就要把其中的内容复制到GitHub。
假如很不幸,你并不拥有一对公钥/私钥,不用着急,请执行以下命令:
$ ssh-keygen -o
然后一路enter就行了,接着你就可以按照上面介绍的方法查看你已经生成的ssh公钥/私钥对了。
添加SSH
-
进入GitHub后,点击右上角的个人头像,进入Settings
-
在屏幕左侧,点击SSH and GPG keys
- 点击new ssh keys
-
添加公钥,具体见以下图片
- 确认,执行命令
$ ssh -T git@github.com
后记
如果对你有所帮助,还请点个赞再走捏。
AutoDL配置ssh——AutoDL帮助文档