Go語言並發爬蟲的具體實現
寫在前面
這篇文章主要讓大傢明白
多線程爬蟲
,因為go語言實現並發是很容易的。
這次的服務端,是我們之前搭建的電子商城平臺,所以我們不擔心ip被封
之類的問題。
而實際生產環境中,其實我們都是用python
爬蟲的。python實現多線程也很簡單。
這次我們可以試試新玩法,試試go語言的並發爬蟲。
主要是爬取第一頁的商品,爬取十次,比較單線程和多線程的時間。
1. 單線程爬蟲
定義一個用戶
var Client http.Client
主函數
func main() { url := "http://localhost:3000/api/v1/products" start := time.Now() for i := 0; i < 10; i++ { Spider(url, i) } elapsed := time.Since(start) fmt.Printf("Time %s", elapsed) }
爬取函數
func Spider(url string, i int) { reqSpider, err := http.NewRequest("GET", url, nil) if err != nil { log.Fatal(err) } reqSpider.Header.Set("content-length", "0") reqSpider.Header.Set("accept", "*/*") reqSpider.Header.Set("x-requested-with", "XMLHttpRequest") respSpider, err := Client.Do(reqSpider) if err != nil { log.Fatal(err) } bodyText, _ := ioutil.ReadAll(respSpider.Body) var result Result _ = json.Unmarshal(bodyText, &result) fmt.Println(i,result.Data) }
運行時間為:651.8207ms
2. 多線程爬蟲
2.1 channel main函數
我們構造一個無緩沖的通道,來阻塞主進程,等待子進程的執行。
func main() { url := "http://localhost:3000/api/v1/products" ch := make(chan bool) start := time.Now() for i := 0; i < 10; i++ { go Spider(url, ch, i) } for i := 0; i < 10; i++ { <-ch } elapsed := time.Since(start) fmt.Printf("Time %s", elapsed) }
最後記得在爬蟲的結束的時候,把值寫入到通道中,不然會一直阻塞主進程
運行時間:187.7921ms
比之前快瞭非常多。
2.2 sync.WaitGroup
定義一個進程組並加10個進程
var wg sync.WaitGroup wg.Add(10)
開辟十個goruntime
for i := 0; i < 10; i++ { go func(i int) { defer wg.Done() SpiderWaitGroup(url,i) }(i) }
阻塞主進程
wg.Wait()
結果:64.5246ms
3. 源碼地址
GitHub地址:https://github.com/CocaineCong/Go-Spider-Demo
NormalStart(url) // 單線程爬蟲 ChannelStart(url) // Channel多線程爬蟲 WaitGroupStart(url) // Wait 多線程爬蟲
其實多線程的兩種都差不多的,隻是有時候會因為機器的原因而導致一些誤差。
到此這篇關於Go語言並發爬蟲的具體實現的文章就介紹到這瞭,更多相關Go語言並發爬蟲 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Go語言如何輕松編寫高效可靠的並發程序
- Go語言學習之WaitGroup用法詳解
- Golang中的sync包的WaitGroup操作
- 解決golang sync.Wait()不執行的問題
- 在golang中使用Sync.WaitGroup解決等待的問題