问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

WEB 爬虫 是什么?

发布网友 发布时间:2022-04-27 09:33

我来回答

1个回答

热心网友 时间:2023-08-18 20:37

http://googlechinablog.com/2006/05/web-crawlers.html

数学之美系列六 -- 图论和网络爬虫 (Web Crawlers)

2006年5月15日 上午 07:15:00
发表者: 吴军,Google 研究员

[离散数学是当代数学的一个重要分支,也是计算机科学的数学基础。它包括数理逻辑、集合论、图论和近世代数四个分支。数理逻辑基于布尔运算,我们已经介绍过了。这里我们介绍图论和互联网自动下载工具网络爬虫 (Web Crawlers) 之间的关系。顺便提一句,我们用 Google Trends 来搜索一下“离散数学”这个词,可以发现不少有趣的现象。比如,武汉、哈尔滨、合肥和长沙市对这一数学题目最有兴趣的城市。]

我们上回谈到了如何建立搜索引擎的索引,那么如何自动下载互联网所有的网页呢,它要用到图论中的遍历(Traverse) 算法。

图论的起源可追溯到大数学家欧拉(Leonhard Euler)。1736 年欧拉来到德国的哥尼斯堡(Konigsberg,大哲学家康德的故乡,现在是俄罗斯的加里宁格勒),发现当地市民们有一项消遣活动,就是试图将下图中的每座桥恰好走过一遍并回到原出发点,从来没有人成功过。欧拉证明了这件事是不可能的,并写了一篇论文,一般认为这是图论的开始。

图论中所讨论的的图由一些节点和连接这些节点的弧组成。如果我们把中国的城市当成节点,连接城市的国道当成弧,那么全国的公路干线网就是图论中所说的图。关于图的算法有很多,但最重要的是图的遍历算法,也就是如何通过弧访问图的各个节点。以中国公路网为例,我们从北京出发,看一看北京和哪些城市直接相连,比如说和天津、济南、石家庄、南京、沈阳、大同直接相连。我们可以依次访问这些城市,然后我们看看都有哪些城市和这些已经访问过的城市相连,比如说北戴河、秦皇岛与天津相连,青岛、烟台和济南相连,太原、郑州和石家庄相连等等,我们再一次访问北戴河这些城市,直到中国所有的城市都访问过一遍为止。这种图的遍历算法称为“广度优先算法”(BFS),因为它先要尽可能广地访问每个节点所直接连接的其他节点。另外还有一种策略是从北京出发,随便找到下一个要访问的城市,比如是济南,然后从济南出发到下一个城市,比如说南京,再访问从南京出发的城市,一直走到头。然后再往回找,看看中间是否有尚未访问的城市。这种方法叫“深度优先算法”(DFS),因为它是一条路走到黑。这两种方法都可以保证访问到全部的城市。当然,不论采用哪种方法,我们都应该用一个小本本,记录已经访问过的城市,以防同一个城市访问多次或者漏掉哪个城市。

现在我们看看图论的遍历算法和搜索引擎的关系。互联网其实就是一张大图,我们可以把每一个网页当作一个节点,把那些超链接(Hyperlinks)当作连接网页的弧。很多读者可能已经注意到,网页中那些蓝色的、带有下划线的文字背后其实藏着对应的网址,当你点下去的的时候,浏览器是通过这些隐含的网址转到相应的网页中的。这些隐含在文字背后的网址称为“超链接”。有了超链接,我们可以从任何一个网页出发,用图的遍历算法,自动地访问到每一个网页并把它们存起来。完成这个功能的程序叫做网络爬虫,或者在一些文献中称为"机器人" (Robot)。世界上第一个网络爬虫是由麻省理工学院 (MIT)的学生马休.格雷(Matthew Gray)在 1993 年写成的。他给他的程序起了个名字叫“互联网漫游者”("www wanderer")。以后的网络爬虫越写越复杂,但原理是一样的。

