zookeeper+solr搭建集群服务

一。zookeeper(集群管理(主从管理,负载均衡,高可用的管理),配置文件的集中管理,)集群搭建

  1. 将zookeeper上传到服务器。
  2. 将zookeeper解压。
  3. 将zookeeper向/usr/local/solr-cloud目录下复制三份。
  4. 配置zookeeper。 
    4.1 在zookeeper01目录下创建data文件夹。 
    4.2 在data目录下创建一个myid的文件。 
    4.3 修改myid文件的内容为1(02对应2,03对应3)。 
    4.4 zookeeper02.03同样设置。 
    4.5 进入conf文件,把zoo_sample.cfg文件更名为zoo.cfg. 
    4.6 修改zoo.cfg.将datadir的属性指定为刚才创建的data文件夹。修改clientport指定的端口号为(01:2881;02:2882;03:2883)。添加如下内容:
server.1=192.168.1.111:2881:3881
server.2=192.168.1.111:2882:3882
server.3=192.168.1.111:2883:3883

5.启动zookeeper . 
进入zookeeper 的bin目录,使用zkserver.sh启动zookeeper服务。 
./zkserver.sh start —-启动服务 
./zkserver.sh stop —–停止服务 
./zkserver.sh status —查看服务状态

二。搭建solr服务集群

  1. 安装四个tomcat,修改其端口号不能冲突。8080-8083。
  2. 向tomcat下部署solr。将单据版的solr项目复制到tomcat下即可。
  3. 为每个solr实例创建对应的solrhome.
  4. 为每个solr实例关联对应的solehome.修改web.xml 实现
  5. 修改每个solrhome下的solr.xml文件。修改host,hostport属性为对于的tomcat的ip及端口号。

<solr>

  <solrcloud>
    <str name="host">${host:192.168.1.111}</str>
    <int name="hostPort">${jetty.port:8082}</int>
    <str name="hostContext">${hostContext:solr}</str>
    <int name="zkClientTimeout">${zkClientTimeout:30000}</int>
    <bool name="genericCoreNodeNames">${genericCoreNodeNames:true}</bool>
  </solrcloud>

  <shardHandlerFactory name="shardHandlerFactory"
    class="HttpShardHandlerFactory">
    <int name="socketTimeout">${socketTimeout:0}</int>
    <int name="connTimeout">${connTimeout:0}</int>
  </shardHandlerFactory>

</solr>
  • 录下的example/scripts/cloud-scripts/zkcli.sh命令上传配置文件。在zookeeper集群已经启动模式下。 
    把/usr/local/solrhome01/collection1/conf目录上传到zookeeper。 
    需要zookeeper集群已经启动。
./zkcli.sh -zkhost 192.168.1.111:2181,192.168.1.111:2182,192.168.1.111:2183 -cmd upconfig -confdir /usr/local/solrhome01/collection1/conf -confname myconf
  1. 使用zookeeper的zkcli.sh命令查看是否上传成功。
  2. 修改每个tomcat下的catalina.sh文件。告知solr实例zookeeper的位置。
JAVA_OPTS="-DzkHost=192.168.1.111:2181,192.168.1.111:2182,192.168.1.111:2183"
  •  

9.启动每个solr. 
这里写图片描述
10.集群分片 
将集群分为两片,每片两个副本。 
http://192.168.1.111:8080/solr/admin/collections?action=CREATE&name=collection2&numShards=2&replicationFactor=2 
这里写图片描述

11.删除不用collection1 
http://192.168.1.111:8080/solr/admin/collections?action=DELETE&name=collection1 
这里写图片描述
删除后的集群信息 
这里写图片描述
12.java中使用slorJ连接集群服务器。

public void testSolrCloud() throws Exception {
        //创建一个SolrServer对象
        CloudSolrServer solrServer = new CloudSolrServer("192.168.1.111:2181,192.168.1.111:2182,192.168.1.111:2183");
        //设置默认的collection
        solrServer.setDefaultCollection("collection2");
        //创建一个文档对象
        SolrInputDocument document = new SolrInputDocument();
        document.addField("id", "test01");
        document.addField("item_title", "title1");
        //添加文档
        solrServer.add(document);
        //提交
        solrServer.commit();

    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值