git仓库从http链接转为ssh
阅读原文
为了方便我们经常会使用http或者https协议去clone远程仓库。
git clone https://github.com/Name/project
如果你是用了类似IDEA这样的集成工具,可能你输入一次密码后就不需要再次输入了,应为他替你进行了后续的验证。
如果单纯的使用git,那么每次pull和push都需要输入密码,是非常麻烦的
那么如何将http协议clone的本地仓库修改为ssh的呢?
解决办法
1.确定你的git已设置用户名和邮箱
git config --global user.name "YourName"
git config --global user.email "email@mail.com"
2.查看你的home目录下是否已经生成过ssh-key
ll ~/.ssh
如果目录不存在或者没有看到id_rsa和id_rsa.pub这两个文件(注:id_rsa为默认创建名字)
新建一个ssh-key
ssh-keygen -t rsa -C "email@mail.com"
注:请确保email地址相同
3.向你的远程git仓库加入你的公钥(注:gitea、gitlab、github一般在用户的设置页面添加,如果远程是通过git init初始化的项目,请追加到远程机器的~/.ssh/authorized_keys 文件中)
cat .~/ssh/id_rsa.pub
4.转换本地连接远程git的地址(注:这也是git clone http://xxx.com和git clone git@xxx.com的区别,使用本方法节省删除文件以及从新克隆的时间)
在你git clone项目后,只需将.git/config文件中
url = http://xxx.com/Name/project.git
改为
url = git@xxx.com/Name/project.git
即可。
5.测试你的ssh-key
ssh -T git@xxx.com