`
wangdei
  • 浏览: 372164 次
社区版块
存档分类
最新评论

Google搜索引擎技术实现探究

阅读更多

        化柏林 (呵呵,此片文章有点过时,但是还是适合一些小型的抓取spider,如

http://www.bt285.cn BT下载
http://www.yaonba.com.cn NBA中文网
http://www.5a520.cn 小说520网

 http://www.bt285.cn/yazhou/ 亚洲BT 有BT亚洲
http://www.vagaaga.cn vagaa)
                  (中国科学技术信息研究所  北京 100038)
【摘要】  本文从技术的角度剖析了Google搜索引擎的体系结构与工作过程,详细介绍了基于Robot的网页搜索、标引入库和检索引擎三大模块,统计了Google的技术数据,并分析了Google的技术实现特点,解释了Google检索的种种现象。
 【关键词】  Google 搜索引擎 技术实现   【分类号】 G354

Anatomy of Google Search Engine Viewed on Technical Implementation
Hua Bolin
(Institute of Scientific and Technical Information of China, Beijing 100038)
【Abstract】 This paper anatomized architecture and procedure of Google viewed on Technical Implementation. It introduced three functional modules, which is Web crawler, index and create database, search engine. Then do a statistic of technical data about Google, and analyzed technical feature, explained a variety of phenomena when using Google to retrieval.
【Keywords】 Google, Search Engines, Technical Implementation
1 Google技术总况与体系结构
Google拥有10亿个网址,30亿个网页,3.9 亿张图像,Google 支持66种语言接口,16种文件格式,面对如此海量的数据和如此异构的信息,google是如何实现半秒内搜索的呢? Google拥有1600台服务器,大部分代码用C或C++实现,有很好的执行效率,运行在Solaris 或Linux 上。Google用了64个桶(barrels),有293M词典(lexicon)、43G的顺排档文件、41G的倒排档文件,构造了一个5.18亿个超链接的网络关联图。
Google搜索引擎有两个特征来提高查准率:利用网页间的链接关系来计算每一个网页的等级;利用链接关系来改善检索结果。除此之外,Google还对所有的点击都有定位信息,广泛利用搜索的亲近度。第二,Google 记录详细的可视化表达诸如词的字体大小,大或粗体的词的权重就高。第三,整个页面的HTML源文件在知识库中是可用的。
Google搜索引擎从功能上同样分为三大部分:网页爬行、标引入库和用户查询。网页爬行主要负责网页的抓取,由URL服务器、爬行器、存储器、分析器和URL解析器组成, 爬行器是该部分的核心;标引入库主要负责对网页内容进行分析,对文档进行标引并存储到数据库里,由标引器和分类器组成,该模块涉及许多文件和数据,有关于桶的操作是该部分的核心;用户查询主要负责分析用户输入的检索表达式,匹配相关文档,把检索结果返回给用户,由查询器和网页级别评定器组成,其中网页等级的计算是该部分的核心。其总体系统结构如图1所示。

2 基于Robot的搜索过程
Robot使用多线程并发搜索技术,主要完成文档访问代理、路径选择引擎和访问控制引擎。基于Robot的Web页搜索模块主要由URL服务器、爬行器、存储器、URL解析器四大功能部件和资源库、锚库、链接库三大数据资源构成,另外还要借助标引器的一个辅助功能。具体过程是,有个URL服务器发送要去抓取的URL,爬行器根据URL抓取WEB页并送给存储器,存储器压缩Web页并存入数据资源库,然后由标引器分析每个WEB页的所有链接并把相关的重要信息存储在anchors 文件中。URL解析器读anchors文件并解析URL,然后依次转成docID。再把anchor文本变成顺排索引,送入索引库。具体过程如图2所示。


2.1 URL服务器(URL Server)
URL服务器是整个Web页搜索模块的开始,主要用来管理和维护URL列表。首先由它发送一个新的URL给爬行器,让爬行器去搜索。如果爬行器遇到了不可下载的网页,就会给URL一个返回信息,然后取下一个URL。URL服务器会从文档索引库里不断地取新的URL以供爬行器使用。
2.2 爬行器(crawler)
爬行器是整个搜索模块中最关键的一部分,它由好几个分布的爬行器组成,并协同工作。爬行器遇到HTML页的头有如下标记就不再抓取此页,<head><meta name="robots" content="noindex, nofollow"></head>,返回一个空值,继续向其他方向爬行,这就有效防止爬行器标引此页及本页的相关链接页。如果网页已经标引过,就从将要爬行的网页队列中移除。Web页文本的繁殖思想是由3W蠕虫来实现的,当它搜索非文本信息时,尽可能少的下载文档,以扩展搜索度,因为非文本信息如图片等没有链接会造成爬行的中断。这样,Google就可以通过各种策略来解决排序沉没(rank sink)和排序漏出(rank loak)等问题。
2.3 存储器(store server)
存储器把爬行器抓来的Web页进行压缩并存储到数据资源库中。数据资源库包含每一个Web页的全部HTML,所有的网页用zlib进行压缩,Google更注重zlib的压缩速度而不是压缩率。bzip对数据库的压缩率接近4:1,而zlib为3:1。这样,Google就能把147.8G的HTML文档压缩成53.5G的数据存储在库中。在数据资源库中,对文档进行归类,加上docID前缀、文档的长度和URL。文档索引记录着每一个文档的信息,它是一个有固定长度,经docID排序的ISAM索引(Index sequential access mode)。存在每个条目中的信息包括当前文档状态,数据库中的指针,文档校验和以及其它统计信息。如果文档被爬行过,它也包含到可变长文件的指针,这个称为docinfo的文件包含文档的URL和标题。否则,指针指向仅包含URL的URL列表。
2.4 分析器(parser)
分析器可以看成是标引器的一部分,也可以说是标引器的一个辅助功能部分。它分析每个WEB页的所有链接并把相关的重要信息存储在anchors 文件中,构成一个锚库。每当从WEB页分析出一个新的URL时,为每个WEB页分配一个称为docID的关联ID。这个文件包含足够的信息来决定每个链接的何去何从。锚经常提供比web页本身更精确的页描述。锚可以存在文档,这些文档不能被基于文本的搜索引擎所标引,如图片、程序、数据库。这就为返回那些不能精确爬行的Web页提供了可能。
2.5 URL解析器(URL Resolver)
 URL解析器读anchors文件并把相对URL转成绝对URL,然后依次转成docID。把anchor文本变成顺排索引,存到文档索引库里,并用anchor所指向的docID进行关联。把URL转换成docID的文件,是由URL校验和及相应的docID两列组成的一个列表,并以校验和排序。为了找到一个特定URL的docID,首先计算URL的校验和,在校验和文件中进行二元查找,以找到相应的docID。执行一次批处理,通过合并文件把URL 转成docID。使用这种批处理模式很关键,要不然就得为每一个链接都作一次查找,假设一个磁盘上有322,000,000个链接记录,那么这样一个过程需要2个多月的时间。它还产生成对docID的链接数据库,以用于计算所有文档的PageRanks。
3 标引入库
标引入库模块由分类器和标引器组成。标引入库模块处理大量的文件和数据,用来构建庞大的数据库,主要涉及数据资源库、词典库、链接库、桶等。桶的结构与内容非常复杂,有关桶的操作是本模块的核心,
3.1 分类器(sorter)
分类器从桶中取出数据,按docID进行一级分类,然后按照wordID进行二级分类并产生倒排档索引。分类器产生wordID的列表并把其偏移量写到倒排档索引中。一个称为DumpLexicon的程序把这个列表和由标引器产生的词典揉和在一起并为检索器产生一个新的词典。
3.2 标引器(indexer)
标引器有许多函数,它读数据库,解压缩文档然后进行分析。每个文档都被转成一套单词出现频率,称之为采样数。采样数记录单词及在文档中出现的位置,字体的大小以及大写信息。标引器把这些采样数分配到一套“桶”中,创建一个部分分类的顺排索引。对于中文,Google主要采用了二元切分法,也就是为什么我们输入长于两个汉字的中文,如果不加双引号,Google会自动给以切分的原因。
3.3 桶(barrels)
Google共有64个桶(barrels),每个桶都存着wordID的归类,包括顺排档与倒排档。如果一个文档包含落在某个桶里的词,docID和wordID的列表以及相应的命中列表就被记录到桶里。Google存储每一个wordID时,存储的是与所在桶的最小wordID的相对差异,而不是存储实际的wordID。这样,在未排序的桶中用24位存储wordID,留下8位用来存储命中列表的长度。
倒排档索引就象顺排档一样由系列的桶组成,唯一的不同是被分类器处理过。有个重要的问题是docID应当在doclist中如何排序。一个简单的解决办法是用docID进行分类,这允许多词查询而带来的不同doclist的合并。另外一个办法是按词在每个文档中出现的频率等级进行分类存储,尽管这使得处理单个词的查询变得繁琐,但为多词查询提供了可能。Google在这两个方案中选择了折衷,使用两套倒排的桶,一套为包括标题和anchor hits的命中列表,我们称之为短桶,另一套为所有的命中列表,我们称之为长桶。
在顺排档索引和倒排档索引中,命中列表占据了大量的空间。命中列表是指词在一篇文档中的出现频率,包括位置、字体和大写信息。Google为编码位置、字体和大写考虑了多种编码方案——简单编码、优化压缩编码和哈夫曼编码。由于优化压缩编码对空间的要求比简单编码低,操作过程比哈夫曼编码简单,因此,Google最终选择了优化压缩编码。
Google用两个字节的压缩编码来记录每次命中,命中类型有两种:特殊命中与普通命中。特殊命中包括URL的命中率、标题、链接文本和关键标记。普通命中含有所有的信息,包括大写位、字体大小和12位标记词在文档中出现的位置信息等。字体大小用3位来表达文档的其它内容的相对值(仅有7个值可用,因为111是特殊命中的标记)。特殊标记由大写位,字体设成7来表明是一个特殊命中,有4位表示类型,用8位标记位置。为了节省空间,命中列表的长度由顺排档中的wordID和倒排档中的docID决定。分别需要8位与5位。如果长度更长的话,在相应的位里就存着一个溢出编码,接下来的两个字节存储命中列表的实际长度。


3.4 词典(lexicon)
词典有几种不同的形式。对早期系统的一个重要改变是根据合理的代价分配内存。该词典包含1400万个词条(有些生僻词没加),由两部分实现,词表和指针的哈希表。词表还有一些辅助信息用以实现其它功能。对于每个有效的wordID,词典包含指向wordID所在桶的指针。它指向docID和相应的命中列表的doclist。Doclist表明该词在所有文档中出现的所有情况。
4 检索过程与网页级别
Google用户查询模块主要由网页级别评定器和查询器组成。
4.1 查询器(searcher)
查询器运行在Web服务器上,并用DumpLexicon产生的词典、倒排档索引和PageRanks一起来响应查询。首先接受用户输入的检索表达式,进行分析得出各项检索要求,提取检索词并转成wordID,接着到短桶文档列表里进行查词,遍历文档列表直到匹配所有的词条,找到一篇就计算网页等级,短桶查完了,如果没有足够的匹配记录,就去查长桶。查完了所有的文档列表,就对检索结果进行排序并返回前K项。

4.2 网页级别评定器(PageRanker)
网页级别评定器借用了图书文献里的参考文献与引用文献的评价思想,利用链接网页的数量及重要性进行等级评定,而链接网页的重要性由它的链接网页的数量及重要性决定,因此是一种迭代计算。评级函数有许多参数,如类型权重和相关类型权重等。
 如果有许多网页指向网页P,那么P就是一个好的网页。IR'(P),从不同域的链接要比同一个域内的链接重要。自然链接可以表明相关重要性。当从网页 A 链接到网页 B 时,Google 就认为“网页 A 投了网页 B 一票”。Google 根据网页的得票数评定其重要性。除了考虑网页得票数(即链接)的纯数量之外,Google 还要分析投票的网页。“重要”的网页所投出的票就会有更高的权重,也有助于提高其它网页的“重要性”。 被引率高就说明该页值得看,PageRank通过web链接架构来处理靠递归繁殖提高权重的情况。
假定网页A有指向A的网页T1...Tn(也叫引用网页)。参数d是一个设定于0、1之间的递减因子,通常定为0.85。C(A)为从网页A链出去的链接数,因此,网页A的PageRank就可以求出:
PR(A) = (1-d) + d (PR(T1)/C(T1) + ... + PR(Tn)/C(Tn)) 
PageRank 或者PR(A)用迭代算法来计算,相当于一个规范化的Web链接矩阵的特征向量。有26,000,000个网页在一台中型工作站上用几个小时就能算完。PageRanks形成了web页的概率分布,所有web页的PageRanks和为1。

重要的、高质量的网页会获得较高的网页级别。Google 在排列其搜索结果时,总会考虑每个网页的级别。当然,如果不能满足用户的查询要求,网页级别再高对用户来说也毫无意义。因此,Google 将网页级别与完善的文本匹配技术结合在一起,为用户找到最重要、最有用的网页。Google 所关注的远不只是关键词在网页上出现的次数,它还对该网页的内容以及该网页所链接的内容进行全面检查,从而确定该网页是否满足用户的查询要求。Google在检索引擎里用一个用户反馈机,对信任用户可有选择地评估所有的返回结果,这种反馈被存到数据库里,当修改评级函数时,就能发现对以前评过级的检索所产生的影响。
5 功能检索的实现
对于Google的检索实现,笔者对检索做了大量的测试,而对技术仅作了有限的部分测试,其理解如下:
5.1 逻辑表达式
Google支持的逻辑运算有与、或、非,其形式分别为“ ”、“or”、“-”,对应Google高级检索里的“包含全部字词”、“包含任何一个字词” 、“不包含以下字词”。Google不支持截词检索,因为截词检索会极大地降低计算机的检索速度。当然Google对词的切分技术也并不理想,对西文比较有效,对亚洲语言作得不好。
5.2 指定文件类型
Google可以指定查找的文件格式,如pdf、doc、ppt等格式文件。如果某个搜索结果是 PDF 文件而不是网页,它的标题前面会出现以蓝色字体标明的 [PDF]。用户只想查一般网页,而不要 PDF 文件,只需在搜索关键词后加上 -filetype:pdf 就可以了,而如果只想查pdf文件,则用filetype:pdf就可以指定pdf文件了。每一个文档在数据库里都有其文件类型,因此,实现它并不困难。
5.3 指定范围
Google可以指定网页的范围,如(all)intitle,(all)intext ,(all)inurl,(all)inanchor等。网页标题只是对HTML的<title></title>里的内容进行检索,如果title的内容与文章真正的标题不一致,则Google没有能力检索出来。在
http://www7.scu.edu.au/programme/fullpapers/1921/com1921.htm里的文章真正的标题是The Anatomy of a Large-Scale Hypertextual Web Search Engine,而相关HTML文件里<title></title>的内容却是The Anatomy of a Search Engine,因此在Google的输入框里键入allintitle:“The Anatomy of a Large-Scale Hypertextual Web Search Engine”,是查不到该文章的。而对文章内容的检索识别是HTML文件里的<body></body>中的内容。当然还可以限定时间、指定站点等。通过site:www.xxx.xxx.xxx指定站点实现站内搜索是很有用的。
5.4 语言问题
Google支持66种语言接口,35种语言指定检索,Google对语种的判别不是通过URL信息(域名中的国别),主要通过HTML中的charset,和对网页内容部分识别的统计信息来联合判断。其实,好多人还把Google当词典来用,我们输入“"层次分析法"  analysis”指定中文网页就可以检索出层次分析法的英文翻译。
5.5 同义词检索
选择“搜索所有网站或搜索所有中文网页”,输入“计算机”,则会把含有“电脑”的网页(不论有没有“计算机”)搜索出来,而在简体中文网页里就不会实现这样的功能,因为Google采用Basis Technology的中文简繁体转换技术。
5.6网页目录
Google按内容把网页信息分为15个大类,主要是通过词频分布与统计技术,对内容进行识别并用分类器(sorter)进行归类。
5.7 图像搜索
Google搜集了3.9 亿张图像,对图像的描述信息建了一个很大的数据库。图像检索使用的主要是文件名、图片附近的文本、图片的标题以及从图片中提取的部分内容。
5.8 相似结果
google 会省略相似的结果,尤其是来自不同站点页内容相同的文章,有时我们在Google显示的结果中不能下载相应的文章时,而省略的结果中可能允许下载,这时google的省略功能就带来了不便。判断内容相似主要可能是根据文章题目、文章大小和部分词语统计信息等。当然还有许多特点与使用技巧,那不是本文讨论的重点。
当我们了解了Google的技术实现,就可以理解检索过程中出现的种种现象。针对这些特点再去调整检索策略,这样它返回的结果就不再成千上万了。正常情况下,把检索结果控制在百条左右,是一个专业检索水平的标志,这样的结果对我们也才真正的有意义。

参考文献
[1] 
http://www.google.com/intl/zh-CN/features.html
[2] http://www.google.com/intl/zh-CN/why_use.html
[3] Junghoo Cho, Hector Garcia-Molina and Lawrence Page. Efficient crawling through URL ordering http://www7.scu.edu.au/programme/fullpapers/1919/com1919.htm
[4] Sergey Brin and Lawrence Page. The Anatomy of a Large-Scale Hypertextual Web Search Engine.  http://www-db.stanford.edu/~backrub/google.html
[5] The Google Pagerank Algorithm and How It works. http://www.iprcom.com/papers/
pagerank/

<script type="text/javascript"></script>

 

分享到:
评论
1 楼 kaka99 2008-08-29  

相关推荐

    Google 搜索引擎技术实现探究

    ### Google 搜索引擎技术实现探究 #### 一、Google技术总览与体系结构 Google作为全球最著名的搜索引擎之一,其背后的技术架构与运作机制一直是业界关注的焦点。截至某一时间点,Google已拥有超过10亿个网址链接,...

    基于Nutch和Hadoop的分布式搜索引擎探究.pdf

    分布式搜索引擎的实现和优化是当前信息技术研究的热点,而Nutch和Hadoop是实现分布式搜索引擎的关键技术。本文将对基于Nutch和Hadoop的分布式搜索引擎进行深入探究。 首先,分布式系统是现代搜索引擎的重要组成部分...

    搜索引擎营销-搜索引擎营销发展现状及前景.pptx

    挑战方面互联网领域的人口红利优势逐步的在减少,促使搜索引擎运营商从注重用户规模到探究用户行为方向发展。预计未来几年中国搜索引擎市场仍将保持较为稳健的增长速度,到2025年,市场规模预计将接近1680亿元。 ...

    sousuoyinqin.zip_搜索引擎

    搜索引擎是互联网上不可或缺的信息检索工具,它通过复杂的算法和机制帮助用户快速找到所需的信息。...通过学习“搜索引擎关键技术.ppt”这样的资源,我们可以深入探究这些概念并掌握搜索引擎的运作精髓。

    好一搜超级搜索引擎源码 V4.0 商业版

    通过研究【好一搜超级搜索引擎源码 V4.0 商业版】,开发者可以深入探究以上各个技术点,理解搜索引擎的运行机制,并可能在此基础上构建出更适合特定场景的搜索引擎。无论是对于学术研究还是商业应用,这个源码都是一...

    搜索引擎行业发展状况调查报告

    这份报告由万瑞数据在金融危机背景下发布,旨在深入探究搜索引擎行业的现状,特别是针对此前中央电视台报道引发的搜索引擎信任危机的影响。报告通过网上调查的方式收集数据,涉及新浪、搜狐、网易、千龙、中华、凤凰...

    《如何使用搜索引擎获取信息》教学设计.pdf

    接着,教师引导学生了解搜索引擎的类型和特点,通过讨论和实际操作,学生学习使用常见的搜索引擎,如Google、百度、雅虎中国和搜狗搜索。教师还会教授基本的搜索技巧,例如有针对性的搜索、分类查询和使用不同搜索...

    搜索引擎说课稿.pdf

    - **知识与技能目标**:学生将了解搜索引擎的基本概念,熟悉常用搜索引擎如百度、谷歌等,并掌握搜索引擎的两种主要分类——全文搜索引擎和目录搜索引擎,以及它们各自的特点。此外,学生还将学习如何使用特殊符号...

    搜索引擎说课稿.doc

    - 学生将了解搜索引擎的基本概念,熟悉如百度、谷歌等常用搜索引擎。 - 掌握搜索引擎的两种主要分类——全文搜索引擎和目录搜索引擎,理解其不同特点。 - 学习并运用各种搜索符号(如引号、减号、双引号等)来...

    Google桌面搜索 源码下载

    "百度搜索"和"谷歌搜索"是中国和全球最知名的网络搜索引擎。虽然两者主要应用于在线搜索,但它们的一些核心技术,如信息检索、自然语言处理和用户行为分析,同样对桌面搜索产生了深远影响。例如,Google桌面搜索可能...

    高中《信息技术》教师资格——《搜索引擎》教案.pdf

    高中《信息技术》课程中的《搜索引擎》教案主要关注的是教授学生如何有效地使用搜索引擎来获取和处理信息。这节课的核心目标是让学生掌握基本的搜索技巧,理解信息来源的不同类别,并学会根据需求选择合适的信息获取...

    二年级信息技术上册 第10课 交通安全宣传栏——搜索引擎 1(第一课时)教案 河大版.doc

    本节课是小学二年级信息技术课程的第10课,主题为“交通安全宣传栏——搜索引擎”,主要目的是让孩子们初步了解搜索引擎,并通过实际操作,学会如何利用搜索引擎搜索和下载相关信息,提升他们的网络信息意识和操作...

    高中信息技术教案.pdf

    高中信息技术教案.pdf 本资源是高中信息技术教案的教学大纲,...本教案旨在帮助学生学习搜索引擎的使用方法,提高学生获取信息的能力,培养学生自主探究、协作学习的能力,提高学习信息技术的热情以及协作学习的精神。

    基于大数据的计算机信息处理技术探究.zip

    例如,在搜索引擎优化中,通过对海量用户行为数据的分析,可以提升搜索结果的相关性和用户体验。在推荐系统中,基于用户历史行为、兴趣偏好和社交网络的大数据分析,可以精准推送个性化内容。在网络安全领域,大数据...

    探究云计算下大数据的信息检索技术应用.pdf

    目前,谷歌和百度等搜索引擎公司已经在信息检索技术上处于领先地位。它们所采用的核心技术,包括检索过程和网页收录过程,可以为云计算平台下的大数据信息检索提供借鉴。在云计算平台中,信息检索过程主要包含两个...

    信息时代高校英语专业教师教育信息技术应用能力探究.pdf

    例如,教师应掌握高效的网络搜索技巧,利用百度、谷歌等搜索引擎获取最新的英语教学资料,为学生创造丰富的学习环境。同时,教师应熟悉信息交流工具如QQ、微信,进行专业信息的分享与互动,并能运用Word、PowerPoint...

    探究型学习方案实用.pdf

    1. 网络资源的搜索与利用:探究型学习通常需要学习者能够使用搜索引擎(如Google、雅虎、搜狐和新浪等)检索到相关的信息,这要求学习者掌握有效的搜索技巧,如使用关键词、高级搜索运算符以及评估信息的准确性和...

    3.2因特网上的信息检索教案_[归类].pdf

    实践与探究环节,我们可以对比Google、Yahoo和百度等不同搜索引擎,观察它们的更新频率、搜索结果的相关性和用户界面的差异,以更好地理解和选择适合自己的信息检索工具。这些知识对于提高网络信息检索效率和精准度...

Global site tag (gtag.js) - Google Analytics