这里忽略solr其他依赖环境的搭建,这里搭建solr5.2.1。使用Java1.7.0_17,tomcat使用6.0.36版本的。


1、下载solr压缩文件

  Solr是Apache基金组织在lucene之上建立的一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口。Lucene是一个全文检索引擎工具包,不是一个完整的应用服务器。下载Solr的地址为:http://mirrors.hust.edu.cn/apache/lucene/solr/,这个链接中只有常用的版本和最新的版本,如果需要下载其他版本的solr,请进入链接http://archive.apache.org/dist/lucene/solr/。这里我们下载solr-5.2.1版本的solr。

2、解压solr-5.2.1.tgz,解压后目录为F:\study\solr-5.2.1,下面我将该目录设为${SOLR_HOME}。

3、将${SOLR_HOME}\server\webapps\下的solr.war复制到tomcat的webapps目录下,并启动tomcat,tomcat会自动将war包解压。

4、关闭tomcat,删除solr.war文件,修改solr文件夹名为solr5.2.1(可选)。

5、复制jar包,将${SOLR_HOME}\server\lib\ext目录下的所有jar复制到${TOMCAT_HOME}\webapps\solr5.2.1\WEB-INF\lib目录下。

6、在E盘建立一个文件夹E:\solrhome\5.2.1,设置WEB-INF下的web.xml文件。我们之后将该文件夹设为${SOLR.SOLR.HOME}

 <env-entry>
<env-entry-name>solr/home</env-entry-name>
<env-entry-value>E:\solrhome\5.2.1</env-entry-value>
<env-entry-type>java.lang.String</env-entry-type>
</env-entry>

7、复制文件${SOLR_HOME}/server/solr目录下的solr.xml和zoo.cfg两个文件到我们建立的${SOLR.SOLR.HOME}文件夹中。

8、由于Solr5.2.1中的example core位于example文件夹中,是为了使用自带jetty添加的,所以我们就直接创建新的collection。

8、在${SOLR.SOLR.HOME}文件夹中添加一个子目录core0/conf,在conf中创建两个文件,分别为:schemal.xml和solrconfig.xml文件。文件内容如下所示:

<?xml version="1.0" ?>
<schema name="core0" version="1.5">
<fieldtype name="string" class="solr.StrField" sortMissingLast="true" omitNorms="true"/>
<fieldType name="long" class="solr.TrieLongField" precisionStep="0" positionIncrementGap="0"/> <field name="id" type="string" indexed="true" stored="true" multiValued="false" required="true"/>
<field name="name" type="string" indexed="true" stored="true" multiValued="false" />
<field name="age" type="long" indexed="true" stored="true" multiValued="false" />
<field name="_version_" type="long" indexed="true" stored="true"/> <uniqueKey>id</uniqueKey> <defaultSearchField>name</defaultSearchField> <solrQueryParser defaultOperator="OR"/>
</schema>

schema.xml

<?xml version="1.0" encoding="UTF-8" ?>
<config>
<luceneMatchVersion>5.2.1</luceneMatchVersion>
<directoryFactory name="DirectoryFactory" class="${solr.directoryFactory:solr.StandardDirectoryFactory}"/> <dataDir>${solr.core0.data.dir:}</dataDir> <schemaFactory class="ClassicIndexSchemaFactory"/> <updateHandler class="solr.DirectUpdateHandler2">
<updateLog>
<str name="dir">${solr.core0.data.dir:}</str>
</updateLog>
</updateHandler> <requestHandler name="/get" class="solr.RealTimeGetHandler">
<lst name="defaults">
<str name="omitHeader">true</str>
</lst>
</requestHandler> <requestHandler name="/replication" class="solr.ReplicationHandler" startup="lazy" /> <requestDispatcher handleSelect="true" >
<requestParsers enableRemoteStreaming="false" multipartUploadLimitInKB="2048" formdataUploadLimitInKB="2048" />
</requestDispatcher> <requestHandler name="standard" class="solr.StandardRequestHandler" default="true" />
<requestHandler name="/analysis/field" startup="lazy" class="solr.FieldAnalysisRequestHandler" />
<requestHandler name="/update" class="solr.UpdateRequestHandler" />
<requestHandler name="/admin/" class="org.apache.solr.handler.admin.AdminHandlers" /> <requestHandler name="/admin/ping" class="solr.PingRequestHandler">
<lst name="invariants">
<str name="q">solrpingquery</str>
</lst>
<lst name="defaults">
<str name="echoParams">all</str>
</lst>
</requestHandler> <admin>
<defaultQuery>solr</defaultQuery>
</admin>
</config>

