찾다
백엔드 개발GolangGo 's Crawler Colly의 큐 스레드의 문제는 무엇입니까?

Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까?

Go Crawler Colly의 요청 대기열 및 스레드 동시성 : 심도있는 토론

Colly Crawler Go 라이브러리를 사용할 때는 요청 큐 및 스레드 동시성 메커니즘을 이해하는 것이 중요합니다. 이 기사는 Colly의 큐 스레드 수와 요청 지연 사이의 상호 작용을 분석하고 "Go Crawler Colly의 대기열 스레드 문제"에 대답합니다.

예를 들어 설명하기 위해 예제를 사용합니다. 큐 스레드 수를 2로 설정하고 q, _ := queue.New(2, storage) 사용하여 큐를 만들고 세 가지 요청을 추가하십시오. 효과를 관찰하려면 수집기 지연을 5 초로 설정하십시오. 직관적으로, 두 요청은 거의 동시에 발행되어야하며 5 초 후에 반환해야합니다. 세 번째 요청은 10 초 후에 실행됩니다.

그러나 실제 결과는 다릅니다.

  1. 두 가지 요청이 생성됩니다.
  2. 5 초 후에 첫 번째 요청이 반환됩니다.
  3. 세 번째 요청이 생성됩니다.
  4. 5 초 후에 두 번째 요청이 반환됩니다.
  5. 5 초 후에 세 번째 요청이 반환됩니다.

이는 Colly의 수집가가 요청을 처리 할 때 큐의 전반적인 상황을 고려하지만 요청 자체의 지연은 실제 실행 시간에 영향을 미칩니다. 큐 스레드 수는 동시 요청 수를 제한하지만 요청이 설정되면 지연이 스레드 수의 동시 한계 효과를 대체합니다. 각 요청은 이전 요청이 완료된 후 실제 병렬로 처리되지 않고 다른 5 초로 지연됩니다.

Colly의 OnRequest 콜백 함수는 요청이 발행 될 때가 아니라 요청이 생성 될 때 해고됩니다. 요청 발급 시간을 제어하기보다는 요청 발급 전에 전처리에 주로 사용됩니다. 실제 요청 발급 시간은 수집기의 지연 설정에 의해 결정됩니다.

따라서 요청이 지연되도록 설정되면 Colly 대기열의 스레드 수는 동시성에 거의 영향을 미치지 않으며 요청의 순서와 시간은 주로 수집기의 지연 설정에 의해 제어됩니다. 이것은 Colly의 대기열 메커니즘과 동시성 제어에 대한 명확한 이해를 갖는 데 도움이됩니다.

위 내용은 Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
go语言有没有缩进go语言有没有缩进Dec 01, 2022 pm 06:54 PM

go语言有缩进。在go语言中,缩进直接使用gofmt工具格式化即可(gofmt使用tab进行缩进);gofmt工具会以标准样式的缩进和垂直对齐方式对源代码进行格式化,甚至必要情况下注释也会重新格式化。

go语言为什么叫gogo语言为什么叫goNov 28, 2022 pm 06:19 PM

go语言叫go的原因:想表达这门语言的运行速度、开发速度、学习速度(develop)都像gopher一样快。gopher是一种生活在加拿大的小动物,go的吉祥物就是这个小动物,它的中文名叫做囊地鼠,它们最大的特点就是挖洞速度特别快,当然可能不止是挖洞啦。

一文详解Go中的并发【20 张动图演示】一文详解Go中的并发【20 张动图演示】Sep 08, 2022 am 10:48 AM

Go语言中各种并发模式看起来是怎样的?下面本篇文章就通过20 张动图为你演示 Go 并发,希望对大家有所帮助!

【整理分享】一些GO面试题(附答案解析)【整理分享】一些GO面试题(附答案解析)Oct 25, 2022 am 10:45 AM

本篇文章给大家整理分享一些GO面试题集锦快答,希望对大家有所帮助!

tidb是go语言么tidb是go语言么Dec 02, 2022 pm 06:24 PM

是,TiDB采用go语言编写。TiDB是一个分布式NewSQL数据库;它支持水平弹性扩展、ACID事务、标准SQL、MySQL语法和MySQL协议,具有数据强一致的高可用特性。TiDB架构中的PD储存了集群的元信息,如key在哪个TiKV节点;PD还负责集群的负载均衡以及数据分片等。PD通过内嵌etcd来支持数据分布和容错;PD采用go语言编写。

go语言是否需要编译go语言是否需要编译Dec 01, 2022 pm 07:06 PM

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说Go语言程序在运行之前需要通过编译器生成二进制机器码(二进制的可执行文件),随后二进制文件才能在目标机器上运行。

go语言能不能编译go语言能不能编译Dec 09, 2022 pm 06:20 PM

go语言能编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言。对Go语言程序进行编译的命令有两种:1、“go build”命令,可以将Go语言程序代码编译成二进制的可执行文件,但该二进制文件需要手动运行;2、“go run”命令,会在编译后直接运行Go语言程序,编译过程中会产生一个临时文件,但不会生成可执行文件。

golang map怎么删除元素golang map怎么删除元素Dec 08, 2022 pm 06:26 PM

删除map元素的两种方法:1、使用delete()函数从map中删除指定键值对,语法“delete(map, 键名)”;2、重新创建一个新的map对象,可以清空map中的所有元素,语法“var mapname map[keytype]valuetype”。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.