为什么fetch一个不存在的网址,程序不会timeout

fhxbzz · · 1913 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

```package main import ( "bufio" "fmt" "io" "io/ioutil" "net/http" "os" "time" ) func main() { start := time.Now() ch := make(chan string) urls := loadUrls("urls.txt") for _, url := range urls { go fetch(url, ch) } for range urls { fmt.Println(<-ch) } fmt.Printf("%.3fs elapsed\n", time.Since(start).Seconds()) } func loadUrls(filename string) []string { f, err := os.Open("urls.txt") if err != nil { fmt.Fprintln(os.Stderr, err) os.Exit(1) } input := bufio.NewScanner(f) urllist := make([]string, 0, 16) for input.Scan() { urllist = append(urllist, "http://"+input.Text()) } f.Close() return urllist } func fetch(url string, ch chan<- string) { t := time.NewTimer(10 * time.Second) select { case <-t.C: ch <- fmt.Sprint("time out:", url) default: start := time.Now() resp, err := http.Get(url) if err != nil { ch <- fmt.Sprint(err) return } nbytes, err := io.Copy(ioutil.Discard, resp.Body) resp.Body.Close() if err != nil { ch <- fmt.Sprintf("while reading %s: %v", url, err) return } secs := time.Since(start).Seconds() ch <- fmt.Sprintf("%.3fs %8d %s", secs, nbytes, url) } } ```

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1913 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传