CN113946734A - 基于爬虫的数据采集系统 - Google Patents

基于爬虫的数据采集系统 Download PDF

Info

Publication number
CN113946734A
CN113946734A CN202110978180.0A CN202110978180A CN113946734A CN 113946734 A CN113946734 A CN 113946734A CN 202110978180 A CN202110978180 A CN 202110978180A CN 113946734 A CN113946734 A CN 113946734A
Authority
CN
China
Prior art keywords
crawler
task
html
scheduler
url
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202110978180.0A
Other languages
English (en)
Inventor
解峥
刘春阳
张旭
张丽
张翔宇
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
National Computer Network and Information Security Management Center
Original Assignee
National Computer Network and Information Security Management Center
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by National Computer Network and Information Security Management Center filed Critical National Computer Network and Information Security Management Center
Priority to CN202110978180.0A priority Critical patent/CN113946734A/zh
Publication of CN113946734A publication Critical patent/CN113946734A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/951Indexing; Web crawling techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/955Retrieval from the web using information identifiers, e.g. uniform resource locators [URL]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/546Message passing systems or structures, e.g. queues

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了基于爬虫的数据采集系统,包括:URL管理器,用于获取URL链接;HTML下载器,用于根据所述URL链接下载HTML网页;HTML解析器,用于解析所述HTML网页的源代码,获得网页数据;数据存储器,用于存储所述网页数据。本发明使用方便,用户体验好。

Description

