1.Solr介绍
官网地址:http://lucene.apache.org/solr/
2.Solr搭建
Linux命令(ctrl+Insert复制/shift粘贴)
chmod +x solr
su root/123456
yum install unzip -y
yum install lsof -y
rm –rf solr-7.1.0
ps aux|grep solr
unzip -q solr-7.0.0.zip
2.1启动SolrCloud(先步骤3,配置中文分析器)
./bin/solr start -e cloud
安心等待(记得命令在bin中,就./solr)
- 创建节点,输入2(how many Solr nodes)
- 输入端口8082/8083
- 输入项目名称,techproducts
- 选择:_default(ctrl+Backspace)
- visit: http://172.16.100.204:8082/solr
- 访问:http://172.16.100.204:8983/solr/#/techproducts/query
Starting up Solr on port 8082 using command:
"bin/solr" start -cloud -p 8082 -s "example/cloud/node1/solr"
上述命令注意目录在solr,另外开一个8084,但是不在总
2.2停止SolrCloud
bin/solr stop -all
bin/solr start -all
3.配置IK中文分析器
bin CHANGES.txt contrib dist docs example licenses LICENSE.txt LUCENE_CHANGES.txt NOTICE.txt README.txt server
/home/developer/solr-7.1.0/server/solr-webapp/webapp/WEB-INF/lib
添加jar包依赖:
cp ik-analyzer-solr5-5.x.jar /home/developer/solr-7.1.0/server/solr-webapp/webapp/WEB-INF/lib
创建classes:
mkdir /home/developer/solr-7.1.0/server/solr-webapp/webapp/WEB-INF/classes
复制文件:
cp ext.dic IKAnalyzer.cfg.xml stopword.dic /home/developer/solr-7.1.0/server/solr-webapp/webapp/WEB-INF/classes
- 把IKAnalyzer依赖的jar包添加到solr工程中
- 把IK文件放到服务器的classes中
- 指定分析器
cd /home/developer/solr-7.1.0/server/solr/configsets/_default/conf
vi managed-schema
shift+G,然后i插入,ESC+:wq保存退出
<fieldType name="text_ik" class="solr.TextField">
<analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>
</fieldType>
4.添加分析域(进入solr首页)
Schema中Add Field: name为item_title和field type为strings
5.solrjTest
http://localhost:8080/solrj/query.do
http://localhost:8080/solrj/add.do
package com.beikbank.solr.controller;
import org.apache.solr.client.solrj.SolrClient;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrClient;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.SolrDocumentList;
import org.apache.solr.common.SolrInputDocument;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import java.io.IOException;
@Controller
@RequestMapping(value = "/solrj")
public class SolrJTestController {
private static SolrClient client;
private static String url;
static {
url = "http://172.16.100.204:8082/solr/techproducts";
client = new HttpSolrClient.Builder(url).build();
}
@ResponseBody
@RequestMapping(value = "/query.do", method = RequestMethod.GET)
public void query() throws IOException, SolrServerException {
//创建连接
//创建一个查询对象
SolrQuery query = new SolrQuery();
query.setQuery("*:*");
//执行查询
QueryResponse response = client.query(query);
//取查询结果
SolrDocumentList solrDocumentList = response.getResults();
}
/**
* 保存或者更新solr数据
*/
@ResponseBody
@RequestMapping(value = "/add.do", method = RequestMethod.GET)
public void add() throws IOException, SolrServerException {
//创建连接
//创建一个文档对象
SolrInputDocument document = new SolrInputDocument();
//添加域
document.addField("id", "solrtest01");
document.addField("item_title", "测试商品");
//添加到索引库
client.add(document);
//提交
client.commit();
}
}