golang 异步并发http轮询(爬虫)

目录

一 同步http

二 异步http

三 控制异步并发速度

四 异步并发实现

五 说明


一 同步http

func Http_curl(url string, payload_str string, method string) []byte{
    payload := strings.NewReader(payload_str)
    req, _ := http.NewRequest(method, url, payload)
    req.Header.Add("content-type", "application/x-www-form-urlencoded")
    req.Header.Add("cache-control", "no-cache")
    res, _ := http.DefaultClient.Do(req)
    defer res.Body.Close()
    body, _ := ioutil.ReadAll(res.Body)
    //fmt.Println(string(body))
    return body
}

二 异步http

func Http_curl_async(url string, payload_str string, method string){
    go func() {
        Http_curl(url,payload_str,method)
    }()
}

三 控制异步并发速度

var(
    chSem = make(chan int, 5)
)

func Http_curl_async(url string, payload_str string, method string){
    go func() {
        chSem <- 1
        Http_curl(url,payload_str,method)
        <- chSem
    }()
}

四 异步并发实现

package utils

import (
    "fmt"
    "io/ioutil"
    "net/http"
    "strings"
    "sync"
)

var(
    chSem = make(chan int, 5)
    chSemWg sync.WaitGroup
)
func Http_curl(url string, payload_str string, method string) []byte{
    payload := strings.NewReader(payload_str)
    req, _ := http.NewRequest(method, url, payload)
    req.Header.Add("content-type", "application/x-www-form-urlencoded")
    req.Header.Add("cache-control", "no-cache")
    res, _ := http.DefaultClient.Do(req)
    defer res.Body.Close()
    body, _ := ioutil.ReadAll(res.Body)
    //fmt.Println(string(body))
    return body
}

func Http_curl_async_loop(looptimes int,url string, payload_str string, method string){
    chSemWg.Add(looptimes)
    for i := 0; i < looptimes; i++ {
        cur_i := i
        go func() {
            chSem <- 1
            fmt.Println(cur_i)
            Http_curl(url,payload_str,method)
            <- chSem
            chSemWg.Done()
        }()
    }
    chSemWg.Wait()
}
utils.Http_curl_async_loop(100,"http://www.baidu.com", "s=s01","POST")

五 说明

  • 如果不用wg,轮询没走完程序就会退出
  • 要控制并发速度,不然协程多了,开启和维护的资源也不少

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Go语言(golang)因其轻量级、高效和内置支持并发的特点,非常适合用于构建高并发服务器。以下几点描述了为何Go适合高并发场景以及如何实现: 1. ** goroutines 和 channels**:Go的核心特性之一就是goroutine和channel。goroutine是一种轻量级线程,创建成本低,可以同时处理大量请求,而channel则提供了一种安全的异步通信机制,使得并发任务间的数据传递变得简单。 2. ** CSP (Communicating Sequential Processes)**:Go的设计理念深受 Communicating Sequential Processes (CSP) 影响,鼓励程序员编写独立运行并能相互协作的小型函数式程序,这有助于组织和管理复杂的并发逻辑。 3. **内存模型**:Go的内存模型是基于单线程的,但在用户空间内通过goroutines模拟并发,这种设计避免了锁的竞争,提高了性能。 4. **惰性计算和短暂停留**:对于网络I/O密集型应用,Go的net/http包利用HTTP连接复用和长生命周期的连接池,减少了不必要的上下文切换。 5. **并发安全库**:Go的标准库提供了如sync.Map这样的并发安全数据结构,帮助开发者在高并发环境中操作共享数据。 要创建一个高并发服务器,你可以按照以下步骤: - 使用`net/http`包创建Server实例。 - 实现HandlerFunc来处理请求。 - 如果有需要,使用context包进行请求超时控制和取消。 - 利用goroutines和channels处理并发请求。 ```go package main import ( "fmt" "net/http" ) func handler(w http.ResponseWriter, r *http.Request) { // 处理请求逻辑... fmt.Fprintln(w, "Hello from Go!") } func main() { http.HandleFunc("/", handler) err := http.ListenAndServe(":8080", nil) if err != nil { panic(err) } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值