Web搜索引擎设计和实现分析_第1页
Web搜索引擎设计和实现分析_第2页
Web搜索引擎设计和实现分析_第3页
Web搜索引擎设计和实现分析_第4页
Web搜索引擎设计和实现分析_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Web搜索引擎设计和实现分析XX大学计算机系1XX海峰塑化2胡朝晖1王海瑛2-一、引言-随着Internet的飞速开展,人们越来越依靠网络来查找他们所需要的信息,但是,由于网上的信息源多不胜数,也就是我们经常所说的RichData,PoorInformation。所以如何有效的去发现我们所需要的信息,就成了一个很关键的问题。为了解决这个问题,搜索引擎就随之诞生。-现在在网上的搜索引擎也已经有很多,比拟著名的有AltaVista,InfoSeek,Metacrawler,SavvySearcI#等。国内也建立了很多的搜索引擎,比方:搜狐、新浪、北极星等等,当然由于它们建立的时间不长,在信息搜索的

2、取全率和取准率上都有待于改良和提高。-AltaVista是一个速度很快的搜索引擎,由于它强大的硬件配置,使它能够做及其复杂的查询。它主要是基于关键字进展查询,它漫游的领域有Web和Usenet。支持布尔查询的AND,OR和NOT,同时还加上最相近定位NEAR,允许通配符和向后搜索比方:你可以查找到某一页的所有Web站点。你可以决定是否对搜索的短语加上权值,在文档的什么部位去查找它们。能够进展短语查询而不是简单的单词查询的优点是很明显的,比方,我们想要查找一个短语tobeornottobe,如果只是把它们分解成单词的话,这些单词都是属于StopWord,这样这个查询就不会有任何结果,但是把它当作

3、一个整体来查询,就很容易返回一些结果,比方关于哈姆雷特或者是莎士比亚等等的信息。系统对查询结果所得到的网页的打分是根据在网页中所包含的你的搜索短语的多少,它们在文档的什么位置以及搜索短语在文档内部之间的距离来决定的。同时可以把得到的搜索结果翻译成其他的语言。-Exite是称为具有智能的搜索引擎,因为它建立了一个基于概念的索引。当然,它所谓的智能”是基于对概率统计的灵活应用。它能够同时进展基于概念和关键字的索引。它能够索引Web,Usenet和分类的广告。支持AND,OR,NOT等布尔操作,同时也可以使用符号+和-。缺点是在返回的查询结果中没有指定网页的尺寸和格式。-InfoSeek是一个简单但

4、是功能强大的索引,它的一个优点是有一个面向主题搜索的可扩展的分类。你可以把你的搜索短语和相似的分类目录的主题短语相互参照,而那些主题短语会自动加到你的查询中去。使你的搜索有更好的主题相关性。同时它也支持对图象的查询。它能够漫游Web,Usenet,UsenetFAQs等等。不支持布尔操作,但是可以使用符号+和-”相当于AND和NOT”-实际上不能称为是一个搜索引擎站点,但是它提供了一个分层的主题索引,使你能够从一个通常的主题进入到一个特定的主题,对Web进展了有效的组织和分类。比方你想要建立一个网页,但是你不知道如何操作,为了在上找到关于建立网页的信息,你可以先在上选择一个主题:计算机和Int

5、ernet,然后在这个主题下,你可以发现一些子主题,比方:Web网页制作,CGI编程,JAVA,HTML,网页设计等,选择一个和你要找的相关的子主题,最终你就可以得到和该子主题相关的所有的网页的。也就是说,如果你对要查找的内容属于哪个主题十分清楚的话,通过目录查询的方法要比一般的使用搜索引擎有更好的准确率。你可以搜索的索引,但是事实上,你并没有在搜索整个Web。但是提供了选项使你可以同时搜索其他的搜索引擎,比方:AltaVistao但是要注意的是实际上只是对Web的一小局部进展了分类和组织,而且它的实效性也不是很好。-搜索引擎的根本原理是通过网络机器人定期在web网页上爬行,然后发现新的网页,

