共计 7037 个字符,预计需要花费 18 分钟才能阅读完成。
CentOS7 下 ZooKeeper 集群安装部署
安装 JDK
yum install -y java-1.8.0-openjdk
安装 ZooKeeper
下载
wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.10/zookeeper-3.4.10.tar.gz
tar -zxvf zookeeper-3.4.10.tar.gz
官方地址:http://www.apache.org/dyn/closer.cgi/zookeeper/
配置 zoo.cfg
cp conf/zoo_sample.cfg conf/zoo.cfg
vi conf/zoo.cfg
修改(本)
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/data/solr/zookeeper
# the port at which the clients will connect
clientPort=2181
server.211=dt211.corp:2888:3888
server.212=0.0.0.0:2888:3888
server.214=dt214.corp:2888:3888
创建数据目录和 myid
mkdir /data/solr/zookeeper
vi /data/solr/zookeeper/myid
myid 文件中只有一个数字,与 server id 对应
212
防火墙配置
firewall-cmd --permanent --add-port=2181/tcp
firewall-cmd --permanent --add-port=2888/tcp
firewall-cmd --permanent --add-port=3888/tcp
firewall-cmd --reload
同步到其它机器
————————————– 分割线 ————————————–
CentOS7 NFS 共享设置
安装 nfs 工具
yum install -y nfs-utils
配置共享目录
创建共享目录
mkdir /home/share
目录授权
chmod 766 /home/share
编辑 exports
vi /etc/exports
添加内容
/home/share 192.168.1.0/24(rw,sync)
先启动 rpcbind
systemctl start rpcbind
在启动 nfs
systemctl start nfs
查看本机共享目录
exportfs
防火墙设置
firewall-cmd --permanent --add-service=nfs
firewall-cmd --reload
挂载共享目录
安装 nfs,同上
创建挂载目录
mkdir /mnt/share
添加挂载
mount 192.168.1.212:/home/share /mnt/share
异常处理
1.mount.nfs: requested NFS version or transport protocol is not supported
启动顺序不对,先启动 rpcbind,在启动 nfs
2.mount.nfs: access denied by server while mounting
————————————– 分割线 ————————————–
修改 zoo.cfg,本机 IP 地址:0.0.0.0
启动集群
启动
bin/zkServer.sh start
查看状态
bin/zkServer.sh status
停止
bin/zkServer.sh stop
异常处理
1.java.net.ConnectException: 拒绝连接 (Connection refused)
本机 IP 要改成 0.0.0.0,无法识别别名,127.0.0.1 也只能有一台
CentOS7 下 Solr6.6 集群安装部署
Solr
添加 zk 地址
vi bin/solr.in.sh
# Set the ZooKeeper connection string if using an external ZooKeeper ensemble
# e.g. host1:2181,host2:2181/chroot
# Leave empty if not using SolrCloud
ZK_HOST="hbase201:2181,hbase202:2181,hbase203:2181/solr"
# Set the ZooKeeper client timeout (for SolrCloud mode)
ZK_CLIENT_TIMEOUT="15000"
上传配置文件
./zkcli.sh -zkhost hbase201,hbase202,hbase203:2181/solr -cmd upconfig -confdir /usr/solr/solr-6.6.0/server/solr/configsets/data_driven_schema_configs/conf -confname solr
同步到其它服务器
scp -r /usr/solr hbase201:/usr/
scp -r /usr/solr hbase202:/usr/
分别启动 solr 服务
bin/solr start -force
集群操作
查看状态
http://hbase203:8983/solr/#/~cloud
创建集群
http://hbase203:8983/solr/admin/collections?action=CREATE&name=test&numShards=3&replicationFactor=3&maxShardsPerNode=3&collection.configName=solr
删除集群
http://hbase203:8983/solr/admin/collections?action=DELETE&name=test
重新加载
http://hbase203:8983/solr/admin/collections?action=RELOAD&name=test
更新配置文件,添加 DIH
修改 solrconfig.xml
vi solrconfig.xml
<lib dir="${solr.install.dir:../../../..}/dist/" regex="solr-dataimporthandler-.*\.jar" />
<requestHandler name="/dataimport" class="solr.DataImportHandler">
<lst name="defaults">
<str name="config">data-config.xml</str>
</lst>
</requestHandler>
创建 data-config.xml
vi data-config.xml
<dataConfig>
<dataSource type="JdbcDataSource"
driver="com.mysql.jdbc.Driver"
convertType="true"
url="jdbc:mysql://127.0.0.1:3306/db_name"
user="sa"
password="123456"/>
<document>
<entity name="query_news" query="SELECT id, title, content, tags FROM news" >
</entity>
</document>
</dataConfig>
创建 schema.xml
vi schema.xml
<schema name="query_news">
<uniqueKey>id</uniqueKey>
<field name="id" type="int" indexed="true" stored="true" required="true" multiValued="false" />
<field name="title" type="string" indexed="true" stored="true" required="true" multiValued="false" />
<field name="content" type="string" indexed="true" stored="true" required="false" multiValued="false" />
<field name="tags" type="string" indexed="true" stored="false" required="false" multiValued="false" />
<field name="_version_" type="long" indexed="true" stored="true"/>
<field name="info_text" type="text_general" indexed="true" stored="false" multiValued="true" />
<copyField source="title" dest="info_text" />
<copyField source="content" dest="info_text" />
<copyField source="tags" dest="info_text" />
<fieldType name="string" class="solr.StrField" sortMissingLast="true" />
<fieldType name="int" class="solr.TrieIntField" precisionStep="0" positionIncrementGap="0"/>
<fieldType name="text_general" class="solr.TextField" positionIncrementGap="100">
<analyzer type="index">
<tokenizer class="solr.StandardTokenizerFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
<analyzer type="query">
<tokenizer class="solr.StandardTokenizerFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
</fieldType>
</schema>
上传配置文件
./zkcli.sh -zkhost hbase201,hbase202,hbase203:2181/solr -cmd putfile /configs/solr/solrconfig.xml /usr/solr/solr-6.6.0/server/solr/configsets/data_driven_schema_configs/conf/solrconfig.xml
./zkcli.sh -zkhost hbase201,hbase202,hbase203:2181/solr -cmd putfile /configs/solr/data-config.xml /usr/solr/solr-6.6.0/server/solr/configsets/data_driven_schema_configs/conf/data-config.xml
./zkcli.sh -zkhost hbase201,hbase202,hbase203:2181/solr -cmd putfile /configs/solr/schema.xml /usr/solr/solr-6.6.0/server/solr/configsets/data_driven_schema_configs/conf/schema.xml
更新配置文件
http://hbase201:8983/solr/admin/collections?action=RELOAD&name=test
备份和恢复
备份
http://hbase201:8983/solr/test/replication?command=backup&location=/home/test_bak
恢复
- 停止 Solr 服务
- Copy 备份文件到 CoreIndex 目录
- 启动 Solr 服务
Index 存储为 HDFS
修改 solrconfig.xml
vi solrconfig.xml
<directoryFactory name="DirectoryFactory" class="solr.HdfsDirectoryFactory">
<str name="solr.hdfs.home">hdfs://hbase201:9000/solr</str>
<bool name="solr.hdfs.blockcache.enabled">true</bool>
<int name="solr.hdfs.blockcache.slab.count">1</int>
<bool name="solr.hdfs.blockcache.direct.memory.allocation">true</bool>
<int name="solr.hdfs.blockcache.blocksperbank">16384</int>
<bool name="solr.hdfs.blockcache.read.enabled">true</bool>
<bool name="solr.hdfs.nrtcachingdirectory.enable">true</bool>
<int name="solr.hdfs.nrtcachingdirectory.maxmergesizemb">16</int>
<int name="solr.hdfs.nrtcachingdirectory.maxcachedmb">192</int>
</directoryFactory>
<lockType>${solr.lock.type:hdfs}</lockType>
上传配置文件到 zookeeper
./zkcli.sh -zkhost hbase201,hbase202,hbase203:2181/solr -cmd putfile /configs/solr/data-config.xml /usr/solr/solr-6.6.0/server/solr/configsets/data_driven_schema_configs/conf/data-config.xml
更新 Hadoop 处理 jar 包(solr 自带版本不一致)
rm -f server/solr-webapp/webapp/WEB-INF/lib/hadoop-*
rm -f server/solr-webapp/webapp/WEB-INF/lib/protobuf-java-*
cd /usr/hadoop/hadoop-2.7.4/share
cp hadoop/common/hadoop-common-2.7.4.jar /usr/solr/solr-6.6.0/server/solr-webapp/webapp/WEB-INF/lib/
cp hadoop/common/lib/hadoop-* /usr/solr/solr-6.6.0/server/solr-webapp/webapp/WEB-INF/lib/
cp hadoop/common/lib/protobuf-java-2.5.0.jar /usr/solr/solr-6.6.0/server/solr-webapp/webapp/WEB-INF/lib/
cp hadoop/hdfs/hadoop-hdfs-2.7.4.jar /usr/solr/solr-6.6.0/server/solr-webapp/webapp/WEB-INF/lib/
更多 Solr 相关教程见以下内容:
CentOS7 下搭建 Solr 6.6 全文检索服务器及 IK 分词器配置 http://www.linuxidc.com/Linux/2017-12/149897.htm
Apache Solr: 安装和运行 http://www.linuxidc.com/Linux/2016-12/138527.htm
Solr 实现 Low Level 查询解析(QParser)http://www.linuxidc.com/Linux/2012-05/59755.htm
Solr6.0.0 + Tomcat8 配置问题 http://www.linuxidc.com/Linux/2016-05/131845.htm
CentOS 6.7 下单机部署 Solr 7.1.0 http://www.linuxidc.com/Linux/2017-12/149889.htm
Solr 的详细介绍:请点这里
Solr 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-12/149902.htm