欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

SolrCloud搭建

程序员文章站 2024-03-02 18:31:52
...

SolrCloud

1.基于 Solr 和Zookeeper的分布式搜索方案,它的主要思想是使用 Zookeeper作为集群的配置信息中心
特色功能:
1)集中式的配置信息
2)自动容错
3)近实时搜索
4)查询时自动负载均衡
2.zookeeper作为集群的管理工具
1. 集群管理: 容错, 负载均衡
2. 配置文件的集中管理
3. 集群的入口
3.solr的安装
1:安装 Tomcat,解压缩即可。
2:解压 solr。
3:把 solr 下的dist目录solr-4.10.3.war部署到 Tomcat\webapps下(去掉版本号)。
4:启动 Tomcat解压缩 war 包
5:把solr下example/lib/ext 目录下的所有的 jar 包,添加到 solr 的工程中(\WEB-INF\lib目录下)。
6:创建一个 solrhome 。solr 下的/example/solr 目录就是一个 solrhome。复制此目录到D盘改名为solrhome  
7:关联 solr 及 solrhome。需要修改 solr 工程的 web.xml 文件
8. http://IP:8080/solr/
4.IK分词器的配置
1、把IKAnalyzer2012FF_u1.jar 添加到 solr 工程的 lib 目录下
2、创建WEB-INF/classes文件夹把扩展词典、停用词词典、配置文件放到solr工程的WEB-INF/classes目录下。
3、修改 Solrhome 的 schema.xml 文件,配置一个 FieldType,使用 IKAnalyzer
<fieldType name="text_ik" class="solr.TextField">
	<analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>
</fieldType>
5.SolrCloud, 搭建集群
(1)搭建Zookeeper集群(我们在上一小节已经完成)
(2)将已经部署完solr 的tomcat的上传到linux
(3)在linux中创建文件夹 /usr/local/solr-cloud  创建4个tomcat实例
	[[email protected] ~]# mkdir /usr/local/solr-cloud
	[[email protected] ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-1
	[[email protected] ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-2
	[[email protected] ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-3
	[[email protected] ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-4
(4)将本地的solrhome上传到linux
(5)在linux中创建文件夹 /usr/local/solrhomes ,将solrhome复制4份
	[[email protected] ~]# mkdir /usr/local/solrhomes
	[[email protected] ~]# cp -r solrhome /usr/local/solrhomes/solrhome-1
	[[email protected] ~]# cp -r solrhome /usr/local/solrhomes/solrhome-2
	[[email protected] ~]# cp -r solrhome /usr/local/solrhomes/solrhome-3
	[[email protected] ~]# cp -r solrhome /usr/local/solrhomes/solrhome-4
(6)修改每个solr的 web.xml 文件, 关联solrhome
    <env-entry>
       <env-entry-name>solr/home</env-entry-name>
       <env-entry-value>/usr/local/solrhomes/solrhome-1</env-entry-value>
       <env-entry-type>java.lang.String</env-entry-type>
    </env-entry>
(7)修改每个tomcat的原运行端口8085 8080 8009  ,分别为
    8185  8180  8109 
    8285  8280  8209 
    8385  8380  8309 
    8485  8480  8409 
6.配置集群
(1)修改每个 tomcat实例 bin 目录下的 catalina.sh 文件
	把此配置添加到catalina.sh中( 第234行 ) :
	JAVA_OPTS="-DzkHost=192.168.25.129:2181,192.168.25.129:2182,192.168.25.129:2183"
	JAVA_OPTS ,顾名思义,是用来设置JVM相关运行参数的变量 .  此配置用于在tomcat启动时找到 zookeeper集群。
(2)配置 solrCloud 相关的配置。每个 solrhome 下都有一个 solr.xml,把其中的 ip 及端口号配置好(是对应的tomcat的IP和端口)。	solrhomes/solrhome-1/solr.xml
	<solrcloud>
        <str name="host">192.168.25.129</str>
        <int name="hostPort">8180</int>
        <str name="hostContext">${hostContext:solr}</str>
        <int name="zkClientTimeout">${zkClientTimeout:30000}</int>
        <bool name="genericCoreNodeNames">${genericCoreNodeNames:true}</bool>
  	</solrcloud>
(3)让 zookeeper 统一管理配置文件。需要把 solrhome下collection1/conf 目录上传到
zookeeper。上传任意 solrhome 中的配置文件即可。
	我们需要使用solr给我们提供的工具上传配置文件:
	solr-4.10.3/example/scripts/cloud-scripts/zkcli.sh
	将solr-4.10.3压缩包上传到linux,解压,然后进入solr-4.10.3/example/scripts/cloud-scripts目录 ,执行下列命令
	
	./zkcli.sh -zkhost 192.168.25.129:2181,192.168.25.129:2182,192.168.25.129:2183 -cmd upconfig-confdir /usr/local/solrhomes/solrhome-1/collection1/conf -confname myconf
	
	-zkhost  :指定zookeeper地址列表
	-cmd    :指定命令。upconfig 为上传配置的命令
	-confdir  : 配置文件所在目录
	-confname : 配置名称