solrconfig.xml

9、启动Tomcat,访问http://localhost:8080/solr5.2.1/#/,我们可以看到访问以及成功,现在开始设置我们刚刚创建的core0这个collection。

10、在solr web page中创建新的core。

   

11、插入数据

  插入数据在这里介绍两种方式,第一种通过post.jar来插入数据,第二种通过solr web page来插入数据,我们先采用post.jar插入。

  使用post.jar进行插入数据:

  a) 复制${SOLR_HOME}\example\exampledocs\post.jar到${SOLR.SOLR.HOME}\core0目录下。

  b) 创建一个xml文件或者复制exampledocs文件夹下的ipod_other.xml文件,并进行修改。

  c) 结合我们之前创建的schema.xml文件,我们发现有id,name,age,_version_四个属性,其中_version_由solr自动创建。那么表示我们的xml文件中只能有id,name和age。内容参考如下:

<add>
<doc>
<field name="id">HS-14</field>
<field name="name">Tom</field>
<field name="age">20</field>
</doc>
<doc>
<field name="id">IW-02</field>
<field name="name">Benedict Bill</field>
<field name="age">19</field>
</doc>
<doc>
<field name="id">IW-04</field>
<field name="name">Bernard Bill</field>
<field name="age">23</field>
</doc>
</add>

ipod_other.xml

  d) 进入cmd命令行,移动到目标目录后,执行命令:

java -Durl=http://localhost:8080/solr5.2.1/core0/update -Ddata=files -jar post.jar ipod_other.xml

    

  e) 进入web page查看文档,http://localhost:8080/solr5.2.1/#/~cores/core0,如下图,我们可以看到文档数量在增加。

  使用web page url进行数据的插入:

  a) 进入http://localhost:8080/solr5.2.1/#/core0/documents页面,这里我们采用json数据格式进行数据的插入:

  b) 添加要插入的数据后,截图如下:

  我们可以通过query来查看数据结果:如下:

至此solr5.2.1的tomcat安装完成,在此过程中我遇到的问题,我会标志在下的:

问题一:Can't find: admin-xxx.html

  这个问题在solr5.2.1中我也不知道为什么会存在,不过将${SOLR_HOME}/example/example-DIH/solr/solr/conf目录下将admin-extra.xml、admin-extra.menu-bottom.html和admin-extra.menu-top.html复制到${SOLR.SOLR.HOME}/core2/conf目录下,重新加载core即可。

问题二: null:java.lang.RuntimeException:java.lang.LinkageError

  这个问题在apache-tomcat7.0.56中存在,我将tomcat换成tomcat6以后,就没有出现过了,问题好像是编译有冲突,不过我没找它,可以参考:

https://jira.duraspace.org/browse/DS-2293https://issues.apache.org/jira/browse/SOLR-7060

其他的就没有遇到啥问题啦,这个tomcat安装到此为止。

