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"));
		}
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值