Solr是一個(gè)高性能,采用Java開(kāi)發(fā),基于Lucene的全文搜索服務(wù)器。用戶(hù)可以通過(guò)http請(qǐng)求,向搜索引擎服務(wù)器提交一定格式的XML文件,生成索引;也可以通過(guò)Http Get操作提出查找請(qǐng)求,并得到XML格式的返回結(jié)果。提供了比Lucene更為豐富的查詢(xún)語(yǔ)言,同時(shí)實(shí)現(xiàn)了可配置、可擴(kuò)展并對(duì)查詢(xún)性能進(jìn)行了優(yōu)化,并且提供了一個(gè)完善的功能管理界面, 是一款非常優(yōu)秀的全文搜索引擎。
一、下載和安裝
本次搭建系統(tǒng)環(huán)境為Windows 10 ,Linux類(lèi)似,以后有時(shí)間會(huì)加上。
下載Solr,這次使用最新的6.1.0版本地址:
http://www.apache.org/dyn/closer.lua/lucene/solr/6.1.0下載容器,選擇比較熟悉的Tomcat,版本選擇Tomcat 8.0 地址:
http://tomcat.apache.org/download-80.cgi-
都是壓縮文件,如果你可以熟練的將壓縮包解壓到相同目錄下,最后看到這倆家伙說(shuō)明你離成功不遠(yuǎn)了..
Paste_Image.png 將
\solr-6.1.0\server\solr-webapp\webapp
文件夾 復(fù)制到\apache-tomcat-8.5.4\webapps
下,并將webapp 修改為solr。打開(kāi)
\apache-tomcat-8.5.4\webapps\solr\WEB-INF\web.xml
,修改以下配置(可能被注釋掉,先解除注釋),將solr/home修改為你的。
<env-entry>
<env-entry-name>solr/home</env-entry-name>
<!-- 這個(gè)目錄就是配置、索引、數(shù)據(jù)以后存放的地方,數(shù)據(jù)量上去后會(huì)非常龐大。 -->
<env-entry-value>E:\Server\solr-6.1.0\server\solr</env-entry-value>
<env-entry-type>java.lang.String</env-entry-type>
</env-entry>
其實(shí)到這步基本上完事了,如果你需要打印日志的話(huà),就接著配置6、7。
- 將
\solr-6.1.0\server\lib\ext
下的所有jar包復(fù)制到\apache-tomcat-8.5.4\webapps\solr\WEB-INF\lib
下. - 將
\solr-6.1.0\server\resources\log4j.properties
復(fù)制到```\apache-tomcat-8.5.4\webapps\solr\WEB-INF\classes`` 下(如果沒(méi)有classes文件夾創(chuàng)建之),好了現(xiàn)在日志也有了。
OK,現(xiàn)在運(yùn)行\apache-tomcat-8.5.4\bin\startup.bat
啟動(dòng)小貓咪, 訪問(wèn)http://127.0.0.1:8080/solr/index.html/
如果可以成功打開(kāi)的話(huà),恭喜你Solr 搭建成功了,是不是很簡(jiǎn)單...
不過(guò)這些都是小學(xué)生入門(mén)級(jí)別的配置...,更專(zhuān)業(yè)、詳細(xì)的配置見(jiàn)Solr 官方文檔及Tomcat 官方文檔
二、基本操作
有童鞋會(huì)說(shuō)了,搭建好了然后怎么提供搜索服務(wù)呢?別急,現(xiàn)在的Solr就相當(dāng)于一個(gè)空的數(shù)據(jù)庫(kù),什么還沒(méi)有,首先我們要搞一點(diǎn)數(shù)據(jù)來(lái),那么我們要先創(chuàng)建一個(gè)Core(相當(dāng)于創(chuàng)建數(shù)據(jù)表)這個(gè)Core我們叫user_core吧。
- 進(jìn)入 core home 目錄,我們現(xiàn)在配的是
\solr-6.1.0\server\solr
,在該目錄下創(chuàng)建user_core
文件夾 - 將
\solr-6.1.0\server\solr\configsets\basic_configs\conf
文件夾復(fù)制到user_core
文件夾下 -
進(jìn)入管理頁(yè)面,填寫(xiě)表單,點(diǎn)擊Add Core。
Paste_Image.png
添加成功后選擇我們的core,執(zhí)行一下查詢(xún),我們可以看到毛豆沒(méi)查出來(lái),因?yàn)楝F(xiàn)在core里空空如也~
q 就是查詢(xún)參數(shù) *:*相當(dāng)于查詢(xún)所有,至于 name:李* 就是查詢(xún)所有name以李開(kāi)頭的行
好了,我們按照下面步驟插入點(diǎn)數(shù)據(jù)吧
- 配置Schema,增加字段(剛才只是相當(dāng)于創(chuàng)建了數(shù)據(jù)表,并沒(méi)有添加字段)
2.點(diǎn)擊 Add Field,增加name(string)、age(int) 兩個(gè)字段,現(xiàn)在我們的user_core,有三個(gè)字段id、name、age
3.點(diǎn)擊左側(cè)是Documents插入數(shù)據(jù),這里選擇以json的方式,我們插入這條
{'id':1,'name':'土豆','age':20}
試試(這里的update在 id相同時(shí)執(zhí)行更新操作,不同則執(zhí)行新增操作)。
4.插入成功后再執(zhí)行下Query 看看是不是已經(jīng)可以查出來(lái)啦。
三、總結(jié)
我們可以這樣理解,Solr相當(dāng)于數(shù)據(jù)庫(kù),Core相當(dāng)于表,Documents內(nèi)的Field相當(dāng)于表中的字段。至于操作,很簡(jiǎn)單吧,也就是些CRUD操作,比操作數(shù)據(jù)庫(kù)還簡(jiǎn)單點(diǎn),但是比數(shù)據(jù)庫(kù)快多了。
Solr 提供以HTTP 請(qǐng)求的形式的API,任何語(yǔ)言都可以與之交互,下篇文章將介紹如果使用SolrJ 以Java 編程方式操作Solr,這也是使用Solr最普遍的形式。
本文是筆者剛接觸Solr時(shí)寫(xiě)下的,如果你想更多的了解 Solr 及 Solr Cloud請(qǐng)閱讀我的文集,那里更加完善 ->Solr&Solr Cloud