solr入门

solr环境搭建

下载solr6.2和配置jdk,tomcat略过

说明:
solr_home:用来放core
core:装索引和数据的地方
document:索引和数据
Field:字段,相当于数据库的字段
FieldType:字段类型

1. 配置solr项目
  • 解压下载的solr,把solr-6.2.0\server\solr-webapp下的webapp复制到tomcat\webapps下并更名为solr

solr项目内容:


  • solr-6.2.0\server\lib\ext下的jar包复制到tomcat-8.5.9\webapps\solr\WEB-INF\lib
  • 把问\solr-6.2.0\dist下含“dataimport”的jar包也复制到如上位置(该jar包用来导入数据)

  • solr-6.2.0\example\resources*下的log4j.properties复制到tomcat-8.5.9\webapps\solr\WEB-INF\classes*下(没有classes改目录先创建)

2. 配置solr核心目录
  • 在任意位置创建solr_home目录,并且把*\solr-6.2.0\example\example-DIH\solr\*下的任意一个core和solr.xml放到solr_home目录下(这里我选的是solr)

solr_home内容:

  • tomcat-8.5.9\webapps\solr\WEB-INF\web.xml中指明solr_home
    <env-entry>
       <env-entry-name>solr/home</env-entry-name>
       <env-entry-value>D:\tomcat-8.5.9\webapps\solr\solr_home</env-entry-value>
       <env-entry-type>java.lang.String</env-entry-type>
    </env-entry>
3. 查看配置界面

启动tomcat,输入地址:

http://localhost:8080/solr/index.html

界面操作后面再细谈




solr配置中文分词

1. 下载IKAnalyzer中文分词包并解压

http://download.csdn.net/detail/by_false/9645175

整合包内容:

2. 配置IKAnalyzer中文分词
  • 把ik-analyzer-solrx.jar复制到*tomcat-8.5.9\webapps\solr\WEB-INF\lib*
  • 把如整合包中的如下文件复制*tomcat-8.5.9\webapps\solr\WEB-INF\lib\classes*下
  • 编辑solr_home\solr\conf\managed-schema,添加
    <fieldType name="text_ik" class="solr.TextField">  
        <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>  
    </fieldType> 
3. 测试分词




solr导入数据库

1. 引入mysql-connectX.jar包

注意:版本不一样也可能导致失败,这里使用5.x版本成功

2. 编辑配置文件
  • solr_home\solr\conf\solrconfig.xml添加如下标签
<requestHandler name="/dataimport" class="solr.DataImportHandler">
    <lst name="defaults">
      <str name="config">solr-data-config.xml</str> <!--该文件名可以任意,但创建的文件要与之对应-->
    </lst>
  </requestHandler>
  • 编辑/创建solr_home\solr\conf\solr-data-config.xml,添加如下内容(具体请根据需求配置)
<dataConfig>
<dataSource name="source1"
            type="JdbcDataSource"
            driver="com.mysql.jdbc.Driver"
            url="jdbc:mysql://192.168.88.112:3306/ppppx?characterEncoding=utf-8&autoReconnect=true"
            user="root"
            password="root">
</dataSource>

  <document>
    <entity name="test" dataSource="source1" query="SELECT goods_id,goods_price,goods_name,goods_jingle,store_id,store_name,goods_image FROM ppppx_goods">
        <!--当数据库字段名和managed-schema字段不一致时配置

        <field column="goods_id" name="goods_id" />
        <field column="goods_name" name="goods_name" />
        <field column="goods_jingle" name="goods_jingle" />
        <field column="goods_price" name="goods_price" />
        <field column="store_id" name="store_id" />
        <field column="store_name" name="store_name" />
        <field column="goods_image" name="goods_image" />
        -->
        
    </entity>
  </document>
</dataConfig>
<!--
    <entity name="entity名称" dataSource="选择一个数据源" query="查询语句,得到的结果会在solr的core中建立索引">
        <field column="数据库表字段" name="业务字段" /> //业务字段需要与managed-schema中的Field对应
    </entity>
-->
  • 编辑solr_home\solr\conf\managedo-schema.xml,添加
<!--业务字段-->
   <field name="goods_id" type="int" indexed="true" stored="true" required="true" multiValued="false" /> 
   <field name="goods_name" type="text_ik" indexed="true" stored="true" /><!--需要使用中文分词的type选"text_ik"-->
   <field name="goods_price" type="double" indexed="true" stored="true" />
   <field name="goods_jingle" type="text_ik" indexed="true" stored="true" />
   <field name="store_id" type="int" indexed="true" stored="true" />
   <field name="store_name" type="text_ik" indexed="true" stored="true" />
   <field name="goods_image" type="string" indexed="true" stored="true" />

   <!--为copyFiled配置字段-->
   <field name="goods_search" type="text_ik" indexed="true" stored="false" multiValued="true"/>
   <!--为copyFiled配置字段-->
   <!--业务字段-->

修改

<uniqueKey>id</uniqueKey>

为,并且注释掉id字段

<!--<field name="id" type="string" indexed="true" stored="true" required="true" multiValued="false" />-->
<uniqueKey>goods_id</uniqueKey>

注意:编辑完成后,记得使用utf-8的编码保存

<font color="red">补充:字段详解</font>

3. 页面导入数据

导入可能出错,可以看tomcat启动时的java窗口

  • 查询测试


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容