当您在克隆或从远程仓库获取数据时,很可能因为网络状况不佳遇到很慢甚至超时的情况,那么此时您可能需要配置 Git 的代理。

Git 支持的传输协议以及判断(点击展开)

在此之前需要先提一下,Git 支持的传输协议有 ssh、git、http 和 https 协议(此外,ftp 和 ftps 也可用于拉取,但在 Git 官方文档中提到是低效且过时的,不建议使用)。

其原生传输协议(即 git:// URL)不做鉴权,在不安全的网络环境下应谨慎使用。

要如何分辨 Git 使用的传输协议呢?可以通过 Git URL 来进行判断:

  • ssh

    • ssh://[user@]host.xz[:port]/path/to/repo.git/  [user@]host.xz:path/to/repo.git/
  • git

    • git://host.xz[:port]/path/to/repo.git/
  • http / https

    • http[s]://host.xz[:port]/path/to/repo.git/
  • ftp / ftps

    • ftp[s]://host.xz[:port]/path/to/repo.git/

连接到 Git 仓库最常用的传输协议可以分为两类:

  • HTTP / HTTPS 传输协议
  • SSH 传输协议

  • 使用 HTTP / HTTPS 传输协议连接到 Git 仓库的 URL 实例如下:
COPYhttp://github.com/cms-sw/cmssw.git
https://github.com/cms-sw/cmssw.git
  • 使用 SSH 传输协议连接到 Git 仓库的 URL 实例如下:
COPYgit@github.com:cms-sw/cmssw.git
ssh://git@github.com/cms-sw/cmssw.git

预先准备

开始操作之前,你需要明确这些内容:

  • 电脑已经安装了 Git(这不是废话吗,23333)。如果你是 Windows 用户,那么本文的命令你需要通过 Git Bash 来执行;如果你是 Linux 或 macOS 用户直接在终端运行即可。
  • 知道如何用 vim 编辑文件,退出编辑的基本操作。

Git 使用 HTTP / HTTPS 传输协议的代理方法

针对 Git 使用 HTTP / HTTPS 传输协议的代理方法如下:

  • 针对所有域名的仓库
git config --global` **`http`**`.proxy <protocol>://<host>:<port>
命令注解(点击展开)
  • --glboal 选项指的是修改 Git 的全局配置文件 ~/.gitconfig(而非各个 Git 仓库里的配置文件 .git/config)。
  • <protocol> 指的是代理协议,如 http,https,socks5 等。
  • <host> 为代理主机,如使用本地代理主机 127.0.0.1 或 localhost 等。
  • <port> 则为代理端口号,如 clash 使用的 7890 或 7891 等。
  • 常见误用git config --global https.proxy <protocol>://<host>:<port>,这一写法完全是错误的。请记住: Git 代理配置项正确写法 http.proxy,并不支持 https.proxy 这一错误写法
  • 如果想了解 <url> 的更多模式,如子域名等的情况,可参照 Git 的官方文档 
  • 或者针对特定域名的仓库
git config --global` **`http`**`.<url>.proxy <protocol>://<host>:<port>
命令注解(点击展开)
  • --glboal 选项指的是修改 Git 的全局配置文件 ~/.gitconfig(而非各个 Git 仓库里的配置文件 .git/config)。
  • <url> 指的是你需要使用代理的远程仓库,该 <url> 支持 HTTP / HTTPS 传输协议的格式:
    • <url> 格式为 http://example.com  https://example.com
  • <protocol> 指的是代理协议,如 http,https,socks5 等。
  • <host> 为代理主机,如使用本地代理主机 127.0.0.1 或 localhost 等。
  • <port> 则为代理端口号,如 clash 使用的 7890 或 7891 等。
  • 常见误用:针对 HTTPS 传输协议(即 https:// 开头)的 <url> 代理,命令写成 “git config --global https.https://github.com.proxy protocol://127.0.0.1:7890” ,这一写法完全是错的。请记住:请记住: Git 代理配置项正确写法 http.<url>.proxy,并不支持 https.<url>.proxy 这一错误写法
  • 如果想了解 <url> 的更多模式,如子域名等的情况,可参照 Git 的官方文档 

实例

针对 Git 使用 HTTP / HTTPS 传输协议的代理方法,在 Windows,Linux,macOS 上用户的操作均是一样的。

也许你光看我上面的内容还看不明白,不妨我们来看下实例部分:

此处以 Clash for Windows 为例子。如图:

image

Clash for Windows 既支持 HTTP / HTTPS 协议代理,也支持 SOCKS v5 协议代理。如果你使用其他的代理软件,你可以根据你使用的代理软件的代理协议和本地端口号参考本文修改即可。


针对所有域名的 Git 仓库

根据你的代理软件支持的代理协议选取其中一种即可:

  • http 代理
  • socks5 代理
COPYgit config --global http.proxy http://127.0.0.1:7890

注意7890 为 Clash for Windows 的 http 代理端口。


针对特定域名的 Git 仓库

前面我们说的是,让所有域名下的仓库都走代理的情况,但是在现实情况下我们并不想这么做。那么现在我来介绍一下针对特定域名仓库走代理的做法,此处以 GitHub 为例:

当我们在 GitHub 仓库使用 HTTPS 传输协议克隆源码时,我们往往是这么做的的:

COPYgit clone https://github.com/<user>/<repository>.git

那么我前面命令注解所提到的 <url> 就是 https://github.com

根据你的代理软件支持的代理协议选取其中一种即可:

  • http 代理
  • socks5 代理
COPYgit config --global http.https://github.com.proxy http://127.0.0.1:7890

Git 使用 SSH 传输协议的代理方法

在这种情况下,Git 依靠 ssh 程序处理连接; 为了通过代理进行连接,您必须配置 ssh 程序本身,在 ~/.ssh/config 文件中设置 ProxyCommand 选项,通过在 ProxyCommand 中声明,使用不同操作系统下的程序来通过代理建立连接。

  • macOS 是通过在 ProxyCommand 中声明 nc 程序(该 nc 程序命令为系统自带的 OpenBSD 版本的 netcat 提供)来代理的;

  • Linux 一样可以通过 nc 程序、但是 Linux 上 nc 程序有 2 种 netcat 版本可以提供,分为 Nmap 版和 OpenBSD 版。如果是 OpenBSD 的版本,则 nc 命令与 macOS 相同;如果是 Nmap 版本的,nc 其实是指向 ncat 程序的符号链接,则其具体命令不一样;各 Linux 发行版本下 netcat 软件包名如下表:

    Linux 发行版本 / netcat 软件包名 Nmap 版 OpenBSD 版
    Fedora 系列 nmap-ncat netcat
    Debian 系列 ncat netcat-openbsd
  • Windows 下则是通过安装 Git for Windows 附带的 connect 程序。


相关 man 手册(点击展开)



























实例

接下来的操作,请按照你的系统、选择的 netcat 的实现版本以及所使用的代理协议进行选择:


Linux(OpenBSD 版 netcat)和 macOS 用户

  • https 代理
  • socks5 代理

编辑 ~/.ssh/config 文件

COPYvim ~/.ssh/config

给文件加上如下内容:

COPYHost github.com
User git
ProxyCommand nc -X connect -x 127.0.0.1:7890 %h %p

解释:

  • Host 后面 接的 github.com 是指定要走代理的仓库域名。
  • 在 ProxyCommand 中,Linux 和 macOS 用户用的是 OpenBSD 版本的 nc
  • -X 选项后面接的是 connect 的意思是 HTTPS 代理。
  • -x 选项后面加上代理地址和端口号。
  • 在调用 ProxyCommand 时,%h%p 将会被自动替换为目标主机名SSH 命令指定的端口%h%p 不要修改,保留原样即可)。

Linux(Nmap 版 netcat)用户

  • http 代理
  • socks5 代理

编辑 ~/.ssh/config 文件

COPYvim ~/.ssh/config

给文件加上以下内容:

COPYHost github.com
User git
ProxyCommand nc --proxy 127.0.0.1:7890 --proxy-type http %h %p

解释:

  • Host 后面 接的 github.com 是指定要走代理的仓库域名。
  • 在 ProxyCommand 中,Linux 用户用的是 Nmap 版本的 nc
  • --proxy-type 选项后面的 http 的意思是指使用 HTTP 代理。
  • 在调用 ProxyCommand 时,%h%p 将会被自动替换为目标主机名SSH 命令指定的端口%h%p 不要修改,保留原样即可)。