6、把它们取回来放到本地的数据库中,用户的查询请求可以通过查询本地的数据库来得到。如每天会找到大约500万个新的网页。-搜索引擎的实现机制一般有两种,一种是通过手工方式对网页进展索引,比如的网页是通过手工分类的方式实现的,它的缺点是Web的覆盖率比拟低,同时不能保证最新的信息。查询匹配是通过用户写入的关键字和网页的描述和标题来进展匹配,而不是通过全文的匹配进展的。第二种是对网页进展自动的索引,象AltaVista那么是完全通过自动索引实现的。这种能实现自动的文档分类,实际上采用了信息提取的技术。但是在分类准确性上可能不如手工分类。-搜索引擎一般都有一个Robot定期的一些站点,来检查这些站点的变化

7、,同时查找新的站点。一般站点有一个robot.txt文件用来说明效劳器不希望Robot的区域,Robot都必须遵守这个规定。如果是自动索引的话,Robot在得到页面以后,需要对该页面根据其内容进展索引,根据它的关键字的情况把它归到某一类中。页面的信息是通过元数据的形式保存的,典型的元数据包括标题、IP地址、一个该页面的简要的介绍,关键字或者是索引短语、文件的大小和最后的更新的日期。尽管元数据有一定的标准,但是很多站点都采用自己的模板。文档提取机制和索引策略对Web搜索引擎的有效性有很大的关系。高级的搜索选项一般包括:布尔方法或者是短语匹配和自然语言处理。一个查询所产生的结果按照提取机制被分成不

8、同的等级提交给用户。最相关的放在最前面。每一个提取出来的文档的元数据被显示给用户。同时包括该文档所在的URL地址。-另外有一些关于某一个主题的专门的引擎,它们只对某一个主题的内容进展搜索和处理,这样信息的取全率和精度相对就比拟高。-同时,有一类搜索引擎,它本身不用Robot去定期的采集网页。象SavvySearch口MetaCrawler是通过向多个搜索引擎同时发出询问并对结果进展综合返回给用户实现搜索功能。当然实际上象SavvySearch能够对各个搜索引擎的功能进展分析和比拟,根据不同的用户查询提交给不同的搜索引擎进展处理,当然用户自己也可以指定利用哪一个搜索引擎。-一个优秀的搜索引擎必须

9、处理以下几个问题:1网页的分类2自然语言的处理3搜索策略的调度和协作4面向特定用户的搜索。所以很多搜索引擎不同程度的使用了一些人工智能的技术来解决这些方面的问题。-二、网络Spider的实现描述-现在有很多文章对Web引擎做了大量的介绍和分析,但是很少有对它们的实现做一个详细的描述,这里我们主要来介绍一个具有根本功能的Web引擎的实现。本文,我们以类C+语言的形式来描述Web引擎如何采集网页并存放到数据库中的过程。同时描述了如何根据用户输入的关键字查询数据库并得到相关网页的过程。-2.1数据库构造-首先,我们要建立一个数据库表用来存放我们得到的网页。这里一般需要建立如下的表:-1.字典表的建立

10、,事实上这里是用文档中有意义的单词和它们的出现频率来代表一个文档。-该表WordDictionaryTbl主要要包括三个字段,主要是用来存放和一个网页相关的单词的情况url_id对每一个URL的唯一的ID号word该URL中的经过stem的单词intag该单词在该网页中白出现的次数-2.存储每一个URL信息的表-该表(URLTbl)中主要的关键字段有:recid每一条记录的唯一的ID号status得到该URL内容的状态,比方HTTP_STATUS_TIMEOUT表示下载网页的最大允许超时urlURL的字符串名称content_type内容的类型last_modified最新的更改时间title

11、该URL的标题docsize该URL的文件的尺寸last_index_time最近一次索引的时间next_index_time下一次索引的时间tag对于网页,用来表示它的类型,比方:是text,或者是html,或者是图片等等hops得到文件时候的曾经失败的次数keywords对于网页,和该网页相关的关键字description对于网页,指网页的内容的描述lang文档所使用的语言-3.因为网页中有很多单词是一些介词和语气助词或者是非常常用的常用词,它们本身没有多少意义。比方:英语中的about,in,at,we,this等等。中文中的如和,一起,关于等等。我们统一的把它们称为停顿词stopwor

