windows 中安装及使用 SSH Key
转自 简书技术博客:https://www.jianshu.com/p/a3b4f61d4747
- 联系管理员开通ssh功能;
- 重新创建环境;
- 下载工具包到本地机器wsCli 0.4
- 解压后,把相应的wsCli程序放在系统目录下(比如windows是C:\Windows下,linux/macOS放在/usr/local/bin下);
- 先安装git ,然后右键进入git bash
- 然后执行命令 , ssh-keygen -t rsa 生成 ssh key
- 将生成的id_rsa.pub的内容到 服务器 里并且 修改.ssh目录和相关文件的权限:
mkdir -p ~/.ssh echo "{你的id_rsa.pub中的所有内容}" >> ~/.ssh/authorized_keys chmod 700 ~/.ssh chmod 600 ~/.ssh/*
回到服务器首页,拷贝ssh连接开发环境命令,在你自己电脑上执行即可(windows可以在git-bash或mobaxterm里执行)
git
ssh
-
本地PC操作
- 打开git bash, 输入以下命令生成一对公私钥
ssh-keygen -t rsa
生成的文件有id_rsa(私钥)、id_rsa.pub(公钥)
- 打开git bash, 输入以下命令生成一对公私钥
-
远程git服务器
- 在用户主目录下,如用户名
wenzhu
,则在/home/wenzhu
目录下新建一个.ssh
(注意前面有个点) - 修改
.ssh
文件夹的权限为700chmod 700 .ssh
- 新建名为
authorized_keys
的文件,修改权限为600chmod 600 authorized_keys
- 将本地PC生成的公钥文件的内容复制到
authorized_keys
后面,这样就算配置完成了。 - 如果有新的PC需要连接该git服务器,按照步骤1生成公私钥,只需要将公钥复制到
authorized_keys
就可以了。
- 在用户主目录下,如用户名
-
使用SSH连接git服务器
可以使用以下客户端进行连接- SecureCRT是一个功能强大的终端仿真器,下载链接: http://securecrt-32bit.softonic.cn/
- putty是一个轻量级的SSH和Telnet客户端,下载链接:http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html
一、安装环境
1、本机系统:Windows 10 Pro(64位)
2、Git版本:Git-2.11.0-64-bit.exe(64位)
二、Git安装
去官网下载完后一路下一步完成安装,如下图:
安装完后先在系统环境变量中看下是否配置
然后在桌面右击鼠标,选择Git bash here,然后输入下面代码:
git --version #验证git是否安装成功,输出版本号就代表安装成功
如下图:
安装完成有配置一下全局的用户名和邮箱,输入如下命令:
git config --global user.name "自定义用户名"
git config --global user.email "邮箱"
使用如下命令可以取消全局设置:
git config --global --unset user.name
git config --global --unset user.email
三、Git生成单个SSH key及管理生成的多个SSH Key
1、生成单个SSH Key,输入下面的命令【命令说明】
ssh-keygen -t rsa -C "yourmail@gmail.com"
生成单个SSH Key时可以连续回车,不输入密钥文件名字和密码
生成后会在【C:\Users\用户名.ssh】下产生两个文件,如图:
2、管理git生成的多个ssh key
<strong>问题说明</strong>
当有多个git账号的时候,比如一个github,用于自己进行一些开发活动,再来一个gitlab,一般是公司内部的git。这两者你的邮箱如果不同的话,就会涉及到一个问题,生成第二个git的key的时候会覆盖第一个的key,导致必然有一个用不了。
<strong>解决方法</strong>
我们可以在【~/.ssh】目录下新建一个config文件配置一下,就可以解决问题
<strong>具体步骤</strong>
<ul><li>生成第一个ssh key(这里我用的是github的邮箱)</li></ul>
ssh-keygen -t rsa -C "yourmail@qq.com"
进入【C:\Users\用户名.ssh】,点击鼠标右键-选择Git bash here,这一步很重要,不然在下面输入密钥名称的时候,会将密钥生成在当前打开git bash的路径下,比如我在桌面打开的git bash,就会生成在桌面上,当然也可以在输入名称前将路径补全。如下图:
这里我没有一路【回车】而是给生成的密钥命名为【id_rsa_github】,下面连续两次回车,没有给密钥设置密码(看个人需求)
<ul><li>生成另一个ssh key(这里我用的公司邮箱)</li></ul>
ssh-keygen -t rsa -C "yourmail@glanway.com"
生成后的文件如下图所示:
<ul><li>执行ssh-agent命令</li></ul>
ssh-agent就是一个密钥管理器,运行ssh-agent以后,使用ssh-add将私钥交给ssh-agent保管,其他程序需要身份验证的时候可以将验证申请交给ssh-agent来完成整个认证过程
<ul><li>添加私钥</li></ul>
ssh-add ~/.ssh/id_rsa_github
ssh-add ~/.ssh/id_rsa_gitlab
在执行上面的添加私钥命令时,如果出现如下错误:
解决方法如下:
1、输入如下命令查看已开启的ssh-agent线程
ps aux | grep ssh
执行如下命令杀死线程:
kill -9 线程号
进入用户名目录下的.ssh目录,打开git bash,执行如下命令
exec ssh-agent bash
eval ssh-agent -s
ssh-add ./id_rsa_github
在执行【ssh-add ./id_rsa_gitlab】将第二个私钥添加进去
<ul><li>创建并修改config文件</li></ul>
1、创建config文件,将文件创建在【.ssh】目录下
①在windows下新建一个txt文本,然后将名字改成config(包括.txt后缀)
②在git bash下,直接touch config即可创建一个config文件
2、编辑config文件,修改如下内容:
# gitlab
Host gitool.glanway.com
HostName gitool.glanway.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_gitlab
User yangjie
# github
Host github.com
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_github
User yangjie
配置文件说明:
每个账号单独配置一个Host,每个Host要取一个别名,每个Host主要配置HostName和IdentityFile两个属性即可
Host的名字可以取为自己喜欢的名字,不过这个会影响git相关命令
例如:
Host mygithub 这样定义的话,命令如下,即git@后面紧跟的名字改为mygithub
git clone git@mygithub:PopFisher/AndroidRotateAnim.git
就相当于你配置的HostName真正的域名,映射成了Host后面的配置的名字
HostName #这个是真实的域名地址
IdentityFile #这里是id_rsa的地址
PreferredAuthentications #配置登录时用什么权限认证--可设置publickey,password publickey,keyboard-interactive等
User #配置使用用户名
【注意】不要在配置文件中添加下面这样的注释
HostName git.glanway.com //这里填你们公司的git网址即可
这种注释在读取该配置文件时会导致报错,不被识别
3、将公钥添加到github和gitlab上
4、测试
看到如下输出表示配置成功
ssh -T git@github.com #测试github
ssh -T git@gitool.glanway.com #测试gitlab
作者:指間的Coding
链接:https://www.jianshu.com/p/a3b4f61d4747
使用git的远程仓库,生成秘钥,遇到的问题
如何处理呢?
1.找到Git/usr/bin目录下的ssh-keygen.exe(如果找不到,可以在计算机全局搜索)
2.属性-->高级系统设置-->环境变量-->系统变量,找到Path变量,进行编辑,End到最后,输入分号,粘贴复制的ssh-keygen所在的路径,保存;
重新cmd,执行ssh-keygen,成功!
tips:如果不想添加到环境变量,只想临时使用,可以在Git/usr/bin目录下直接执行 ssh-keygen的命令,因为系统会优先在当前路径下查找ssh-keygen.exe
---------------------
原文:https://blog.csdn.net/zy_281870667/article/details/50443403