在管理Git项目上,不少时候都是直接使用https url克隆到本地,固然也有有些人使用SSH url克隆到本地。这两种方式的主要区别在于:使用https url克隆对初学者来讲会比较方便,复制https url而后到git Bash里面直接用clone命令克隆到本地就行了,可是每次fetch和push代码都须要输入帐号和密码,这也是https方式的麻烦之处。而使用SSH url克隆却须要在克隆以前先配置和添加好SSH key,所以,若是你想要使用SSH url克隆的话,你必须是这个项目的拥有者。不然你是没法添加SSH key的,另外ssh默认是每次fetch和push代码都不须要输入帐号和密码,若是你想要每次都输入帐号密码才能进行fetch和push也能够另外进行设置。前面的几篇介绍Git的博客里面采用的都是https的方式做为案例,今天主要是记录如何配置使用ssh方式来提交和克隆代码。git
步骤1:检查你的电脑上是否已经生成了SSH Key
在git bash下执行以下命令github
cd ~/.ssh ls
这两个命令就是检查是否已经存在id_rsa.pub或id_dsa.pub文件,若是文件已经存在,那么你能够跳过步骤2,直接进入步骤3。bash
步骤2:建立一个SSH Key
在git bash下执行以下命令服务器
ssh-keygen -t rsa -C "你的email地址"
代码参数含义:
-t指定密钥类型,默认是rsa,能够省略。
-C设置注释文字,好比邮箱。
-f指定密钥文件存储文件名。
以上命令省略了-f参数,所以,运行上面那条命令后会让你输入一个文件名,用于保存刚才生成的SSH key代码,如:
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/you/.ssh/id_rsa): [Press enter]
固然,你也能够不输入文件名,使用默认文件名(推荐),那么就会生成id_rsa和id_rsa.pub两个秘钥文件。
接着又会提示你输入两次密码(该密码是你push文件的时候要输入的密码,而不是github管理者的密码),固然,你也能够不输入密码,直接按回车。那么push的时候就不须要输入密码,直接提交到Git服务器上了,如:
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
接下来,就会显示以下一些提示,如:
Your identification has been saved in /c/Users/you/.ssh/id_rsa.
Your public key has been saved in /c/Users/you/.ssh/id_rsa.pub.
The key fingerprint is:
01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db 你的email地址
当你在Git Bash上看到这段显示的时候,那就说明,你的SSH key已经建立成功,你只须要添加到Git服务器上的SSH key上就能够了。ssh
步骤3:添加SSH Key到Git服务器
这个因为不一样的Git服务器,在界面添加的区域不同,因此不作详述,具体参照不一样Git服务器本身的操做。
经历了以上的三个步骤以后,你就能够愉快的使用SSH URL的方式来提交和克隆项目的代码了,而且不须要再频繁的输入帐号密码,若是你以前已经一直使用https方式进行开发,当前想要切换成为ssh方式进行开发,只须要执行以下几步的操做便可:ide
git remote rm origin git remote add origin "Git仓库的ssh格式地址" git push origin
在管理Git项目上,不少时候都是直接使用https url克隆到本地,固然也有有些人使用SSH url克隆到本地。这两种方式的主要区别在于:使用https url克隆对初学者来讲会比较方便,复制https url而后到git Bash里面直接用clone命令克隆到本地就行了,可是每次fetch和push代码都须要输入帐号和密码,这也是https方式的麻烦之处。而使用SSH url克隆却须要在克隆以前先配置和添加好SSH key,所以,若是你想要使用SSH url克隆的话,你必须是这个项目的拥有者。不然你是没法添加SSH key的,另外ssh默认是每次fetch和push代码都不须要输入帐号和密码,若是你想要每次都输入帐号密码才能进行fetch和push也能够另外进行设置。前面的几篇介绍Git的博客里面采用的都是https的方式做为案例,今天主要是记录如何配置使用ssh方式来提交和克隆代码。fetch
步骤1:检查你的电脑上是否已经生成了SSH Key
在git bash下执行以下命令ui
cd ~/.ssh ls
这两个命令就是检查是否已经存在id_rsa.pub或id_dsa.pub文件,若是文件已经存在,那么你能够跳过步骤2,直接进入步骤3。url
步骤2:建立一个SSH Key
在git bash下执行以下命令spa
ssh-keygen -t rsa -C "你的email地址"
代码参数含义:
-t指定密钥类型,默认是rsa,能够省略。
-C设置注释文字,好比邮箱。
-f指定密钥文件存储文件名。
以上命令省略了-f参数,所以,运行上面那条命令后会让你输入一个文件名,用于保存刚才生成的SSH key代码,如:
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/you/.ssh/id_rsa): [Press enter]
固然,你也能够不输入文件名,使用默认文件名(推荐),那么就会生成id_rsa和id_rsa.pub两个秘钥文件。
接着又会提示你输入两次密码(该密码是你push文件的时候要输入的密码,而不是github管理者的密码),固然,你也能够不输入密码,直接按回车。那么push的时候就不须要输入密码,直接提交到Git服务器上了,如:
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
接下来,就会显示以下一些提示,如:
Your identification has been saved in /c/Users/you/.ssh/id_rsa.
Your public key has been saved in /c/Users/you/.ssh/id_rsa.pub.
The key fingerprint is:
01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db 你的email地址
当你在Git Bash上看到这段显示的时候,那就说明,你的SSH key已经建立成功,你只须要添加到Git服务器上的SSH key上就能够了。
步骤3:添加SSH Key到Git服务器
这个因为不一样的Git服务器,在界面添加的区域不同,因此不作详述,具体参照不一样Git服务器本身的操做。
经历了以上的三个步骤以后,你就能够愉快的使用SSH URL的方式来提交和克隆项目的代码了,而且不须要再频繁的输入帐号密码,若是你以前已经一直使用https方式进行开发,当前想要切换成为ssh方式进行开发,只须要执行以下几步的操做便可:
git remote rm origin git remote add origin "Git仓库的ssh格式地址" git push origin