在linux上搭建Solr集群的方法有哪些?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
什么是SolrCloud
SolrCloud(solr 云)是Solr提供的分布式搜索方案,當你需要大規模,容錯,分布式索引和檢索能力時使用 SolrCloud。當一個系統的索引數據量少的時候是不需要使用SolrCloud的,當索引量很大,搜索請求并發很高,這時需要使用SolrCloud來滿足這些需求。
SolrCloud是基于Solr和Zookeeper的分布式搜索方案,它的主要思想是使用Zookeeper作為集群的配置信息中心。
Solr集群的系統架構

需要實現的solr集群架構

Zookeeper作為集群的管理工具。
1、集群管理:容錯、負載均衡。
2、配置文件的集中管理
3、集群的入口
需要實現zookeeper 高可用。需要搭建集群。建議是奇數節點。需要三個zookeeper服務器。 投票選舉 需要超過半數以上
搭建solr集群需要7臺服務器。
搭建偽分布式:
需要三個zookeeper節點
需要四個tomcat節點。
建議虛擬機的內容1G以上。
一.在linux上安裝zookeeper集群 https://blog.csdn.net/lushizhuo9655/article/details/109135460
二.在linux上搭建solr集群
Solr集群的搭建
根據單機版的操作安裝好solr和對應的業務域 https://blog.csdn.net/lushizhuo9655/article/details/109033855
第一步:創建四個tomcat實例。每個tomcat運行在不同的端口。8180、8280、8380、8480
cd /root cp -r apache-tomcat-7.0.47 /usr/local/solr-cloud/tomcat01 cp -r apache-tomcat-7.0.47 /usr/local/solr-cloud/tomcat02 cp -r apache-tomcat-7.0.47 /usr/local/solr-cloud/tomcat03 cp -r apache-tomcat-7.0.47 /usr/local/solr-cloud/tomcat04 cd /usr/local/solr-cloud/ ll
第二步:部署solr的war包。把單機版的solr工程復制到集群中的tomcat中。(記得每個tomcat的端口要記得修改 每個tomcat改三個端口)
cp -r ../solr/tomcat/webapps/solr/ tomcat01/webapps/ cp -r ../solr/tomcat/webapps/solr/ tomcat02/webapps/ cp -r ../solr/tomcat/webapps/solr/ tomcat03/webapps/ cp -r ../solr/tomcat/webapps/solr/ tomcat04/webapps/ vim tomcat01/conf/server.xml vim tomcat02/conf/server.xml vim tomcat03/conf/server.xml vim tomcat04/conf/server.xml


第三步:為每個solr實例創建一個對應的solrhome。使用單機版的solrhome復制四份。
cp -r ../solr/solrhome/ solrhome01 cp -r ../solr/solrhome/ solrhome02 cp -r ../solr/solrhome/ solrhome03 cp -r ../solr/solrhome/ solrhome04
第四步:需要修改solr的web.xml文件。把solrhome關聯起來。
vim tomcat01/webapps/solr/WEB-INF/web.xml vim tomcat02/webapps/solr/WEB-INF/web.xml vim tomcat03/webapps/solr/WEB-INF/web.xml vim tomcat04/webapps/solr/WEB-INF/web.xml
改成對應的02 03 04
第五步:配置solrCloud相關的配置。每個solrhome下都有一個solr.xml,把其中的ip及端口號配置好。
vim solrhome01/solr.xml vim solrhome02/solr.xml vim solrhome03/solr.xml vim solrhome04/solr.xml




第六步:修改tomcat/bin目錄下的catalina.sh 文件,關聯solr和zookeeper。
cd tomcat01/bin/ ll vim catalina.sh
把此配置添加到配置文件中:
JAVA_OPTS="-DzkHost=192.168.0.245:2181,192.168.0.245:2182,192.168.0.245:2183"

cd .. cd .. vim tomcat02/bin/catalina.sh vim tomcat03/bin/catalina.sh vim tomcat04/bin/catalina.sh
配置文件都加上那一句配置的代碼
第七步:讓zookeeper統一管理配置文件。需要把solrhome/collection1/conf目錄上傳到zookeeper。上傳任意solrhome中的配置文件即可。
cd solrhome01 ll cd collection1/conf
使用工具上傳配置文件:/root/solr-4.10.3/example/scripts/cloud-scripts/zkcli.sh
cd /root/solr-4.10.3/example/scripts/cloud-scripts/
配置文件的文件夾上傳到zookeeper
./zkcli.sh -zkhost 192.168.0.245:2181,192.168.0.245:2182,192.168.0.245:2183 -cmd upconfig -confdir /usr/local/solr-cloud/solrhome01/collection1/conf -confname myconf
查看zookeeper上的配置文件:
使用zookeeper目錄下的bin/zkCli.sh命令查看zookeeper上的配置文件:
./zkCli.sh

退出:
quit

使用以下命令連接指定的zookeeper服務:
./zkCli.sh -server 192.168.0.245:2183


此時表明,配置文件已經上傳到zookeeper上了

第八步:啟動每個tomcat實例。要包裝zookeeper集群是啟動狀態。
cd .. cd .. ll vim start-tomcat-all.sh
/usr/local/solr-cloud/tomcat01/bin/startup.sh /usr/local/solr-cloud/tomcat02/bin/startup.sh /usr/local/solr-cloud/tomcat03/bin/startup.sh /usr/local/solr-cloud/tomcat04/bin/startup.sh
chmod u+x start-tomcat-all.sh ./start-tomcat-all.sh
看是否起來了
tail -f /usr/local/solr-cloud/tomcat01/logs/catalina.out tail -f /usr/local/solr-cloud/tomcat02/logs/catalina.out tail -f /usr/local/solr-cloud/tomcat03/logs/catalina.out tail -f /usr/local/solr-cloud/tomcat04/logs/catalina.out
第九步:訪問集群 http://192.168.0.245:8180/solr 發現比單機的多了個cloud

第十步:創建新的Collection進行分片處理。 直接在瀏覽器
http://192.168.0.245:8180/solr/admin/collections?action=CREATE&name=collection2&numShards=2&replicationFactor=2


第十一步:刪除不用的Collection。
http://192.168.0.245:8180/solr/admin/collections?action=DELETE&name=collection1


看完上述內容,你們掌握在linux上搭建Solr集群的方法有哪些的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。