[solr] - solr5.2.1环境搭建 - 使用tomcat做为容器的更多相关文章

  1. [solr] - solr5.2.1环境搭建 - 使用solr自带的jetty服务器

    solr除了使用tomcat作为容器外,还可以使用其他的常用容器,比如jetty,jboos等,而且solr自身就自带jetty服务器,那么现在就solr自带的jetty服务器进行安装操作.由于sol ...

  2. solr 6.2.1环境搭建

    一:Solr简介 Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引:也可以通过 ...

  3. solr 6.6 基础环境搭建 (一)

    Apache Solr 介绍 参考博主原文链接1:http://www.cnblogs.com/blueskyli/p/7100443.html 参考博主原文链接2:http://www.cnblog ...

  4. Tomcat + solr5.2.1环境搭建

    1. 下载solr并解压后的目录为:E:\solr-5.2.1   ,  http://lucene.apache.org/solr/downloads.html 2. 将solr部署到Tomcat中 ...

  5. linux下solr5.0.0环境搭建

    1解压 linux下解压命令 tar -zxvf solr-5.0.0.tgz 2启动 linux 系统 直接切换solr-5.0.0\bin 文件夹 执行 solr star -p 8983 (如果 ...

  6. solr5.2.1环境搭建教程

    环境:w8.1 + solr5.2.1 + apache7.0+jdk1.7 解压:solr5.2.1 复制E:\solr-5.2.1\server\webapps 下的solr.war包到D:\ap ...

  7. Linux环境下java开发环境搭建二 tomcat搭建

    第一步:下载安装包并解压 # tar zxvf 压缩包名 第二步:把解压出的文件移动到/usr/local/tomcat7中 #mv 解压出来的文件夹  /usr/local/tomcat7 第三步: ...

  8. dubbo环境搭建与tomcat集成、DEMO示例、常见问题(最完整版本、带管理控制台、监控中心、zookeeper)

    以windows为例,linux基本相同,开发环境一般linux,个人环境一般windows(如果不开额外vm的话). 示例以dubbo官方自带demo为例子,进行整合和稍加修改测试. 0.dubbo ...

  9. 1.环境搭建-mysql+tomcat+myeclipse安装并配置

    一.安装mysql数据库并配置 下载地址:https://pan.baidu.com/s/1OJ3ggda7Cthl4GCxWKbTng 密码:sd6b 1.打开安装程序

随机推荐

  1. Delphi ADOQuery连接数据库的查询、插入、删除、修改

    http://blog.csdn.net/chinazhd/article/details/45047777 //查询记录 procedure TForm1.Button1Click(Sender: ...

  2. 利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开(转)

    源:利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开 //---------------------------------------------------------------- ...

  3. IOS开发-ObjC-NSString

    NSString是oc语言Foundation框架中常用的类,我根据每个方法的功能将NSString的常用方法分为创建字符串.初始化字符串.判断和比较字符串.大写和小写相互转化.字符串的截取.类型转换 ...

  4. 数据结构-String、char

    String 常用方法: 获取长度:int length = strl.length() 获取第i个字符:char iChar =  str.charAt(i) String转成字符数组:char[] ...

  5. web 前端routine

    HTML:check CSS : check Javascript: struggling 框架:—— SQL:—— http://www.cnblogs.com/kzang/tag/SQL/ web ...

  6. dp中表示无限取的写法

    dp[i][j]=dp[i-a[i][j]+dp[i-a[i]][j-1]; 其中前一项j不变表示j这一项无限取

  7. SNPs & MAF

    SNPs,全称是single nucleotide polymorphisms,SNPs等位基因频率的容易估计.采用混和样本估算等位基因的频率是种高效快速的策略.该策略的原理是:首先选择参考样本制作标 ...

  8. js原生写的微博留言板有angularjs效果

    1.HTML: <!DOCTYPE html><html><head lang="en">    <meta charset=" ...

  9. jmeter接口测试实践

    一.什么是接口测试? 接口测试是测试系统组件间接口的一种测试.接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点.测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻 ...

  10. Linux文件权限与目录配置

    一.linux文件属性 用户组概念:假如主机有两个团体,第一个团体名为projecta,里面有class1,class2,class3:第二个团体名为projecb,里面有class4,class5, ...