CentOS下用Tomcat+Zookeeper+Nginx+Solr完美搭建SolrCloud平台(三)

  四、安装Tomcat 7.0.42 并部署 Solr 4.5.1 和 项目包

  1、在solr1.jyga.com主机上解压缩 apache-tomcat-7.0.42.tar.gz 至 /media/solr/app/tomcat 。

  2、在 tomcat 目录下创建两个目录 webapps-jyga 和 webapps-solr ,分别存放项目包和solr.war包

[root@solr1 桌面]# mkdir /media/solr/app/tomcat/webapps-jyga
[root@solr1 桌面]# mkdir /media/solr/app/tomcat/webapps-solr
  3、将项目包复制到 webapps-jyga 目录下

[root@solr1 桌面]# cp jyga.war /media/solr/app/tomcat/webapps-jyga/jyga.war

   4、解压缩 solr-4.5.1.tgz 至 /media/solr/app/solr下 

  5、将 example\webapps 目录下的 solr.war 复制到 webapps-solr 目录下

[root@solr1 桌面]# cp /media/solr/app/solr/example/webapps/solr.war /media/solr/app/tomcat/webapps-solr/solr.war

  6、将 solr 中的 example/solr 目录复制到 /media/solr/data 下,做为 SolrCloud 的数据存储目录

[root@solr1 桌面]# cp -r /media/solr/app/solr/example/solr /media/solr/data/solr
  7、将 solr 中的 example/lib/ext 目录下的所有 jar 文件添加到 /media/solr/app/tomcat/webapps-solr/solr.war 包中的 WEB-INF/lib 目录中,使该目录下一共有45个jar文件。

  8、将 solr.war 包中的 WEB-INF/web.xml 文件解压缩出来,按下述内容修改相应的行,并将修改后的 web.xml 文件添加进solr.war 包覆盖原文件

<env-entry>
  <env-entry-name>solr/home</env-entry-name>
  <env-entry-value>/media/solr/data/solr</env-entry-value>
  <env-entry-type>java.lang.String</env-entry-type>
</env-entry

  9、修改 /media/solr/data/solr/solr.xml 文件中的 <solrcloud>节点

  <solrcloud>
    <str name="host">${host:}</str>
    <int name="hostPort">9998</int>
    <str name="hostContext">${hostContext:solr}</str>
    <int name="zkClientTimeout">${zkClientTimeout:15000}</int>
    <bool name="genericCoreNodeNames">${genericCoreNodeNames:true}</bool>
  </solrcloud>
  10、修改 tomcat 的配置文件以实现分别以 80 和 9998 端口运行项目包和solr包

[root@nginx 桌面]# vi /media/solr/app/tomcat/conf/server.xml

<?xml version='1.0' encoding='utf-8'?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <Listener className="org.apache.catalina.core.JasperListener" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />

  <GlobalNamingResources>
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>

  <Service name="SolrCloud">
    <Connector port="9998" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443"
               URIEncoding="UTF-8" />
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
    <Engine name="SolrCloud" defaultHost="localhost">
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>

      <Host name="localhost"  appBase="webapps-solr"
            unpackWARs="true" autoDeploy="true">

        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />

      </Host>
    </Engine>
  </Service>

  <Service name="JYGA">
    <Connector port="80" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443"
               URIEncoding="UTF-8" />
    <Connector port="8010" protocol="AJP/1.3" redirectPort="8443" />
    <Engine name="JYGA" defaultHost="localhost">
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>

      <Host name="localhost"  appBase="webapps-jyga"
            unpackWARs="true" autoDeploy="true">
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />

      </Host>
    </Engine>
  </Service>
</Server>

  11、修改 tomcat 的启动文件 catalina.sh

[root@solr1 桌面]# vi /media/solr/app/tomcat/bin/catalina.sh

#------------------------------------
CATALINA_HOME=/media/solr/app/tomcat
JAVA_HOME=/usr/java/jdk1.7.0_25

JAVA_OPTS="-verbose:gc -Xloggc:solr_gc.log -Dsolr.solr.home=/media/solr/data/solr -DzkHost=solr1.jyga.com:2181,solr2.jyga.com:2181,solr3.jyga.com:2181,solr4.jyga.com:2181,solr5.jyga.com:2181"

# OS specific support. $var _must_ be set to either true of false

  12、将 /media/solr/app/tomcat 和 /media/solr/data/solr 两个目录复制到其它4台主机中

