我正在使用 ssh 创建到 EC2 实例的代理连接:
ssh -v -D 8123 ubuntu@some.ip.address
我写了一个非常简单的 Go 程序来发出 http 请求:
package main
import (
"io/ioutil"
"net/http"
"os"
"log"
"fmt"
)
func main(){
resp, err := http.Get("http://example.com")
if err != nil {
log.Println(err)
os.Exit(1)
}
fmt.Println(string(ioutil.ReadAll(resp.Body)))
}
当我正常运行我的程序时,它按预期工作。但是,当我使用 HTTP_PROXY env var(godoc,example)指定一个 http 代理(或者如果我制作一个使用该代理进行传输的自定义 http 客户端),我得到以下信息:
HTTP_PROXY=localhost:8123 ./main 2018/11/29 23:33:27 Get http://example.com: EOF
以及我在其中建立代理的 SSH 会话的调试给了我:
debug1: Connection to port 8123 forwarding to socks port 0 requested.
debug1: channel 3: new [dynamic-tcpip]
debug1: channel 3: free: dynamic-tcpip, nchannels 4
当我将我的 macbook 的 wifi 适配器配置为用作localhost:8123SOCKS 代理时,它似乎可以工作。我的面向公众的 IP 地址发生变化,并且流量似乎在流动(事实上,我现在正在使用它)。知道为什么我的 Go 程序有问题吗?
慕斯709654
相关分类