Windows 用户

  • http 代理
  • socks5 代理

编辑 ~/.ssh/config 文件

COPYvim ~/.ssh/config

给文件加上以下内容:

COPYHost github.com
User git
ProxyCommand connect -H 127.0.0.1:7890 %h %p

解释:

  • Host 后面 接的 github.com 是指定要走代理的仓库域名。
  • 在 ProxyCommand 中,Windows 用户用的是 connect
  • -H 选项的意思是 HTTP 代理。
  • 在调用 ProxyCommand 时,%h%p 将会被自动替换为目标主机名SSH 命令指定的端口%h%p 不要修改,保留原样即可)。

如何取消 Git 和 ssh 的代理

这里就不多说了,说了那么多,我们无非就是修改了 2 个文件,即 ~/.gitconfig~/.ssh/config删除注释我们增加的相应内容(在相应行的开头加上 # 即可)即可完成取消代理。

参考链接

https://ericclose.github.io/git-proxy-config.html

  1. Git - git-config Documentation
  2. Configure Git to use a proxy
  3. Tutorial: how to use git through a proxy
  4. ssh_config(5) - OpenBSD manual pages
  5. ncat(1) — Linux manual page
  6. nc(1) - OpenBSD manual pages
  7. SSH Proxy Command – connect.c
  8. How can I use SSH with a SOCKS 5 proxy?
  9. Git 基础——代理
  10. SSH via HTTP proxy in OSX