SolrCloud搭建

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

	

5.SolrCloud, 搭建集群
(1)搭建Zookeeper集群(我们在上一小节已经完成)
(2)将已经部署完solr 的tomcat的上传到linux
(3)在linux中创建文件夹 /usr/local/solr-cloud  创建4个tomcat实例
	[root@localhost ~]# mkdir /usr/local/solr-cloud
	[root@localhost ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-1
	[root@localhost ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-2
	[root@localhost ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-3
	[root@localhost ~]# cp -r tomcat-solr /usr/local/solr-cloud/tomcat-4
(4)将本地的solrhome上传到linux
(5)在linux中创建文件夹 /usr/local/solrhomes ,将solrhome复制4份
	[root@localhost ~]# mkdir /usr/local/solrhomes
	[root@localhost ~]# cp -r solrhome /usr/local/solrhomes/solrhome-1
	[root@localhost ~]# cp -r solrhome /usr/local/solrhomes/solrhome-2
	[root@localhost ~]# cp -r solrhome /usr/local/solrhomes/solrhome-3
	[root@localhost ~]# cp -r solrhome /usr/local/solrhomes/solrhome-4
(6)修改每个solr的 web.xml 文件, 关联solrhome
    
       solr/home
       /usr/local/solrhomes/solrhome-1
       java.lang.String
    
(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
	
        192.168.25.129
        8180
        ${hostContext:solr}
        ${zkClientTimeout:30000}
        ${genericCoreNodeNames:true}
  	
(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 : 配置名称

你可能感兴趣的:(集群搭建)