3

遇到一些错误,我必须忽略一些东西。我该如何调试呢?断开连接?

我读到以下内容:
golang - 为什么 net.DialTimeout 有一半时间超时?
去。在服务器程序
golang 中获取错误 i/o 超时在 ubuntu 14.04 LTS 中获取大量读取 tcp ip:port i/o 超时在
Go 源代码中定位“读取 tcp”错误
获取零星的“http:代理错误:读取 tcp:i/ o 超时”在 Heroku 上

此处创建的错误: https ://github.com/golang/go/blob/b115207baf6c2decc3820ada4574ef4e5ad940ec/src/net/net.go#L179

目标:向 url 发送 Get 请求。
预期结果:以 JSON 格式返回正文。
遇到的问题:I/O超时

它适用于邮递员
编辑:我添加了修改后的超时......

Edit2:跟踪错误

邮递员要求:

GET /v2/XRP-EUR/candles?interval=1h HTTP/1.1
Host: api.bitvavo.com

邮递员结果(1440 行):

[
    [
        1609632000000,
        "0.17795",
        "0.17795",
        "0.17541",
        "0.17592",
        "199399.874013"
    ],
    [
        1609628400000,
        "0.17937",
        "0.18006",
        "0.17622",
        "0.17852",
        "599402.631894"
    ],
    [
        1609624800000,
        "0.18167",
        "0.18167",
        "0.17724",
        "0.17984",
        "579217.962574"
    ],.....

代码:

package main

import (
    "fmt"
    "net/http"
    "io/ioutil"
    "time"
)

func main() {
    url := "https://api.bitvavo.com/v2/XRP-EUR/candles?interval=1h"
    method := "GET"

    client := &http.Client {
    }
    client.Timeout = time.Second * 60
    req, err := http.NewRequest(method, url, nil)

    if err != nil {
        fmt.Println(err)
        return
    }
    res, err := client.Do(req)
    if err != nil {
        fmt.Println(err)
        return
    }
    defer res.Body.Close()

    body, err := ioutil.ReadAll(res.Body)
    if err != nil {
        fmt.Println(err)
        return
    }
    fmt.Println(string(body))
}

结果:

Get "https://api.bitvavo.com/v2/XRP-EUR/candles?interval=1h": dial tcp 65.9.73.10:443: i/o timeout
4

2 回答 2

2

在 docker 容器内构建时,我遇到了这个问题。

不知道为什么,但是在 dockerswarm leave --forcesystemctl restart docker构建工作之后。

于 2021-03-31T22:22:18.350 回答
0

Local environment, firewall not allowing golang to dial tcp..
It still allowed the url to be resolved to an ip though (DNS)

于 2021-01-03T12:17:12.823 回答