[root@solr1 桌面]# scp -r /media/solr/app/tomcat root@solr2.jyga.com:/media/solr/app/tomcat
[root@solr1 桌面]# scp -r /media/solr/data/solr root@solr2.jyga.com:/media/solr/data/solr
[root@solr1 桌面]# scp -r /media/solr/app/tomcat root@solr3.jyga.com:/media/solr/app/tomcat
[root@solr1 桌面]# scp -r /media/solr/data/solr root@solr3.jyga.com:/media/solr/data/solr
[root@solr1 桌面]# scp -r /media/solr/app/tomcat root@solr4.jyga.com:/media/solr/app/tomcat
[root@solr1 桌面]# scp -r /media/solr/data/solr root@solr4.jyga.com:/media/solr/data/solr
[root@solr1 桌面]# scp -r /media/solr/app/tomcat root@solr5.jyga.com:/media/solr/app/tomcat
[root@solr1 桌面]# scp -r /media/solr/data/solr root@solr5.jyga.com:/media/solr/data/solr
  12、启动5台主机中的 tomcat
[root@solr1 桌面]# /media/solr/app/tomcat/bin/catalina.sh start
[root@solr1 桌面]# ssh root@solr2.jyga.com
[root@solr2 ~]# /media/solr/app/tomcat/bin/catalina.sh start
[root@solr2 ~]# ssh root@solr3.jyga.com
[root@solr3 ~]# /media/solr/app/tomcat/bin/catalina.sh start
[root@solr3 ~]# ssh root@solr4.jyga.com
[root@solr4 ~]# /media/solr/app/tomcat/bin/catalina.sh start
[root@solr4 ~]# ssh root@solr5.jyga.com
[root@solr5 ~]# /media/solr/app/tomcat/bin/catalina.sh start

  13、如果在实际环境中防火墙必须为打开状态的话,需要将 Tomcat 运行涉及的端口加入防火墙设置。修改 /etc/sysconfig/iptables 文件,在COMMIT前面加入以下几行

-A RH-Firewall-1-INPUT -p tcp -m tcp --dport 80 -j ACCEPT
-A RH-Firewall-1-INPUT -p tcp -m tcp --dport 9998 -j ACCEPT

  14、通过浏览器查看 SolrCloud 的运行情况,输入网址 http://solr1.jyga.com:9998/solr (这儿查看的是solr1主机的,要看其它主机的可以修改网址)


  此时看到的 Cloud 中右边是空白,是因此我们还没有创建相应的 Collection。要正确创建 Collection ,还需要上传正确的配置文件,本文以Solr包中的例子 collection1 为模板。

  15、上传 collection1/conf 目录下的配置文件,并起名为 defaultConf

[root@solr1 ~]$ java -classpath .:/media/solr/app/tomcat/webapp-solr/solr/lib/* org.apache.solr.cloud.ZkCLI -cmd upconfig -zkhost solr1.jyga.com:2181,solr2.jyga.com:2181,solr3.jyga.com:2181,solr4.jyga.com:2181,solr5.jyga.com:2181 -confdir /media/solr/data/solr/collection1/conf -confname defaultConf
  16、将配置文件 defaultConf 关联到 solr 数据目录下的 collection1 节点,使 collection1 节点变成虚拟节点并隐藏起来。

[root@solr1 ~]$ java -classpath .:/media/solr/app/tomcat/webapp-solr/solr/lib/* org.apache.solr.cloud.ZkCLI -cmd linkconfig -collection collection1 -confname defaultConf -zkhost solr1.jyga.com:2181,solr2.jyga.com:2181,solr3.jyga.com:2181,solr4.jyga.com:2181,solr5.jyga.com:2181 
  17、根据上传的配置文件 defaultCon 创建一个节点
[root@solr1 ~]$ curl 'http://solr1.jyga.com:9998/solr/admin/collections?action=CREATE&name=TestCollection&numShards=2@replicationFactor=2&collection.configName=defaultConf'
  这里的action=CREATE是指操作指令为创建,name=TestCollection是指创建的节点的名称为TestCollecion,numShards=2是指有两个Shard,replicationFactor=2是指每个Shard有两个副本(数据冗余),collection.configName=defaultConf是指该节点根据配置文件defaultConf创建。注意 numShards * replicationFactor 的值必须小于SolrCloud的主机数,这里我有一个有5台,可以实现 2 * 1、2 * 2、3 * 1 共三种模式(numShards的值最小为2)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

飞天神笔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值