本文是Apache Solr介绍的姊妹篇,我将逐一分析Apache Solr的各个包,力图详细地分析Solr的设计和架构。Apache Solr由12个包组成,如下:
  1. org.apache.solr.analysis
  2. org.apache.solr.core
  3. org.apache.solr.request
  4. org.apache.solr.schema
  5. org.apache.solr.search
  6. org.apache.solr.search.function
  7. org.apache.solr.servlet
  8. org.apache.solr.tst
  9. org.apache.solr.update
  10. org.apache.solr.util
  11. org.apache.solr.util.test
  12. org.apache.solr.util.xlst
Apache Solr尚处于发展期,目前版本才是1.1.0。文档的注释非常少。我们先从使用者的角度出发,最先看到的当然是servlet,因为Solr本身是个独立的网络应用程序,需要在Servlet容器中运行来提供服务,所以servlet是用户接触的最外层。

我们看看org.apache.solr.servlet包。这个包很简单,只有两个类:SolrServlet和SolrUpdateServlet.我们很容易从类名中猜出这两个类的用途。

SolrServlet类继承HttpServlet类,只有四个方法:
  • init()
  • destroy()
  • doGet()
  • doPost()
SolrServlet类中除了普通的Java类对象(包括Servlet相关的)外,有四个Solr本身的类,还有一个Solr本身的异常。其中两个类和一个异常属于org.apache.solr.core包,两个类属于org.apache.solr.request包。属于core包的有:
  1. Config:
  2. SolrCore:
属于request包的有:
  1. SolrQueryResponse:
  2. QueryResponseWriter:
分析一下这个SolrServlet类。
   首先servlet会调用init()方法进行初始化:通过Context查找java:comp/env/solr/home来确定Solr的主目录(home),接着调用Config.setInstanceDir(home)方法设置这个实例的目录。然后通过SolrCore.getSolrCore()来获得一个SolrCore实例。
   destroy()方法将会在Servlet对象销毁时调用,仅仅调用core.close()关闭SolrCore实例。
   当用户请求进来时doPost()简单地将任务交给doGet()完成,主要的任务由doGet()完成。
分析一下doGet()方法:
  1. 使用SolrCore和doGet()参数request生成一个SolrServletRequest对象(注意:这个SolrServletRequest类不是公开类,位于org.apache.solr.servlet包中,继承了SolrQueryRequestBase类,仅仅接受SolrCore和HttpServletRequest对象作为参数)
  2. 然后SolrCore执行execute()方法(参数为SolrServletRequest和SolrQueryResponse)
由此可见,真正的处理核心是SolrCore的execute方法。下一篇文章我们继续分析。
评论
zhaoyongling721 2008-03-26   回复
支持  支持  继续分析啊  :idea:  :idea: 
imjl 2007-01-26   回复
引用
Apache Solr尚处于发展期,目前版本才是1.1.0。


这句话不准确.

SOLR是从cnet出来的,,,是cnet应用lucene出来的产物..

还有很多大型网站已经应用. 可以见wiki的介绍.
imjl 2007-01-25   回复
呵呵,,没想到有人再分析solr
发表评论

您还没有登录,请登录后发表评论

alartin
搜索本博客
最近加入圈子
存档
最新评论
评论排行榜