12、d。所以我们要建立一个表,来包括所有这些停顿词。该表(StopWordTbl)主要有两个字段。wordchar(32)表示那些停顿词langchar(2)表示所使用的语言-4.我们要建立一个关于robot的表,我们在前面说过,所有的一般都有一个robot.txt文件用来表示网络上的robot可以的权限。该表(RobotTbl)主要有以下字段。hostinfoWeb站点主机的信息path不允许robot的目录-5.建立我们需要屏蔽的那些网页(比方一些内容不XX的或者没有必要去搜索的站点)的一张表(ForbiddenTbl),主要的字段就是网页的URL。-6.另外我们需要建立一个我们所要得到的文件

13、类型的表(FileTypeTbl),比方,对于一个简单的Web搜索引擎,我们可能只需要得到后缀为.html,htm,.shtml和txt的类型文件。其他的我们只是简单的忽略它们。主要的字段就是文件的类型和说明。-其中关于停顿词的表的内容是我们要实现要根据各种语言的统计结果,把那些意义不大的单词放进去。关于文档单词、URL和Robot的表的内容都是在获取Web网页的时候动态增加记录的。-2.2具体网页获取算法描述-具体的网页的获取步骤是这样的:-我们可以设定我们的搜索程序最大可以开的线程的数目,然后这些线程可以同时在网上进展搜索,它们根据数据库中已有的关于网页的信息,找出那些需要更新的网页如何判

14、断哪些网页需要更新是一个值得研究的过程,现在有很多启发式和智能的算法,根本上是基于统计规律进展建模。最简单的当然是设定一个时间范围,在某个时间范围以前的网页被重新去搜索一遍,然后判断那些网页是否在屏蔽表中,如果是的话,就从关于URL的表中删除该条记录。否那么,我们就到相应的站点去得到URL指定的文件(这里需要注意的是根据不同的URL的特点,需要使用不同的协议,比方对于FTP站点要采用FTP协议,对于HTTP站点要采用HTTP协议,新闻站点要采用NNTP协议等等)事实上,我们先得到关于该网页的头信息,如果该网页的最新修改时间和我们最近提取的时间是一样的话,表示该网页内容没有任何更新,那么我们就不

15、必去得到它的内容,只需要修改最近一次更新它的时间为当前的时间就可以了。如果该网页最近做了修改,我们就要得到该网页,并对它的内容进展分析,主要要包括和它相关的,把它们加到相应的数据库中,同时判断网页所包含的各种其他的文件,如文本文件、图形文件、声音文件和其他多媒体文件是否是我们所需要的文件,如果是的话,就把它加到我们响应的数据库中。同时要根据网页的内容提取所有的有意义的单词和它们的出现的次数,放到相应的数据库中。为了更好的描述这个过程,我们来看跟这个过程相关的主要的几个对象和数据构造。对象主要是针对三个层次来讲的。第一层是针对效劳器,第二层是针对每一个页面,第三层是针对每一个页面的全文的索引。-

16、2.3和实现相关的主要类对象和功能描述下面的构造是针对一个站点来说的。ClassCServer主要的属性有:char*url;/站点的URL名称char*proxy;/使用的代理的名称char*basic_auth;/进展根本的HTTP认证intproxy_port;/代理的端口号intperiod;/再次索引的周期intnet_errors;/网络连接不通的次数intmax_net_errors;/可以允许的最大的网络错误intread_timeout;/下载文件允许的最大的延迟intmaxhops;表示URL可以最大跳转的深度intuserobots;/是否遵守robot.txt中的约定i

17、ntbodyweight;/在.之间的单词的权重inttitleweight;/在.之间的单词的权重inturlweight;/在文档的URL中的单词的权重intdescweight;/在之间单词的权重intkeywordweight;/在之间的单词的权重一主要方法有:FindServer();/用来查找该效劳器是否存在并可以连接FillDefaultAttribute()用来针对所有的效劳器填写默认的属;以上的对象中的成员变量是和一个站点相关的参数的设置,我们对所有的站点有一个默认的设置,但是可以对某些站点做一些特殊的设置。这些设置可以在配置文件中设定。-下面是关于文档的构造的主要的数据成员

18、:ClassetDocument主要属性有:inturl_id;/该URL的ID号intstatus;/获取该文档时候的状态intsize;文档的尺寸inttag;/和该文档相关的标签,表示该文档是HTML,TEXT或者是其他类型inthops;/URL跳转的次数char*url;和该文档相关的URL的名称char*content_type;/该内容的类型char*last_modified;/最近一次的更新时间char*title;/该文档的标题char*last_index_time;/上次索引的时间char*next_index_time;/下次索引的时间char*keywords;/该