基于爬虫的数据采集系统
技术领域
本发明涉及计算机信息技术领域。更具体地说,本发明涉及一种基于爬虫的数据采集系统。
背景技术
随着科技的逐步发展,人们已经迈入了“大数据时代”以及“人工智能时代”,然而大数据和人工智能的开发需要非常多的数据支持,数据的来源有很多的渠道。首先是企业所产生的用户数据:百度指数、阿里指数、TBI腾讯浏览指数、新浪微博指数;其次是数据平台购买数据:数据堂、国云数据市场、贵阳大数据交易所;或是政府/机构公开数据:中华人民共和国国家统计局数据、世界银行公开数据、联合国数据、纳斯达克;亦或是数据管理咨询公司:麦肯锡、埃森哲、艾瑞咨询;当然还有爬虫网络数据:如果需要的数据市场没有,或者不愿意购买,则需要使用网络爬虫采集。但是,目前的网络爬虫存在管理不便,用户体验较差的缺陷。因此,亟需设计一种能够一定程度克服上述缺陷的技术方案。
发明内容
本发明的一个目的是提供一种基于爬虫的数据采集系统,其使用方便,用户体验好。
为了实现本发明的这些目的和其它优点,本发明提供了基于爬虫的数据采集系统,包括:URL管理器,用于获取URL链接;HTML下载器,用于根据所述URL链接下载HTML 网页;HTML解析器,用于解析所述HTML网页的源代码,获得网页数据;数据存储器,用于存储所述网页数据。
进一步地,还包括:爬虫调度器,用于调度所述URL管理器、所述HTML下载器、所述HTML解析器和所述数据存储器。
优选的是,还包括:客户端,用于接收爬虫任务,并将所述爬虫任务发送至所述爬虫调度器,所述爬虫任务包括所述URL链接、爬取参数和期限信息;多个服务器,每个所述服务器内均设置所述URL管理器、所述HTML下载器、所述HTML解析器和所述数据存储器;其中,所述爬虫调度器还用于将所述爬虫任务分配至多个所述服务器中的一个,并将所述爬虫任务中的所述URL链接加入对应的所述URL管理器。
优选的是,多个所述服务器分别与多个处理队列对应,每个所述处理队列包括依次排队的多个所述爬虫任务;所述爬虫调度器用于将所述爬虫任务加入多个所述处理队列中的一个。
优选的是,所述爬虫任务中还包括紧急标志,所述爬虫调度器根据所述紧急标志确定所述爬虫任务在处理队列中的位置;若所述紧急标志为第一紧急标志,则将所述爬虫任务加入至所述处理队列的首位,若所述紧急标志为第二紧急标志,则将所述爬虫任务加入至所述处理队列的末位;若所述处理队列的首位已存在包括所述第一紧急标志的所述爬虫任务,则所述爬虫调度器将其中所述期限信息更近的所述爬虫任务设置为首位。
优选的是,所述爬虫调度器间隔设定时间根据所述爬虫任务估算所述处理队列中各所述爬虫任务的所述爬取时长,进而估算各所述爬虫任务的截止时间,并根据所述爬取时长和所述截止时间将位于所述处理队列的末位的所述爬虫任务在各所述处理队列之间切换,以使得各所述处理队列的所述爬虫任务均匹配对应的所述期限信息。
优选的是,所述爬虫调度器还记录各所述爬虫任务的实际爬取时长,若与估算的所述爬取时长的差值大于设定阈值,则标记对应的所述URL链接;当被标记的所述URL链接出现在爬虫任务中时,则结合被记录的实际爬取时长估算所述爬取任务的所述爬取时长。
本发明至少包括以下有益效果:
本发明设置URL管理器获取URL链接,设置HTML下载器根据URL链接下载HTML 网页,设置HTML解析器解析HTML网页的源代码,获得网页数据,设置数据存储器存储网页数据。本发明通过将各功能分别用各模块实现,提升了使用便利性和用户体验。
本发明的其它优点、目标和特征将部分通过下面的说明体现,部分还将通过对本发明的研究和实践而为本领域的技术人员所理解。
附图说明
图1为本发明的架构图。
具体实施方式
下面结合附图对本发明做进一步的详细说明,以令本领域技术人员参照说明书文字能够据以实施。
应当理解,本文所使用的诸如“具有”、“包含”以及“包括”术语并不排除一个或多个其它元件或其组合的存在或添加。
如图1所示,本申请的实施例提供了基于爬虫的数据采集系统,可以选择开发效率比较高的python语言进行开发,由于python的第三方开源库的大而全,因此在高效的开发过程中还能够确保爬虫的稳定性和精确性。具体而言,包括:URL管理器,用于获取URL 链接,即为获取新URL链接提供接口;HTML下载器,用于根据所述URL链接下载HTML 网页;HTML解析器,用于解析所述HTML网页的源代码,获得网页数据,同时也将新的URL链接发送给URL管理器以及将网页数据发送至存储器;数据存储器,用于存储所述网页数据至本地。本实施例通过将各功能分别用各模块实现,提升了使用便利性和用户体验。
在另一种技术方案中,还包括:爬虫调度器,用于管理、调度所述URL管理器、所述HTML下载器、所述HTML解析器和所述数据存储器,爬虫调度器可以是一服务器。
在另一种技术方案中,还包括:客户端,用于接收爬虫任务,并将所述爬虫任务发送至所述爬虫调度器,所述爬虫任务包括所述URL链接、爬取参数和期限信息;多个服务器,每个所述服务器内均设置所述URL管理器、所述HTML下载器、所述HTML解析器和所述数据存储器;其中,所述爬虫调度器还用于将所述爬虫任务分配至多个所述服务器中的一个,并将所述爬虫任务中的所述URL链接加入对应的所述URL管理器。客户端用于用户提交爬虫任务,并发送至爬虫调度器,爬取参数为爬取数据量、数据类型等,紧急标志为爬虫任务的紧急程度,期限信息则为爬虫任务的规定完成时间,多个服务器并行,分别设置有一网络爬虫,分别根据爬虫任务进行数据爬取、采集,提升了数据爬取效率,每个爬虫任务得到的网页数据分别存储在各服务器内。
在另一种技术方案中,多个所述服务器分别与多个处理队列对应,每个所述处理队列包括依次排队的多个所述爬虫任务;所述爬虫调度器用于将所述爬虫任务加入多个所述处理队列中的一个,这里的爬虫任务加入可根据每个处理队列的爬虫任务的数量确定,使得各处理队列的爬虫任务数量相当。
在另一种技术方案中,所述爬虫任务中还包括紧急标志,所述爬虫调度器根据所述紧急标志确定所述爬虫任务在处理队列中的位置;若所述紧急标志为第一紧急标志,则将所述爬虫任务加入至所述处理队列的首位,若所述紧急标志为第二紧急标志,则将所述爬虫任务加入至所述处理队列的末位;若所述处理队列的首位已存在包括所述第一紧急标志的所述爬虫任务,则所述爬虫调度器将其中所述期限信息更近的所述爬虫任务设置为首位。在这些实施例中,将爬虫任务分配至处理队列需要根据爬虫请求中的紧急标志确定,若为第一紧急标志,则表明较为紧急,将其加入处理队列首位,优先进行处理,若为第二紧急标志,则表明不紧急,将其加入处理队列末位,按先到先得的原则进行处理。当具有第一紧急标志的爬虫任务的数量多于服务器的数量,则比较新的爬虫任务与处理队列的首位爬虫任务的期限信息,将期限信息较紧急的爬虫任务放在首位,另一个放在第二位。
在另一种技术方案中,所述爬虫调度器间隔设定时间根据所述爬虫任务估算所述处理队列中各所述爬虫任务的所述爬取时长,进而估算各所述爬虫任务的截止时间,并根据所述爬取时长和所述截止时间将位于所述处理队列的末位的所述爬虫任务在各所述处理队列之间切换,以使得各所述处理队列的所述爬虫任务均匹配对应的所述期限信息。
在这些实施例中,为了避免新的爬虫任务的加入导致排队的爬虫任务的处理被延迟,爬虫调度器间隔设定时间估算截止时间和爬取时长,截止时间为爬虫任务的处理结束时间点,可根据各爬虫任务的爬取时长确定,爬取时长为爬虫任务的处理时间长度,当发现爬虫任务可能无法在期限内完成时,则对位于处理队列末位的爬虫任务的位置进行变换、调整,使得各爬虫任务均能在规定的时间期限内完成。
本实施例还可以包括以下细节,以更好地实现技术效果。当各爬虫任务的实际爬取时长达到估算的爬取时长的1/2时,检测该爬虫任务对应的爬取数据量,爬虫调度器根据爬取数据量对爬取时长进行重新估算,可以经过过往统计结果进行估算,若符合初始估算的爬取时长,则不予处理,若不符合,则根据将重新估算得到的爬取时长,以及对应处理队列中各爬虫任务的爬取时长和截止时间,重新调整位于处理队列末位的爬虫任务,使得各爬虫任务均能在规定的时间期限内完成。
在另一种技术方案中,所述爬虫调度器还记录各所述爬虫任务的实际爬取时长,若与估算的所述爬取时长的差值大于设定阈值,则标记对应的所述URL链接;当被标记的所述URL链接出现在爬虫任务中时,则结合被记录的实际爬取时长估算所述爬取任务的所述爬取时长。在这些实施例中,对于被标记的URL链接,下次出现在爬虫任务中时,则结合被记录的实际爬取时长估算爬取时长,比如按比例进行估算。
这里说明的设备数量和处理规模是用来简化本发明的说明的。对本发明基于爬虫的数据采集系统的应用、修改和变化对本领域的技术人员来说是显而易见的。
尽管本发明的实施方案已公开如上,但其并不仅仅限于说明书和实施方式中所列运用,它完全可以被适用于各种适合本发明的领域,对于熟悉本领域的人员而言,可容易地实现另外的修改,因此在不背离权利要求及等同范围所限定的一般概念下,本发明并不限于特定的细节和这里示出与描述的图例。

