solr6.6教程-从mysql数据库中导入数据(三)

整理多半天的solr6.6,终于算是把solr6.6中配置数据库弄出来了,网上的文章千篇一律,各说个的,没有一篇统一覆盖solr6.6版本配置的 帖子,本章节我会把配置的一些注意事项一一列举,由于时间原因,本片只介绍如何一次性导入数据,不附带增量导入,想看增量的同学可以在后面的文章中。

1,配置准备

本文的前提是你已经配置好了solr,并新创建了一个core,我们下面都会按照前一篇文章中的core_demo为基础开始

2,修改soreconfig.xml

在soreconfig.xml的<requestHandler name="/select" class="solr.SearchHandler">上面添加如下代码:

    <requestHandler name="/dataimport" class="org.apache.solr.handler.dataimport.DataImportHandler">
   <lst name="defaults">
   <str name="config">data-config.xml</str>
   </lst>
  </requestHandler>

注意:需要确认文件中不存在其他的dataimport,如果存在直接替换即可

在同级目录下创建data-config.xml文件,然后配置数据库相关属性

<?xml version="1.0" encoding="UTF-8"?>
<dataConfig>
<dataSource name="source1" type="JdbcDataSource"
driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://127.0.0.1:3306/ecejcallcenter"
user="root"
password="123456" />
<document>
<entity name="cc_bill" dataSource="source1" pk="bill_id"
query="SELECT cc_bill.bill_id,cc_bill.`name`,cc_bill.address,cc_bill.city_name,cc_bill.create_time FROM cc_bill">
<field column='bill_id' name='billid' />
<field column='name' name='name' />
<field column='address' name='address' />
<field column='city_name' name='cityname' />
<field column='create_time' name='createtime' dateTimeFormat='yyyy-MM-dd HH:mm:ss' />
</entity>
</document>
</dataConfig>

  关于详细的配置请参照:http://blog.csdn.net/boolbo/article/details/50352331

   官方wiki:https://cwiki.apache.org/confluence/display/solr/

3,配置managed-schema.xml

<?xml version="1.0" encoding="UTF-8" ?>

<schema name="example" version="1.6">

   <field name="billid" type="int" indexed="true" stored="false"/>
<field name="name" type="string" indexed="true" stored="true"/>
<field name="address" type="string" indexed="true" stored="true"/>
<field name="cityname" type="string" indexed="true" stored="true"/>
<field name="createtime" type="date" indexed="true" stored="true"/> <field name="_version_" type="long" indexed="false" stored="false"/>
<field name="text" type="string" indexed="true" stored="false" multiValued="true"/>
<field name="_root_" type="string" indexed="true" stored="false" docValues="false" /> <uniqueKey>billid</uniqueKey> <fieldType name="string" class="solr.StrField" sortMissingLast="true" />
<fieldType name="int" class="solr.TrieIntField" docValues="true" precisionStep="" positionIncrementGap=""/>
<fieldType name="long" class="solr.TrieLongField" docValues="true" precisionStep="" positionIncrementGap=""/>
<fieldType name="date" class="solr.TrieDateField" docValues="true" precisionStep="" positionIncrementGap=""/> </schema>

网上很多教程说到schema.xml,这个文件是solr之前的版本中用到的,6.6版本是不需要的,直接修改上面的文件就可以。

4,拷贝jar

拷贝solr-6.6.0\dist路径下的solr-dataimporthandler-6.6.0.jar,solr-dataimporthandler-extras-6.6.0.jar 到E:\Java\tomcat\apache-tomcat-8.0.26-windows-x64\webapps\solr\WEB-INF\lib目录下

同时拷贝mysql-connector-java-5.1.40.jar链接jar到该目录下

不需要修改任何配置文件即可,继续下面的步骤

5,修改jar配置路径

继续打开solrconfig.xml 找到lib标签,修改jar的路径,下面贴上我本地修改后的路径

  <lib dir="E:\Java\components\solr-6.6.0/contrib/extraction/lib" regex=".*\.jar" />
<lib dir="E:\Java\components\solr-6.6.0/dist/" regex="solr-cell-\d.*\.jar" /> <lib dir="E:\Java\components\solr-6.6.0/contrib/clustering/lib/" regex=".*\.jar" />
<lib dir="E:\Java\components\solr-6.6.0/dist/" regex="solr-clustering-\d.*\.jar" /> <lib dir="E:\Java\components\solr-6.6.0/contrib/langid/lib/" regex=".*\.jar" />
<lib dir="E:\Java\components\solr-6.6.0/dist/" regex="solr-langid-\d.*\.jar" /> <lib dir="E:\Java\components\solr-6.6.0/contrib/ltr/lib/" regex=".*\.jar" />
<lib dir="E:\Java\components\solr-6.6.0/dist/" regex="solr-ltr-\d.*\.jar" /> <lib dir="E:\Java\components\solr-6.6.0/contrib/velocity/lib" regex=".*\.jar" />
<lib dir="E:\Java\components\solr-6.6.0/dist/" regex="solr-velocity-\d.*\.jar" />

不需要添加任何jar即可

6,重启tomcat,刷新solr页面即可看到下面界面

solr6.6教程-从mysql数据库中导入数据(三)

full-import 全量导入,delta-import-增量导入

点击Execute就可以导入了,点击左侧Query可查询导入的数据

solr6.6教程-从mysql数据库中导入数据(三)

上一篇:js动态加载html,加载后的页面元素某些事件失效的解决方案


下一篇:深入理解ASP.NET的内部运行机制(转)