zookeeper1 : 192.168.1.103
zookeeper2 : 192.168.1.104
zookeeper3 : 192.168.1.105
solr1 : 192.168.1.106
solr2 : 192.168.1.107
solr3 : 192.168.1.108

JDK安装目录:/data/jdk
Solr安装目录:/data/SolrCloud/Solr/solr
Solr配置文件目录:/data/SolrCloud/Solr/solr-config
Solr数据文件目录:/data/SolrCloud/solr-cores
Tomcat安装目录:/data/tomcat
除了安装JDK的目录不需要创建,其它目录都需要进行创建

6台集群全部安装 基础环境配置 tomcat jdk,
1. tomcat放置目录为 /data/tomcat
2. jdk 放置目录为 /data/jdk

solr集群安装:
192.168.1.106 solr1服务器上操作

解压 solr-6.2.0.tgz ,并把solr.war解压到/data/SolrCloud/Solr/solr 目录下。
tar -zxvf solr-6.2.0.tgz
mv /data/solr-6.2.0/server/solr-webapp/webapp /data/SolrCloud/Solr/solr

将 solr-6.2.0/server/lib/ext/ 目录下的jar包拷贝到 /data/SolrCloud/Solr/solr/WEB-INF/lib/ 目录下。
cp /data/solr-6.2.0/server/lib/ext/*.jar /data/SolrCloud/Solr/solr/WEB-INF/lib/

将 solr-6.2.0/server/solr/configsets/basic_configs/conf/ 目录下的文件拷贝到 /data/SolrCloud/Solr/solr-config/
cp /data/solr-6.2.0/server/solr/configsets/basic_configs/conf/* /data/SolrCloud/Solr/solr-config/

将 solr-6.2.0/example/files/conf/ 目录下的文件夹拷贝到 /data/SolrCloud/Solr/solr-config/
cp /data/solr-6.2.0/example/files/conf/lang /data/SolrCloud/Solr/solr-config/

将 /data/SolrCloud/Solr/solr 目录拷贝到 /data/SolrCloud/Tomcat/apache-tomcat-7.0.62/webapps/ 目录下。
cp /data/SolrCloud/Solr/solr /data/tomcat/webapps/

将 solr-6.2.0/server/solr/ 目录下的solr.xml文件拷贝到 /data/SolrCloud/solr-cores 目录下,这是solr的核心配置文件。
cp /data/solr-6.2.0/server/solr/solr.xml /data/SolrCloud/solr-cores

修改 /data/SolrCloud/solr-cores 目录下的solr.xml,修改hostPort和Tomcat端口一致:

<solr>

<solrcloud>

<str name="host">${host:}</str>
<int name="hostPort">8080</int>
<str name="hostContext">${hostContext:solr}</str>

<bool name="genericCoreNodeNames">${genericCoreNodeNames:true}</bool>

<int name="zkClientTimeout">${zkClientTimeout:30000}</int>
<int name="distribUpdateSoTimeout">${distribUpdateSoTimeout:600000}</int>
<int name="distribUpdateConnTimeout">${distribUpdateConnTimeout:60000}</int>
<str name="zkCredentialsProvider">${zkCredentialsProvider:org.apache.solr.common.cloud.DefaultZkCredentialsProvider}</str>
<str name="zkACLProvider">${zkACLProvider:org.apache.solr.common.cloud.DefaultZkACLProvider}</str>

在 /data/tomcat/conf/ 目录下创建Catalina/localhost目录。
mkdir -p /data/tomcat/conf/Catalina/localhost

在 /data/tomcat/conf/Catalina/localhost/ 目录下创建solr.xml,此为Solr/home的配置文件。

<?xml version="1.0" encoding="UTF-8"?>
<Context docBase="/data/tomcat/webapps/solr" debug="0" crossContext="true">
<Environment name="solr/home" type="java.lang.String" value="/data/SolrCloud/solr-cores/" override="true"/>
</Context>
~
~

修改 /data/tomcat/bin/catalina.sh 加入以下内容:
JAVA_OPTS='-DzkHost=zookeeper1:2181,zookeeper2:2181,zookeeper3:2181'

将以上配置同步到其它服务器
scp -r /data/{SolrCloud,tomcat} 192.168.1.107:/data/
scp -r /data/{SolrCloud,tomcat} 192.168.1.108:/data/

上传配置到Zookeeper:
SolrCloud是通过Zookeeper集群来保证配置文件的变更及时同步到各个节点上,所以,需要将配置文件上传到Zookeeper集群。
solr配置文件目录:/data/SolrCloud/Solr/solr-config/

执行以下操作:
java -classpath .:/data/tomcat/webapps/solr/WEB-INF/lib/* org.apache.solr.cloud.ZkCLI -cmd upconfig -zkhost zookeeper1:2181,zookeeper2:2181,zookeeper3:2181 -confdir /data/SolrCloud/Solr/solr-config/ -confname solrconfig

在192.168.1.103 zookeeper1上执行
校验Zookeeper配置文件
cd /data/Zookeeper/bin/
./zkCli.sh -server zookeeper1:2181

[root@zookeeper1 bin]# ./zkCli.sh -server zookeeper1:2181

[zk: zookeeper1:2181(CONNECTED) 2] ls /
[configs, zookeeper]
[zk: zookeeper1:2181(CONNECTED) 3] ls /configs
[solrconfig]
[zk: zookeeper1:2181(CONNECTED) 4] ls /configs/solrconfig
[currency.xml, managed-schema, protwords.txt, solrconfig.xml, synonyms.txt, elevate.xml, stopwords.txt, params.json, lang]

启动Tomcat,先启动solr1 192.168.1.106机器上的tomcat:
/data/tomcat/bin/startup.sh

启动solr2 192.168.1.107和192.168.1.108机器上的Tomcat。

访问http://solr1:8080/solr/index.html

创建Collection及初始化Shard
curl 'http://solr1:8080/solr/admin/collections?action=CREATE&name=collection_&numShards=3&replicationFactor=1'

查看 /data/SolrCloud/solr-cores/ 目录:
[root@solr1 solr-cores]# ls /data/SolrCloud/solr-cores/
collection__shard1_replica1 solr.xml

Solr6.2.0 + zookeeper 集群配置的更多相关文章

  1. zookeeper集群配置与启动——实战

    1,准备: A:三台linxu服务器: 10.112.29.177 10.112.29.172 10.112.29.174 命令 hostname 得到每台机器的 hostname vm-10-112 ...

  2. kafka集群与zookeeper集群 配置过程

    Kafka的集群配置一般有三种方法,即 (1)Single node – single broker集群: (2)Single node – multiple broker集群:    (3)Mult ...

  3. Redis 3.0 Cluster集群配置

    Redis 3.0 Cluster集群配置 安装环境依赖 安装gcc:yum install gcc 安装zlib:yum install zib 安装ruby:yum install ruby 安装 ...

  4. Redis-5.0.5集群配置

    版本:redis-5.0.5 参考:http://redis.io/topics/cluster-tutorial. 集群部署交互式命令行工具:https://github.com/eyjian/re ...

  5. java:zookeeper集群配置,dubbo

    1.zookeeper集群配置: 2.dubbo:(配置见视频)

  6. zookeeper 集群配置采坑 Connection refused WARN [QuorumPeer[myid=1]/0:0:0:0:0:0:0:0:2181:QuorumCnxManager@584] - Cannot open channel to 3 at election address slave2/192.168.127.133:3888

    坑一: Cannot open channel to at election address slave1/ java.net.ConnectException: Connection refused ...

  7. solrCloud+tomcat+zookeeper集群配置

    solrcolud安装solrCloud+tomcat+zookeeper部署  转载请出自出处:http://eksliang.iteye.com/blog/2107002 http://eksli ...

  8. zookeeper集群配置与启动

    摘要:Zookeeper是一个很好的集群管理工具,被大量用于分布式计算.如Hadoop以及Storm系统中.这里简单记录下Zookeeper集群环境的搭建过程.本文以Ubuntu 12.04 LTS作 ...

  9. zookeeper集群配置

    zookeeper集群网上demo一大堆,补充一下一些不明白的地方 1 复制2份zookeeper,savle作为备份节点 2.配置zoo.cfg # The number of millisecon ...

随机推荐

  1. 如何在 ejs 模板中使用 helper function 外部函数进行特殊处理?

    一般我们想要在 ejs 模板中使用外部函数用于特殊的处理,比如:<%= ellipsis(title, 30) %> 通常的做法是: 使用 app.locals 来定义: app.loca ...

  2. CORS(跨域资源共享)简介

    前言:像CORS对于现代前端这么重要的技术在国内基本上居然很少有人使用和提及,在百度或者Google上搜索CORS,搜到的中文文章基本都是另外一种卫星定位技术CORS的介绍,让我等前端同学情何以堪(对 ...

  3. hdu 2099 整除的尾数

    Problem Description 一个整数,只知道前几位,不知道末二位,被另一个整数除尽了,那么该数的末二位该是什么呢?   Input 输入数据有若干组,每组数据包含二个整数a,b(0< ...

  4. 关于netstat

    netstat 命令是 linux 下一个非常有用的命令,顾名思义,其作用是查询当前的网络状态. 以最常用的查询 TCP 连接状态为例 netstat -an|awk '/tcp/ {print $6 ...

  5. APP测试流程

    1 APP测试基本流程 1.1流程图 1.2测试周期 测试周期可按项目的开发周期来确定测试时间,一般测试时间为两三周(即15个工作日),根据项目情况以及版本质量可适当缩短或延长测试时间.正式测试前先向 ...

  6. css3立体旋转动画

    demo地址 效果图 在别人网站上看到一个立体旋转的例子,然后突然想到自己前几天学习的css3旋转,就试着做了一个例子,看起来有一些粗糙. html结构很简单: <div> <ul ...

  7. Facebook通过oAuth验证获取json数据

    首先下载facebook相关的动态库,下载文件:facebook.dll 获取授权token方法: private string SetToken(string gettoken)//此处是你的短to ...

  8. 从show slave status 中判断mysql同步状态

    slave status 中检查同步状态: 1.sql线程和io线程显示yes Slave_IO_Running: Yes Slave_SQL_Running: Yes 2. Master_Log_F ...

  9. ubuntu 安装 GCC

    网上查了好多方式,试了一下,最简单可行的是: sudo apt-get install  build-essential 等待执行完,输入 gcc -v 输出: Using built-in spec ...

  10. jQuery获取cookie

    之前一直以为获取cookie的方法封装在了jQuery包中...没想到还得单独下jquery.cookie.js插件,不太好找,备份一份: /*! * jQuery Cookie Plugin v1. ...