Apache Solr 剖析

来源:互联网 发布:赵泓霖网络课视频 编辑:程序博客网 时间:2024/05/09 10:33

本文是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方法。下一篇文章我们继续分析。

原创粉丝点击