前言
本文介绍的Solr版本:solr-7.7.3
部署环境:windows
Solr的两种部署模式:
Solr程序包安装好后,可以以两种模式来启动solr服务器:
Standalone Server 独立服务器模式
适用于数据规模不大的场景
SolrCloud 分布式集群模式
适用于数据规模大,高可靠、高可用、高并发的场
独立服务器模式架构
1、每个solr服务器实例(启动的一个solr服务器进程)都有一个solr主目录(系统变量名为:solr.solr.home)。启动服务器实例时须为实例指定主目录(默认为:server/solr目录)。
2、solr主目录中存放该服务器实例托管的内核。
3、一个solr服务器实例中可托管多个内核。
Solr主目录介绍
Standalone Mode
每个主目录下都有一个solr服务器实例配置文件solr.xml。
主目录下存放托管的多个内核。内核下,包括conf,data目录,core.proerties文件。
core.proerties:内核属性文件,每个内核目录下都有这个属性文件。
data:索引存放目录
conf:内核配置文件目录
SolrCloud Mode
与Standalone 模式区别:
分布式集群模式下,solr.xml可放置在zk上。
内核的conf目录存在zk上,本地没有。
启动服务器实例命令
bin/solr start [options]
bin/solr start -help
bin/solr restart [options]
bin/solr restart -help
注意:重启要用和启动时一样的options
bin/solr start –s xxxdir –p port
查看本机上运行的solr服务实例的状态
bin/solr status
停止solr服务实例
bin/solr stop [options]
bin/solr stop -help
bin/solr stop –p port
bin/solr stop -all
core 内核管理
内核core:是在Solr服务器中的具体唯一命名的、可管理和可配置的索引。一台solr服务器可以托管一个或多个内核。区分不同模式的文档。
创建内核
bin/solr create [options]
bin/solr create –help
bin/solr create_core [options]
bin/solr create_core -help
-c 内核的名字(必需).
-d 内核配置目录。默认_default.
-p 创建命令要发送到的solr服务实例的端口。如未指定则获取本机运行的solr服务实例列表的第一个。
删除内核
bin/solr delete [options]
bin/solr delete -help
bin/solr delete –c corename –p port
分布式集群模式架构
分布式集群模式下:
索引分割成多个片存储到集群的不同节点上,每个分片有备份,存储在集群的不同节点上。
独立服务器上索引叫内核,SolrCloud中以 collection(集合)来称呼索引,内核存储的是集合分片(shard)的备份(replication)。
SolrCloud分布式集群架构
集合 c1:
红块:分片,黑块:备份
集合 c2:
黄块:分片,橙块:备份
分布式集群模式启动
zookeeper
独立的zookeeper,则需先启动zookeeper
内嵌的zookeeper,则先启动包含zookeeper的solrNode
solrNode
内嵌的zookeeper的第一个solrNode节点服务启动:
bin/solr start –c –p port –s solrhome
其他solr节点的启动:
bin/solr start –c –p port –s solrhome –z zkhost:port
启动的zookeeper实例的端口为 slor实例的端口+1000
分布式集群模式部署
1.创建两个solr主目录,如
D:estsolrCloudode1solr
D:estsolrCloudode2solr
node1/solr目录下需要zk的配置文件,到examplecloudode1solr 下拷贝 zoo.cfg和solr.xml。
2.启动第一个内嵌有zk的solrNode
bin/solr start –c –s F:/test/solrCloud/node1/solr
3.启动第二个solrNode
bin/solr start –c -p 7001 –s F:/test/solrCloud/node2/solr –z localhost:9983
http://localhost:8983/solr/
浏览器访问:http://localhost:8983/solr/
控制台面板有Cloud,Collections等选项。
创建集合 collection
集合---分片数2---备份因子2
一个集合,分成两个分片,每个分片有2个备份。
bin/solr create –c collection01 –d _default –shards 2 –replicationFactor 2 –p 8983
bin/solr create –c collection02 –d sample_techproducts_configs –shards 2 –replicationFactor 2 –p 8983
控制面板:Cloud的Graph:
右下角的Leader:Leader节点,Active:在线,Down:下线
删除集合
bin/solr delete –c collectonname –p port
从上图可以看出:
SolrCloud中以 collection(集合)来称呼索引,内核存储的是集合分片(shard)的备份(replication)
后续介绍Solr其他内容。