我们来看看网络爬虫如何下载整个互联网。假定我们从一家门户网站的首页出发,先下载这个网页,然后通过分析这个网页,可以找到藏在它里面的所有超链接,也就等于知道了这家门户网站首页所直接连接的全部网页,诸如雅虎邮件、雅虎财经、雅虎新闻等等。我们接下来访问、下载并分析这家门户网站的邮件等网页,又能找到其他相连的网页。我们让计算机不停地做下去,就能下载整个的互联网。当然,我们也要记载哪个网页下载过了,以免重复。在网络爬虫中,我们使用一个称为“哈希表”(Hash Table)的列表而不是一个记事本纪录网页是否下载过的信息。

现在的互联网非常巨大,不可能通过一台或几台计算机服务器就能完成下载任务。比如雅虎公司(Google 没有公开公布我们的数目,所以我这里举了雅虎的索引大小为例)宣称他们索引了 200 亿个网页,假如下载一个网页需要一秒钟,下载这 200 亿个网页则需要 634 年。因此,一个商业的网络爬虫需要有成千上万个服务器,并且由快速网络连接起来。如何建立这样复杂的网络系统,如何协调这些服务器的任务,就是网络设计和程序设计的艺术了。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
我车祸被撞掉两颗门牙请问赔偿标准 未成年人在车祸中被撞掉两颗门牙是伤残吗 细菌性阴炎用什么洗液 红核洗液都有哪些作用 日语翻译: 从泡面广告对比来看中日文化差异 ---这一句用日语翻译怎么... ...在网页上打字的时候看不到选字的菜单栏,按空格键字就出来了,在QQ... 洋葱炒肉丝,洋葱是个宝,节后清肠多吃它,排脂降压不可少做法大全_百度知 ... AIGC艺术隐藏式创意二维码百科——艺术二维码什么意思?怎么样生成... 蓝海美业(北京)国际投资管理有限公司企业文化 我新办的交行信用卡昨天激活绑定微信了拿去刷用不了,然后我打给客服反应... 大庆公积金转到哈尔滨的公积金户头上,是取现金还是转移,哪个好?? 哈尔滨初中没毕业学什么好? 影视公司如何发展 哈尔滨工业大学工业设计考研的相关信息,求资料 被搜索引擎视为作弊的11种情况,你知道吗? robots协议的搜索引擎 怎么样才能把网址优化到百度的第一页呢? 哈尔滨龙采科技和妙搜网络是一家吗? PS设置为背景透明为什么是白色? 为什么用PS5新建一个背景为白色文件.可完成制图中北景出现透明色? 梦见白褂子的老人帮忙扇扇子? 我的电脑硬盘里怎么多出许多白色文件夹和白色的应用程序 食品业如何申请注册商标? 梦到有人对着脸扇风 退伍军人都在做什么工作呢? 食品商标怎么 注册? 为什么下载的东西是白色的文件!!附有图片!!! 退伍军人事业部可以为老龄退伍军人找工作吗? ps中为何透明背景比白背景文件大 梦见问路又梦见买鞋子又梦见太阳升起? 985”工程名单与“211”工程什么意思 风景园林专业简历自我评价怎么写 担保人责任 担保人要承担什么责任? 担保人是否承担连带责任 担保人要承担法律责任吗 担保人需要承担什么样的责任 担保人不承担责任有哪些方式 担保人需要承担哪些法律责任 暑假中学生假期社会实践鉴定表怎么填写? 担保人有其他债务是否还要承担担保责任? 担保人是否要承担连带偿还责任 担保人要承担全部责任吗? 担保超过六个月担保人是否还要承担责任 借新还旧担保人是否承担责任? 债权债务转移担保人是否承担保证责任? 电脑上的所有图片类都不能打印是什么原因啊?怎么解决?--电脑是win10系统的? win10照片打不开怎么办 为什么win10系统的照片应用打不开? win10系统突然打不开图片