Claims (7)

1.基于爬虫的数据采集系统,其特征在于,包括:
URL管理器,用于获取URL链接;
HTML下载器,用于根据所述URL链接下载HTML网页;
HTML解析器,用于解析所述HTML网页的源代码,获得网页数据;
数据存储器,用于存储所述网页数据。
2.如权利要求1所述的基于爬虫的数据采集系统,其特征在于,还包括:
爬虫调度器,用于调度所述URL管理器、所述HTML下载器、所述HTML解析器和所述数据存储器。
3.如权利要求2所述的基于爬虫的数据采集系统,其特征在于,还包括:
客户端,用于接收爬虫任务,并将所述爬虫任务发送至所述爬虫调度器,所述爬虫任务包括所述URL链接、爬取参数和期限信息;
多个服务器,每个所述服务器内均设置所述URL管理器、所述HTML下载器、所述HTML解析器和所述数据存储器;
其中,所述爬虫调度器还用于将所述爬虫任务分配至多个所述服务器中的一个,并将所述爬虫任务中的所述URL链接加入对应的所述URL管理器。
4.如权利要求3所述的基于爬虫的数据采集系统,其特征在于,多个所述服务器分别与多个处理队列对应,每个所述处理队列包括依次排队的多个所述爬虫任务;
所述爬虫调度器用于将所述爬虫任务加入多个所述处理队列中的一个。
5.如权利要求4所述的基于爬虫的数据采集系统,其特征在于,所述爬虫任务中还包括紧急标志,所述爬虫调度器根据所述紧急标志确定所述爬虫任务在处理队列中的位置;
若所述紧急标志为第一紧急标志,则将所述爬虫任务加入至所述处理队列的首位,若所述紧急标志为第二紧急标志,则将所述爬虫任务加入至所述处理队列的末位;
若所述处理队列的首位已存在包括所述第一紧急标志的所述爬虫任务,则所述爬虫调度器将其中所述期限信息更近的所述爬虫任务设置为首位。
6.如权利要求5所述的基于爬虫的数据采集系统,其特征在于,所述爬虫调度器间隔设定时间根据所述爬虫任务估算所述处理队列中各所述爬虫任务的所述爬取时长,进而估算各所述爬虫任务的截止时间,并根据所述爬取时长和所述截止时间将位于所述处理队列的末位的所述爬虫任务在各所述处理队列之间切换,以使得各所述处理队列的所述爬虫任务均匹配对应的所述期限信息。
7.如权利要求6所述的基于爬虫的数据采集系统,其特征在于,所述爬虫调度器还记录各所述爬虫任务的实际爬取时长,若与估算的所述爬取时长的差值大于设定阈值,则标记对应的所述URL链接;
当被标记的所述URL链接出现在爬虫任务中时,则结合被记录的实际爬取时长估算所述爬取任务的所述爬取时长。
CN202110978180.0A 2021-08-24 2021-08-24 基于爬虫的数据采集系统 Pending CN113946734A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110978180.0A CN113946734A (zh) 2021-08-24 2021-08-24 基于爬虫的数据采集系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110978180.0A CN113946734A (zh) 2021-08-24 2021-08-24 基于爬虫的数据采集系统