19、文档中的关键字char*description;/该文档的描述主要方法有:FillDocInfo()根据数据库,得到该文档相关信息AddHerf()参加网页中存在的新的的网址DeleteURL()删除一个存在的网址CanGetThisURL()根据配置决定是否去得到该网页下面三个方法是根据不同的URL,用不同的协议去获得文档NNTPGet()FTPGet(.)HTTPGet(.)ParseHead(一)如果是HTTP协议得到的话,分析头信息ParseMainBody()/对获得的文档的主体进展分析ServerResponseType(.)/得到效劳器端的响应消息UpdateURLDB(.)/更

20、新的数据入库;-事实上,我们在要提取一个网页的时候,都要建立一个etDocument对象,然后再对这个网页进展分析的时候,把相关的内容放到这个etDocument的成员变量里面。下面是关于页面全文索引的构造的主要数据成员:ClassCIndexer主要属性有:char*url;/我们要处理的文档相关的URL的名称intmwords;/我们事先设定的一个网页的最大的单词数目intnwords;/实际的得到的单词的数目intswords;/我们已经排序的单词的数目WORD*Word;/所有单词的内容char*buf;/我们为文档所分配的空间主要方法有:InitIndexer()进展初始设置和分配P

21、arseGetFile()/对得到的网页进展全文索引AddWord()/把网页的可以索引的单词加到Word数组中去InToDB(.)/关于网页全文索引的信息入库;-进展网页提取前,我们要建立一个CIndexer对象,它主要是用来对网页进展全文的索引。一般来说我们只对两种类型的URL进展全文索引,一个是text/html,另外一个是text/plain。其中WORD的数据构造如下:typedefstructword_structintcount;/该单词出现的次数intcode;/该单词的正常的形式,比方单词可能为encouraging它的正常的形式应该为encourage这其实是一种又司的st

22、em。即我们只取单词的主干局部。char*word;/该单词白内容WORD;-以下的构造是和网页中的一些的对象相关的一个数据构造typedefstructhrefstructchar*href;/该的名称inthops;/发生的跳转次数intstored;/是否已经存储到数据库中HREF;-所有需要更新的和新产生的URL都被放到这个构造中,当它的数量超过一定的范围以后,被一次性的存入数据库。-关于URL的一个数据构造如下:typedefstructurlchar*schema;/表示该URL是通过什么协议得到的,比方HTTP,FTP,NNTP等。char*specific;主机的名称加上路径c

23、har*hostinfo;/主机的名称加上相关的协议端口char*hostname;/主机的名称char*path;/在主机的具体的路径charfilename;/文件的名称char*anchor;/相关的anchorintport;/协议相关的端口URL;-这是针对URL的一些相关的属性的描述的一个数据构造。事实上在数据库中,我们存储的只是对网页的描述和对一些文本和HTML页面的关键词的索引信息。我们并不存储网页的实际的内容。-三、用户查询实现描述-关于对用户提交的查询请求的实现分析:-用户想要查询某一方面的信息一般都是通过提供和该领域相关的几个关键字来进展的。-我们来看一下关于用户查询的相

24、关的数据构造和类:-下面是一个关于单词和它的权值的根本构造:typedefstructword_weight_paircharwordWORD_LEN;intweight;word_weight_pair;-下面的类主要是用来对用户的查询进展处理和分析:ClassCUserQuerycharm_UserQueryMAX_QUERYLEN;用户的查询表达式CPtrArrayword_weight_col;/是关于构造word_weight_pair的动态数组intm_maxReturnSum;/用户希望返回的最多的网页数intsearch_mode;CObArraym_returnDoc;/是关于etDocument对象的一个动态数组NormalizeWordchar*OneWord;/对单词进展归整化,即Stem.Find(char*odbame);/进展数据库查找和匹配;-系统实现的根本的步骤如下:-1.对用户输入的查询表达式进展分析。事实上,我们在前面的Spider搜索过程中对文档的表示是通过关键字形式描述的,每一个文档可以表示为这样的一个集合其中:=-实际上就是采用矢量空间的表示方法来表示的文档。-我们对用户输入的查询表达式也采用矢量空间的表示方法。我们认为用户输入的关键字

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论