场景:
公司内部使用自建的gitlab
同时自己项目在github上
多个id_rsa生成和正常的一样 ssh-keygen -t rsa
生成完成后会在用户目录下的.ssh
目录下生成一个id_rsa
以及id_rsa.pub
分别为私钥和公钥(上一步可以更改生成的名称)
git默认会使用id_rsa对应的私钥
当同时使用gitlab和github时,原则上应该使用不同的私钥(虽然可以图省事用一样的)。
这时候应该生成另一对公私钥,如id_rsa2
在.ssh/config
里使用如下的配置
# gitlab Host gitlab.com HostName gitlab.com User git PreferredAuthentications publickey IdentityFile ~/.ssh/id_rsa # github Host github.com HostName github.com User git PreferredAuthentications publickey IdentityFile ~/.ssh/id_rsa2 ProxyCommand connect -S 127.0.0.1:1080 %h %p
这样ssh会根据域名不同选用不同的私钥
这时又有一个问题,gitlab在内网中,直接访问会很快;而github在国外,一般要挂上代理才能有一个不错的速度。
因此不能直接开全局代理
在上面的配置里有ProxyCommand connect -S 127.0.0.1:1080 %h %p
一行,这个就是配置针对github使用socks5代理
其中,connect是git自带的一个工具,-S
代表socks5,-H
代表http
显然,我们修改的是ssh的配置文件,因此这里针对的是走ssh协议的情况(也即远程分支为git@github.com/xxx
)的情况
有时候可能会使用https协议进行传输,这时候要在git设置里进行如下设置:
git config --global http.proxy socks5h://127.0.0.1:1080 git config --global http.https://github.com.proxy socks5h://127.0.0.1:1080
前者是对所有的域名、后者则是仅针对github协议
参考