solr集群的创建与使用
一、SolrCloud介绍
SolrCloud(solr 云)是Solr提供的分布式搜索方案,当你需要大规模,容错,分布式索引和检索能力时使用 SolrCloud。当一个系统的索引数据量少的时候是不需要使用SolrCloud的,当索引量很大,搜索请求并发很高,这时需要使用SolrCloud来满足这些需求。
SolrCloud是基于Solr和Zookeeper的分布式搜索方案,它的主要思想是使用Zookeeper作为集群的配置信息中心。
它有几个特色功能:
1)集中式的配置信息
2)自动容错
3)近实时搜索
4)查询时自动负载均衡
二、Solr集群的系统架构
2.1 物理架构
三个Solr实例( 每个实例包括两个Core),组成一个SolrCloud
2.2 逻辑架构
索引集合包括两个Shard(shard1和shard2),shard1和shard2分别由三个Core组成,其中一个Leader两个Replication,Leader是由zookeeper选举产生,zookeeper控制每个shard上三个Core的索引数据一致,解决高可用问题。
用户发起索引请求分别从shard1和shard2上获取,解决高并发问题
2.2.1 collection
Collection在SolrCloud集群中是一个逻辑意义上的完整的索引结构。它常常被划分为一个或多个Shard(分片),它们使用相同的配置信息。
比如:针对商品信息搜索可以创建一个collection。
collection=shard1+shard2+…+shardX
2.2.2 core
每个Core是Solr中一个独立运行单位,提供 索引和搜索服务。一个shard需要由一个Core或多个Core组成。由于collection由多个shard组成所以collection一般由多个core组成
2.2.3 master或slave
Master是master-slave结构中的主结点(通常说主服务器),Slave是master-slave结构中的从结点(通常说从服务器或备服务器)。同一个Shard下master和slave存储的数据是一致的,这是为了达到高可用目的。
2.2.4 shard
Collection的逻辑分片。每个Shard被化成一个或者多个replication,通过选举确定哪个是Leade
2.3 本章实现的solr集群
Zookeeper作为集群的管理工具。
1、集群管理:容错、负载均衡。
2、配置文件的集中管理
3、集群的入口
需要实现zookeeper 高可用。需要搭建集群。建议是奇数节点。需要三个zookeeper服务器。
搭建伪分布式:
需要三个zookeeper节点
需要四个tomcat节点。
建议虚拟机的内容1G以上
三、solr集群搭建步骤
3.1 需要的工具软件
前提确保虚拟机上已经安装jdk
3.2 zookeeper集群的搭建
3.2.1 把zookeeper复制三份
3.2.2 在每个zookeeper目录下创建一个data目录
3.2.3 在data目录下创建一个myid文件,文件名就叫做“myid”。内容就是每个实例的id。例如1、2、3
编辑此文件
写入数字1即可
3.2.4 修改配置文件。
把conf目录下的zoo_sample.cfg文件改名为zoo.cfg
同样的方式,修改另外两个zookeeper
3.2.5 创建批量启动zookeeper命令文件
3.2.6 授权
3.2.7 测试
3.2.8 扩展:创建批量关闭命令
3.3 solr集群的搭建
3.3.1 创建四个tomcat实例。
3.3.2 配置solr实例
solr实例的安装与配置请参考上一篇文章https://blog.csdn.net/tianzhen620/article/details/104800331
3.3.3 修改每个Tomcat运行的端口号
3.3.4 为每个solr实例创建一个对应的solrhome
使用单机版的solrhome复制四份
3.3.5 修改solr的web.xml文件
把solr和solrhome关联起来
3.3.6 配置solrCloud相关的配置
每个solrhome下都有一个solr.xml,把其中的ip及端口号配置好
3.3.7 修改每个Tomcat的catalina.sh文件
每个tomcat都要修改
JAVA_OPTS="-DzkHost=192.168.12.128:2182,192.168.12.128:2183,192.168.12.128:2184"
3.3.8 让zookeeper统一管理配置文件
需要把solrhome/collection1/conf目录上传到zookeeper。上传任意solrhome中的配置文件即可
把配置文件上传到zookeeper,使用单机版solr下的客户端上传
命令:./zkcli.sh -zkhost 192.168.12.128:2182,192.168.12.128:2183,192.168.12.128:2184 -cmd upconfig -confdir /usr/local/solr-cloud/solrhome01/collection1/conf -confname myconf
3.3.9 查看是否上传成功
上传成功
使用quit命令退出zookeeper客户端
3.4 使用solr集群
3.4.1 创建批量启动tomcat文件,并授权
3.4.2 启动tomcat
查看日志
可以看到,四个Tomcat均已启动成功
3.4.3 访问集群
3.5 集群操作
3.5.1 创建新的Collection进行分片处理
在浏览器中输入一下命令:http://192.168.12.128:8180/solr/admin/collections?action=CREATE&name=collection2&numShards=2&replicationFactor=2
3.5.2 删除不用的collection
命令:http://192.168.12.128:8180/solr/admin/collections?action=DELETE&name=collection1
四、solrJ管理集群
4.1 添加文档
@Test
public void testAddDocument() throws Exception {
//创建一个集群的连接,应该使用CloudSolrServer创建
CloudSolrServer solrServer = new CloudSolrServer("192.168.12.128:2181,192.168.12.128:2182,192.168.12.128:2183");
//zkHost:zookeeper的地址列表
//设置一个defaultCollection属性
solrServer.setDefaultCollection("collection2");
//创建一个文档对象
SolrInputDocument document = new SolrInputDocument();
//向文档中添加域
document.addField("item_title", "测试商品");
document.addField("item_price", "100");
document.addField("id", "test001");
//把文件写入索引库
solrServer.add(document);
//提交
solrServer.commit();
}
4.2 查询文档
@Test
public void testQueryDocument() throws Exception {
//创建一个集群的连接,应该使用CloudSolrServer创建
CloudSolrServer solrServer = new CloudSolrServer("192.168.12.128:2181,192.168.12.128:2182,192.168.12.128:2183");
//设置默认的Collection
solrServer.setDefaultCollection("collection2");
//创建一个查询对象
SolrQuery query = new SolrQuery();
//设置查询条件
query.setQuery("*:*");
//执行查询
QueryResponse queryResponse = solrServer.query(query);
//去查询结果
SolrDocumentList solrDocumentList = queryResponse.getResults();
System.out.println("总记录数:"+solrDocumentList.getNumFound());
//打印
for (SolrDocument solrDocument : solrDocumentList) {
System.out.println(solrDocument.get("id"));
System.out.println(solrDocument.get("item_title"));
}
}