`
cxshun
  • 浏览: 724072 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

solr初体验(3)

阅读更多

前两天,学习了solr的基本用法,接下来我们就开始真正来学习一下solr。学习一下它的文件结构,配置文件等。

以我们现在学习的阶段,最重要的文件夹就是example文件夹,这个里面包含了许多我们要学习的东西。

我们再来看一下该文件夹结构

我们看到这样的文件结构,文件夹的意思大家肯定都看得懂,这里只介绍两个文件夹,multicore和solr。

multicore是多个solr实例时才需要用到,现在我们暂时没用,先不管它。solr是自带的一个solr.home,这个是我们此次介绍的重点。

进入此文件夹,我们可以看到如下的结构:

bin文件夹为我们有额外的处理脚本时,需要放在这里,这里暂时没用到,我们先跳过。

conf是solr的配置文件所在,这里是重点。

data为索引目录。

由于我以为运行过,所以有这个data.bak目录,这具是以前的备份。

我们主要来看一下conf文件夹内的配置文件:

这里带副本的是我的备份文件。最主要的文件是schema.xml和solrconfig.xml,其余的如stopwords.txt为停顿词,当索引和查询时遇到这些词会自动忽略,其他文件,我们暂时不用,先不讲了。

打开solrconfig.xml我们可以看到<dataDir>这个标签,默认情况下是这样的

<dataDir>${solr.data.dir:./solr/data}</dataDir>

  它默认在当前目录下的solr目录下创建data目录来存放索引。这就是为什么当我们把solr.home设置成这个时,在tomcat的bin文件夹内启动时会生成solr/data文件夹。因为我们启动tomat时的当前目录为bin。

当然这个不是solr配置错误,对于它自带的jetty服务器来说,它是正确的,因为当前目录,正好是solr的目录。

这个文件我们需要配置的东西不多,先讲到这里,以后用到时再慢慢讲解。

接下来我们看一下重点的schema.xml,这个文件是对我们索引字段的说明,我们可以索引什么field都在这里进行了说明。

我们可以看到里面有一大堆注释,其实看里面的注释,大部分都是可以理解的。这个文件的配置跟我们以后需要进行的中文分词的集成有很大关系,所以这个文件要多看看。

我们看到types标签,而在它里面有一大堆fieldType,里面也有一大堆属性,这里大概介绍一下:

fieldType是定义索引的field类型,它有好几个属性,最主要的是name和class:

name是类型的名称,class是相应的solr中的类。还有两个属性看英文注释可能比较难理解,是sortMissingLast和sortMissingFirst,这两个属性是指当查找出来的内容为空时,它被排在哪里,当sortMissingLast为true时,表示放在最后,sortMissingFirst为true时,表示放在最前。为false时相反。

注意,我们看到后面时发现有fieldType里面有<Analyzer>标签,这个是用于配置分词器的,这个我们以后再说。

接着是<fields>标签和在它里面的<field>,field当然就是我们在索引的内容啦。

它有属性indexed和stored分别对应是否索引和保存,另外还有一个multiValued表示是否允许多值。

这里我们看到features有好几个值,而我们看到配置文件中配置的features也是这样的:

<field name="features" type="text" indexed="true" stored="true" multiValued="true"/>

它表示我们索引的field有多个值,如果这里没配置,在发送数据的时候会报错。

这里的type是对应我们前面配置的fieldType。

另外有一个<dynamicField>这是一个动态匹配的域,

<dynamicField name="*_i"  type="int"    indexed="true"  stored="true"/>

我们看到它的name指定了通配符,它指的是可以匹配所有以_i结尾的名称的field,如果我们指定

<dynamicField name="*"/>

那我们就可以匹配所有的field。

接下来,我们看到:

 <uniqueKey>id</uniqueKey>
<defaultSearchField>text</defaultSearchField>
 <solrQueryParser defaultOperator="OR"/>
  <copyField source="cat" dest="text"/>

        这里应该看英文就可以看明白了,最主要是最下面的copyField,它是指复制field,它会把在source field里的值拷贝到text field里面,这样方便进行索引。注意,这里一般也只有对多值的才会这样做,也即是配置了multiValued为true的field才用copyField.

  

 

  • 大小: 6.8 KB
  • 大小: 2.6 KB
  • 大小: 8.2 KB
  • 大小: 12.6 KB
分享到:
评论

相关推荐

    solr初体验

    Solr初体验:深入理解开源全文搜索引擎 Solr,全称Apache Solr,是一个高度可扩展的、开源的全文搜索引擎平台。它允许开发者通过HTTP接口对大量文本数据进行高效的搜索和分析。Solr由Java编写,是Apache软件基金会...

    Solr初体验

    Solr初体验 Apache Solr 是一款开源的全文搜索引擎,基于 Lucene 库,提供了高效、可扩展的搜索和分析功能。它不仅用于网站的全文检索,还广泛应用于企业级的文档检索、商品搜索以及数据挖掘等领域。这篇博客将带你...

    solr(solr-9.0.0.tgz)

    3. **dist** 文件夹:包含Solr的JAR文件和相关的依赖库,这些文件在启动Solr时会被加载。 4. **docs** 文件夹:包含了Solr的用户文档,可以帮助开发者和管理员了解Solr的使用方法和API。 5. **example** 文件夹:...

    Apache Solr(solr-8.11.1.tgz)

    3. **dist 目录**:包含Solr的JAR文件和其他库,这些是运行Solr服务所必需的。 4. **example 目录**:提供了一个预配置的Solr实例,用于快速入门和测试。它包括一个默认的配置集,以及一个简单的数据导入处理程序...

    solr-6.2.0源码

    3. 多格式支持:Solr支持多种数据格式,如JSON、XML、CSV等,便于数据导入和处理。 4. 高级搜索功能:Solr提供丰富的查询语法,如布尔逻辑、短语匹配、模糊匹配、字段限制等,以及自定义查询解析器和过滤器。 5. ...

    solr4.7服务搭建

    3. **创建 Solr Home**:在 solr 目录下创建一个 home 文件夹(可以自定义名称)。 #### 四、部署 Solr 战包 1. **复制 solr.war 文件**:将 `D:\solr\solr-4.7.2\example\webapps` 下的 solr.war 文件复制到 `D:\...

    Apache Solr(solr-8.11.1.zip)

    3. **Lucene库**:Solr是基于Lucene,一个强大的全文搜索引擎库。Solr在其之上添加了更多高级特性,如 faceting(分面搜索),highlighting(高亮显示),以及更复杂的查询语法。 4. **配置文件**:压缩包中的配置...

    solr.war包solr.war包solr.war包solr.war包solr.war包

    solr.warsolr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包...

    solr服务器_solr_

    3. **Collection**:在SolrCloud模式下,多个Core可以组成一个Collection,提供水平扩展和数据分布的能力。Collection是Solr集群中数据管理和查询的基本单位。 4. **Schema**:Schema定义了Solr如何解析和存储数据...

    solr-7.4.0.zip

    3. `dist`目录:包含了Solr的jar文件和其他依赖库。 4. `example`目录:提供了一个简单的Solr示例,包括一个预配置的Solr实例,可以快速启动并开始使用Solr。 5. `docs`目录:包含了Solr的文档,包括用户手册、API...

    solr安装包下载地址

    Solr,全称为Apache Solr,是一款开源的企业级搜索平台,由Apache软件基金会开发并维护。它是基于Java的,能够处理大量数据并提供...通过深入学习和实践,你可以充分利用Solr的特性,为你的项目带来卓越的搜索体验。

    solr(solr-9.0.0-src.tgz)源码

    3. **源码结构** 解压后的源码包`solr-9.0.0`包含了以下几个关键部分: - `server`: 存放Solr服务器端代码,如SolrJetty容器、管理API等。 - `contrib`: 第三方贡献的模块,如数据导入工具等。 - `dist`: 发布的...

    解决solr启动404问题

    Solr是Apache Lucene项目的一个子项目,是一个高性能、基于Java的企业级全文搜索引擎服务器。当你在尝试启动Solr时遇到404错误,这通常意味着Solr服务没有正确地启动或者配置文件设置不正确。404错误表示“未找到”...

    ikanalyzer-solr8.4.0_solr8_solr_ikanalyzer_中文分词_

    ikanalyzer 是一个专门为Java开发的中文...总之,ikanalyzer-solr8.4.0 是 Solr 8.4.0 版本下用于中文分词的重要工具,通过合理的配置和使用,可以显著提高 Solr 对中文文本的处理能力,从而提升搜索质量和用户体验。

    ikanalyzer-solr中文分词包兼容solr7.5

    在Solr中集成ikanalyzer,可以提高中文搜索的性能,使得搜索结果更加准确,用户体验得到提升。 在实际应用中,安装ikanalyzer-solr分词包的步骤大致如下: 1. 将`ik-analyzer-solr5-5.x.jar`添加到Solr服务器的`...

    solr的学习

    3. 打开 SolrHome 目录。 4. SolrCore 创建成功。 - **配置 SolrCore** - **solrconfig.xml**:配置 SolrCore 实例的相关信息。 - **lib 标签**:加载一些扩展的 jar 包。 - **datadir 标签**:指定数据文件...

    Linux上Solr的启动方式

     (3)当服务启动后,默认发布在8983端口,所以可以访问该端口来访问Solr服务,打开浏览器输入网址:http://http://192.168.247.133:8983/solr/访问。(192.168.247.133是我的虚拟机网址,通过ip ad

    solr ik分词器

    3. **配置Solr核心**:接下来,你需要在你的Solr核心(collection)配置文件`solrconfig.xml`中添加IK分词器的相关配置。在`&lt;requestHandler&gt;`或者`&lt;searchComponent&gt;`部分添加以下代码: ```xml &lt;filter class="...

    solr-4.10.3

    5. **Highlighting(高亮显示)**:4.10.3版本的Solr支持查询结果中的关键词高亮,提升用户体验,帮助用户快速定位到匹配的搜索内容。 6. **复制和更新策略**:Solr允许设置复制和更新策略,如实时索引更新,确保...

    solr-4.4.0.tgz

    3. **部署到 Tomcat**: - 确保你的系统已经安装了 Apache Tomcat,这是 Solr 运行的一个常见容器。 - 将 Solr 的 `server/solr-webapp/webapp` 目录复制到 Tomcat 的 `webapps` 目录下。 - 在 Tomcat 的 `conf/...

Global site tag (gtag.js) - Google Analytics