Publications (1)

Publication Number Publication Date
CN113946734A true CN113946734A (zh) 2022-01-18

Family

ID=79327518

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110978180.0A Pending CN113946734A (zh) 2021-08-24 2021-08-24 基于爬虫的数据采集系统

Country Status (1)

Country Link
CN (1) CN113946734A (zh)

Similar Documents

Publication Publication Date Title
US11061900B2 (en) Temporal optimization of data operations using distributed search and server management
CN110609844B (zh) 一种数据更新方法,装置及系统
US6751627B2 (en) Method and apparatus to facilitate accessing data in network management protocol tables
AU2022200375A1 (en) Temporal optimization of data operations using distributed search and server management
CN102307210A (zh) 一种数据下载系统及其数据管理和下载方法
BR9907075A (pt) Sistema processo e dispositivo de armazanamento digital para distribuir informações pessoais de pelo menos um provedor de informação para pelo menos um usuário final, processo, sistema e dispositivo de armazenamento digital para distribuir armazenar e recuperar dados associados com um usuário final agregado de um ou mais provedores de informação, sistema e processo para gerar documentos eletrônicos, processo, sistema e dispositivo de armazenamento digital para planejar e coleta de informações por um computador central, processo, dispositivo de armazenamento digital e sistema para executar automaticamente uma ação para um usuário final, processo, dispositivo de armazenamento digital e sistema para monitorar interações entre um provedor de informações e um usuário final de informações pessoais, e, processo, dispositivo de armazenamento digital e sitema de acesso automatizado para informações pessoais associadas com um usuário final
CN104468833B (zh) 请求信息统一处理的方法和装置
US20140351273A1 (en) System and method for searching information
CN113472858B (zh) 埋点数据处理方法、装置及电子设备
CN109101599B (zh) 一种增量索引更新方法及系统
CN110334036A (zh) 一种实现缓存数据调度的方法和装置
CN108228322A (zh) 一种分布式链路跟踪、分析方法及服务器、全局调度器
CN110554951A (zh) 一种埋点管理的方法和装置
CN114185761B (zh) 日志采集方法、装置及设备
CN109586970B (zh) 资源分配方法、装置及系统
US20220321395A1 (en) Managing network event data in a telecommunications network
CN106384292A (zh) 社交网络用户关系采集系统及方法
CN116628068B (zh) 一种基于动态窗口的数据搬运方法、系统及可读存储介质
US20190332696A1 (en) Multi-database system
CN113946734A (zh) 基于爬虫的数据采集系统
CN101261643A (zh) 网站页面信息统计方法及装置
CN107590233A (zh) 一种文件管理方法及装置
CN109271104B (zh) 一种用于确定大数据存储系统的运行状态的方法及系统
CN108537577B (zh) 数据的有效性查询方法及装置、存储介质、服务器
CN114625805B (zh) 一种回测配置方法、装置、设备及介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination