1、本文將solr安裝在linux上。首先先安裝好jdk和tomcat。
配置環境:jdk8,tomcat8.5,solr7.2.1.。php
2、複製Solr文件夾中的一些文件到apache-tomcat下:
1)將 solr 壓縮包中 solr\server\solr-webapp\文件夾下有個webapp文件夾,將之複製到tomcat\webapps\目錄下,文件夾名改爲solr(任意) ;html
cp -R /usr/local/tomcat/solr-7.2.1/server/solr-webapp/webapp /usr/local/tomcat/apache-tomcat-8.5.29/webapps/
2)將 solr 壓縮包中 solr\server\lib\ext 中的 jar 所有複製到 Tomcat\ webapps\solr\WEB-INF\lib 目錄中;java
cp -R /usr/local/tomcat/solr-7.2.1/server/solr-webapp/webapp /usr/local/tomcat/apache-tomcat-8.5.29/webapps/
3)將solr壓縮包中solr/server/lib/metrics* 開頭的jar所有複製到 Tomcat\ webapps\solr\WEB-INF\lib 目錄中;mysql
cp -R /usr/local/tomcat/solr-7.2.1/server/lib/metrics*.* /usr/local/tomcat/apache-tomcat-8.5.29/webapps/solr/WEB-INF/lib/
4)將solr壓縮包中solr/server/lib/solr-dataimporthandler-* 開頭的jar所有複製到 Tomcat\ webapps\solr\WEB-INF\lib 目錄中;linux
cp -R /usr/local/tomcat/solr-7.2.1/server/lib/solr-dataimporthandler-* /usr/local/tomcat/apache-tomcat-8.5.29/webapps/solr/WEB-INF/lib/
5)在Tomcat\ webapps\solr\WEB-INF\下創建classes目錄,並將solr/server/resources/log4j.properties文件複製其中;web
cp -R /usr/local/tomcat/solr-7.2.1/server/resources/log4j.properties /usr/local/tomcat/apache-tomcat-8.5.29/webapps/solr/WEB-INF/classes/
6)在tomcat目錄下創建solrhome目錄(也能夠放在其它目錄中)spring
mkdir solrhomesql
7)複製solr/server/solr/* 全部文件到tomcat/solrhome目錄,用到建立solr的core時使用。數據庫
cp -R /usr/local/tomcat/solr-7.2.1/server/solr/* /usr/local/tomcat/apache-tomcat-8.5.29/solrhome/
3、安裝完成以後啓動tomcat,便可運行sorl。輸入路徑地址:apache
http://192.168.1.130:8089/solr/index.html
ip可根據實際狀況填寫。
4、配置solr:
編輯web.xml文件:
[root@localhost down]# vi /down/apache-tomcat-8.5.12/webapps/solr/WEB-INF/web.xml
1)配置solr下core路徑,找以下配置內容(初始狀態下該內容是被註釋掉的):
<env-entry> <env-entry-name>solr/home</env-entry-name> <env-entry-value>/down/apache-tomcat-8.5.12/solrhome</env-entry-value> //將路徑指向咱們建立的solrhome目錄。 <env-entry-type>java.lang.String</env-entry-type> </env-entry>
2)配置訪問權限:找到以下內容,並註釋掉:
<!--
<security-constraint>
<web-resource-collection>
<web-resource-name>Disable TRACE</web-resource-name>
<url-pattern>/</url-pattern>
<http-method>TRACE</http-method>
</web-resource-collection>
<auth-constraint/>
</security-constraint>
<security-constraint>
<web-resource-collection>
<web-resource-name>Enable everything but TRACE</web-resource-name>
<url-pattern>/</url-pattern>
<http-method-omission>TRACE</http-method-omission>
</web-resource-collection>
</security-constraint>
-->
至此solr的配置工做完成.
5、建立core:
一、首先在solrhome中建立mycore目錄;
二、複製solr-6.5.0\example\example-DIH\solr\solr下的全部文件到/down/apache-tomcat-8.5.12/solrhome/mycore目錄下:
三、從新啓動tomcat;
四、此時在瀏覽器輸入http://localhost:8080/solr/index.html便可出現Solr的管理界面,便可看到咱們剛纔的mycore。
6、配置IKAnalyzer的中文分詞:
一、下載IKAnalyzer,解壓後會有五個文件
ext.dic IKAnalyzer.cfg.xml solr-analyzer-ik-5.1.0.jar ik-analyzer-solr5-5.x.jar stopword.dic
1
ext.dic爲擴展字典,stopword.dic爲中止詞字典,IKAnalyzer.cfg.xml爲配置文件,solr-analyzer-ik-5.1.0.jar ik-analyzer-solr5-5.x.jar爲分詞jar包。
二、將文件夾下的IKAnalyzer.cfg.xml , ext.dic和stopword.dic 三個文件 複製到/webapps/solr/WEB-INF/classes 目錄下,並修改IKAnalyzer.cfg.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd"> <properties> <comment>IK Analyzer 擴展配置</comment> <!--用戶能夠在這裏配置本身的擴展字典 --> <entry key="ext_dict">ext.dic;</entry> <!--用戶能夠在這裏配置本身的擴展中止詞字典--> <entry key="ext_stopwords">stopword.dic;</entry> </properties>
三、在ext.dic 裏增長本身的擴展詞典,例如,惟品會 聚美優品
四、複製solr-analyzer-ik-5.1.0.jar ik-analyzer-solr5-5.x.jar到/down/apache-tomcat-8.5.12/webapps/solr/WEB-INF/lib/目錄下。
五、在 solrhome\mycore\conf\managed-schema 文件前增長以下配置
<!-- 我添加的IK分詞 -->
<fieldType name="text_ik" class="solr.TextField">
<analyzer type="index">
<tokenizer class="org.apache.lucene.analysis.ik.IKTokenizerFactory" useSmart="true"/>
</analyzer>
<analyzer type="query">
<tokenizer class="org.apache.lucene.analysis.ik.IKTokenizerFactory" useSmart="true"/>
</analyzer>
</fieldType>
注意: 記得將stopword.dic,ext.dic的編碼方式爲UTF-8 無BOM的編碼方式。
7、solr與mysql集成索引:
首先在 solrconfig.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>
而後在conf下新建data-config.xml文件。裏面內容以下:
<dataConfig> <dataSource name="source1" type="JdbcDataSource" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://數據庫ip:3306/***" user="root" password="123456" /> <document> <entity dataSource="source1" name="Goods" pk="id" query="select goods_name,seo_description,seo_keywords,goods_price,goods_main_photo_id from goods" deltaImportQuery="select * from user where id='${dih.delta.id}'" deltaQuery="select id from user where updateTime> '${dataimporter.last_index_time}'"> <field column="goods_name" name="goodsName" /> <field column="seo_description" name="seoDescription" /> <field column="seo_keywords" name="seoKeywords" /> <field column="goods_price" name="goodsPrice" /> <field column="goods_main_photo_id" name="goodsMainPhotoId" /> <field column="update_time" name="updateTime" /> </entity> </document> </dataConfig>
dataSource是數據庫數據源。Entity就是一張表對應的實體,pk是主鍵,query是查詢語句。Field對應一個字段,column是數據庫裏的column名,後面的name屬性對應着Solr的Filed的名字。其中solrdata是數據庫名,goods是表名。
其中deltaQuery是增量索引,原理是從數據庫中根據deltaQuery指定的SQL語句查詢出全部須要增量導入的數據的ID號。而後根據deltaImportQuery指定的SQL語句返回全部這些ID的數據,即爲此次增量導入所要處理的數據。核心思想是:經過內置變量「dih.delta.id」和「dih.delta.id」和「{dataimporter.last_index_time}」來記錄本次要索引的id和最近一次索引的時間。
而後把mysql所需的jar包和solr-6.2.0\dist下的solr-dataimporthandler-6.2.0.jar和solr-dataimporthandler-extras-6.2.0.jar都複製到項目WEB-INF\lib下。
啓動Tomcat,輸入http://localhost:8080/solr/index.html按以下選擇,
8、查詢參數說明:
一、經常使用
q - 查詢字符串,這個是必須的。若是查詢全部: ,根據指定字段查詢(Name:張三 AND Address:北京)
fq - (filter query)過慮查詢,做用:在q查詢符合結果中同時是fq查詢符合的,例如:q=Name:張三&fq=createDate:[2014-06-18 TO 2015-12-18],找關鍵字」張三」,而且CreateDate是查詢2014-06-18到2015-12-18之間的數據
fl - 指定返回那些字段內容,用逗號或空格分隔多個。
start - 返回第一條記錄在完整找到結果中的偏移位置,0開始,通常分頁用。
rows - 指定返回結果最多有多少條記錄,配合start來實現分頁。
sort - 排序,格式:sort=《field name>+《desc|asc>[,《field name>+《desc|asc>]… 。示例:(score desc, price asc)表示先 「score」 降序, 再 「price」 升序,默認是相關性降序。
wt - (writer type)指定輸出格式,能夠有 xml, json, PHP, phps。
fl表示索引顯示那些field( *表示全部field,若是想查詢指定字段用逗號或空格隔開(如:Name,SKU,ShortDescription或Name SKU ShortDescription【注:字段是嚴格區分大小寫的】))
q.op 表示q 中 查詢語句的 各條件的邏輯操做 AND(與) OR(或)
hl 是否高亮 ,如hl=true
hl.fl 高亮field ,hl.fl=Name,SKU
hl.snippets :默認是1,這裏設置爲3個片斷
hl.simple.pre 高亮前面的格式
hl.simple.post 高亮後面的格式
facet 是否啓動統計
facet.field 統計field
二、 Solr運算符
「:」 指定字段查指定值,如返回全部值:
「?」 表示單個任意字符的通配
「」 表示多個任意字符的通配(不能在檢索的項開始使用或者?符號)
「~」 表示模糊檢索,如檢索拼寫相似於」roam」的項這樣寫:roam~將找到形如foam和roams的單詞;roam~0.8,檢索返回類似度在0.8以上的記錄。
鄰近檢索,如檢索相隔10個單詞的」apache」和」jakarta」,」jakarta apache」~10
「^」 控制相關度檢索,如檢索jakarta apache,同時但願去讓」jakarta」的相關度更加好,那麼在其後加上」^」符號和增量值,即jakarta^4 apache
布爾操做符AND、||
布爾操做符OR、&&
布爾操做符NOT、!、- (排除操做符不能單獨與項使用構成查詢)
「+」 存在操做符,要求符號」+」後的項必須在文檔相應的域中存在
( ) 用於構成子查詢
[] 包含範圍檢索,如檢索某時間段記錄,包含頭尾,date:[200707 TO 200710]
{} 不包含範圍檢索,如檢索某時間段記錄,不包含頭尾
date:{200707 TO 200710}
/ 轉義操做符,特殊字符包括+ - && || ! ( ) { } [ ] ^ 」 ~ * ? : /
注:①「+」和」-「表示對單個查詢單元的修飾,and 、or 、 not 是對兩個查詢單元是否作交集或者作差集仍是取反的操做的符號
好比:AB:china +AB:america,表示的是AB:china忽略不計無關緊要,必須知足第二個條件纔是對的,而不是你所認爲的必須知足這兩個搜索條件
若是輸入:AB:china AND AB:america,解析出來的結果是兩個條件同時知足,即+AB:china AND +AB:america或+AB:china +AB:america
總而言之,查詢語法: 修飾符 字段名:查詢關鍵詞 AND/OR/NOT 修飾符 字段名:查詢關鍵詞
三、 Solr查詢語法
1.最普通的查詢,好比查詢姓張的人( Name:張),若是是精準性搜索至關於SQL SERVER中的LIKE搜索這須要帶引號(」「),好比查詢含有北京的(Address:」北京」)
2.多條件查詢,注:若是是針對單個字段進行搜索的能夠用(Name:搜索條件加運算符(OR、AND、NOT) Name:搜索條件),好比模糊查詢( Name:張 OR Name:李)單個字段多條件搜索不建議這樣寫,通常建議是在單個字段裏進行條件篩選,如(Name:張 OR 李),多個字段查詢(Name:張 + Address:北京 )
3.排序,好比根據姓名升序(Name asc),降序(Name desc)
4.查詢結果匹配
通常狀況下solr默認是進行拆分匹配查詢的,如:「蘇小小」拆成「蘇」,「小」,「小」等。可是若是要進行徹底匹配 「蘇小小」 能夠將關鍵詞用雙引號括起來以下:
例如 :
http://localhost:8081/solr/select/?q=name:」蘇小小」&version=2.2&start=0&rows=10&indent=on&sort=cDate desc&hl=true&hl.fl=content
注意:若是在搜索的目標上有一句話中包含這個關鍵字,那麼這段話也會被搜索到,如:「好久好久之前蘇小小就是很出名了」。千萬不要覺得只是關鍵字的內容才能搜索到。
9、項目代碼:
application.yml 中加上如上配置:
#配置sorl spring: data: solr: host: http://192.168.1.130:8089/solr/mycore
package com.tj.dr.service.impl; ... import java.util.List; @Service public class SearchServiceImpl implements SearchService { @Autowired private SearchMapper searchMapper; @Autowired private SolrClient solrClient; @Reference(version = "1.0") private UserInterfaces userInterfaces; @Reference(version = "1.0") private ConfigInterface configInterface; /** * 更新索引庫全部索引 */ @Override public void importAllIndex() { try { List<SearchGoodsDto> searchGoodsDtos = searchMapper.selectByGoodsList(); List<SolrInputDocument> documents = new ArrayList<>(); for (SearchGoodsDto goods : searchGoodsDtos) { SolrInputDocument document = new SolrInputDocument(); document.addField("id", goods.getId()); document.addField("goodsName", goods.getGoodsName()); String price = goods.getGoodsPrice().toString(); document.addField("goodsPrice", price); String url = null; if (!Common.isEmpty(goods.getGoodsMainPhotoId())) { RedpigmallAccessory pic = userInterfaces.getRedpigmallAccessoryById(Long.valueOf(goods.getGoodsMainPhotoId())); url = configInterface.getSysConfig().getDetail().getImagewebserver() + pic.getPath() + "/" + pic.getName(); } document.addField("goodsMainPhotoId", url); documents.add(document); } solrClient.add(documents); solrClient.commit(); } catch (Exception e) { e.printStackTrace(); } } /** * 分頁查詢商品 * * @param name * @param currentPage * @param pageSize * @return */ @Override public PageUtils query(String name, int currentPage, int pageSize) throws IOException, SolrServerException { SolrQuery params = new SolrQuery(); //查詢條件 params.set("q", "goodsName:" + name); //這裏的分頁和mysql分頁同樣 params.set("start", (currentPage - 1) * pageSize); params.set("rows", pageSize); params.set("wt", "json"); QueryResponse query = solrClient.query(params); //查詢結果 SolrDocumentList results = query.getResults(); List<GoodsClassNameVo> list = new ArrayList<>(); for (SolrDocument result : results) { GoodsClassNameVo searchGoodsDto = new GoodsClassNameVo(); searchGoodsDto.setId(Long.valueOf(result.get("id").toString())); searchGoodsDto.setGoodsName(String.valueOf(result.get("goodsName"))); BigDecimal goodsPrice = new BigDecimal(result.get("goodsPrice").toString()); searchGoodsDto.setGoodsPrice(goodsPrice); if (null!=result.get("goodsMainPhotoId")){ searchGoodsDto.setIcon(result.get("goodsMainPhotoId").toString()); } list.add(searchGoodsDto); } //搜索總數 long found = results.getNumFound(); //搜索開始 long start = results.getStart(); PageUtils<GoodsClassNameVo> pageUtils = new PageUtils<>(); pageUtils.setPageNum(currentPage); pageUtils.setPageSize(pageSize); pageUtils.setTotalNum(Integer.valueOf(String.valueOf(found))); pageUtils.setPageCount(Integer.valueOf(String.valueOf(found / pageSize == 0 ? found / pageSize : found / pageSize + 1))); pageUtils.setIsMore(found - start > pageSize ? 1 : 0); pageUtils.setItems(list); return pageUtils; } /** * @param * @author: ZhongQiuwu * Description:添加單個商品索引 * @Date: 13:54 2018/3/31 */ @Override public void addGoodsIndex(SearchGoodsDto searchGoodsDto) throws IOException, SolrServerException { RedpigmallAccessory pic = userInterfaces.getRedpigmallAccessoryById(Long.valueOf(searchGoodsDto.getGoodsMainPhotoId())); String url = null; if (pic != null) { url = configInterface.getSysConfig().getDetail().getImagewebserver() + pic.getPath() + "/" + pic.getName(); } SolrInputDocument document = new SolrInputDocument(); document.addField("id", searchGoodsDto.getId()); document.addField("goodsName", searchGoodsDto.getGoodsName()); String price = searchGoodsDto.getGoodsPrice().toString(); document.addField("goodsPrice", price); document.addField("goodsMainPhotoId", url); solrClient.add(document); solrClient.commit(); } /** * @param * @param ids * @author: ZhongQiuwu * Description: 根據id批量刪除 * @Date: 13:59 2018/3/31 */ @Override public void deleteGoodsIndex(String[] ids) throws IOException, SolrServerException { List list = new ArrayList<>(); for (String id : ids) { list.add(id); } solrClient.deleteById(list); solrClient.commit(); } }
歡迎工做一到五年的Java工程師朋友們加入Java架構開發:855801563
羣內提供免費的Java架構學習資料(裏面有高可用、高併發、高性能及分佈式、Jvm性能調優、Spring源碼,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構資料)合理利用本身每一分每一秒的時間來學習提高本身,不要再用"沒有時間「來掩飾本身思想上的懶惰!趁年輕,使勁拼,給將來的本身一個交代