6.2 tomcat安装
第一步:将apache-tomcat-XXX.tar.gz解压
tar -zxvf apache-tomcat-XXX.tar.gz
第二步:把解压后的tomcat复制到/usr/local/solrcloud/目录下复制四份。
/usr/local/solrcloud/tomcat1
/usr/local/solrcloud/tomcat2
/usr/local/solrcloud/tomcat3
/usr/local/solrcloud/tomcat4
第三步:修改tomcat的server.xml
vim tomcat2/conf/server.xml,把其中的端口后都加一。保证两个tomcat可以正常运行不发生端口冲突。
6.3 solr单机部署
略
## 6.4 集群部署 ##
6.4.1 启动zookeeper
solrCloud部署依赖zookeeper,需要先启动每一台zookeeper服务器。
6.4.2 zookeeper管理配置文件
由于zookeeper统一管理solr的配置文件(主要是schema.xml、solrconfig.xml), solrCloud各各节点使用zookeeper管理的配置文件
将上边部署的solr单机的conf拷贝到/home/solr下。
执行下边的命令将/home/solr/conf下的配置文件上传到zookeeper
在solr-4.10.3/example目录下先执行:
java -jar start.jar
在solr-4.10.3/example/scripts/cloud-scripts/目录下:
./zkcli.sh -zkhost 10.40.155.196:2181,10.40.155.196:2182,10.40.155.196:2183 -cmd upconfig -confdir /usr/local/solr/solrhome/collection1/conf -confname myconf
登陆zookeeper服务器查询配置文件:
cd /usr/local/zookeeper/bin/
./zkCli.sh
6.5 修改SolrCloud监控端口
为每一个solr创建solrhome
修改每个solrhome的solr.xml文件。将host改成虚拟机ip地址,port改成对应的tomcat的端口号。
6.6 每一台solr和zookeeper关联
修改每一台solr的tomcat 的 bin目录下catalina.sh文件中加入DzkHost指定zookeeper服务器地址:
JAVA_OPTS="-DzkHost=10.40.155.196:2181,10.40.155.196:2182,10.40.155.196:2183"
(可以使用vim的查找功能查找到JAVA_OPTS的定义的位置,然后添加)
6.7 启动所有的solr服务
启动每一台solr的tomcat服务。
6.8 访问solrcloud
访问任意一台solr,左侧菜单出现Cloud:
6.9 SolrCloud集群配置
上图中的collection1集群只有一片,可以通过下边的方法配置新的集群。
如果集群中有四个solr节点创建新集群collection2,将集群分为两片,每片两个副本。
http://10.40.155.196:8081/solr/admin/collections?action=CREATE&name=collection2&numShards=2&replicationFactor=2
删除集群命令;
http://10.40.155.196:8081/solr/admin/collections?action=DELETE&name=collection1
执行后原来的collection1删除
6.10 启动solrCloud注意
启动solrCloud需要先启动solrCloud依赖的所有zookeeper服务器,再启动每台solr服务器。
public class SolrCloudTest {
// zookeeper地址
private static String zkHostString = "10.40.155.196:2181,10.40.155.196:2182,10.40.155.196:2183";
// collection默认名称,比如我的solr服务器上的collection是collection2_shard1_replica1,就是去掉“_shard1_replica1”的名称
private static String defaultCollection = "collection1";
// cloudSolrServer实际
private CloudSolrServer cloudSolrServer;
// 测试方法之前构造 CloudSolrServer
@Before
public void init() {
cloudSolrServer = new CloudSolrServer(zkHostString);
cloudSolrServer.setDefaultCollection(defaultCollection);
cloudSolrServer.connect();
}
// 向solrCloud上创建索引
@Test
public void testCreateIndexToSolrCloud() throws SolrServerException,
IOException {
SolrInputDocument document = new SolrInputDocument();
document.addField("id", "100001");
document.addField("title", "李四");
cloudSolrServer.add(document);
cloudSolrServer.commit();
}
// 搜索索引
@Test
public void testSearchIndexFromSolrCloud() throws Exception {
SolrQuery query = new SolrQuery();
query.setQuery("*:*");
try {
QueryResponse response = cloudSolrServer.query(query);
SolrDocumentList docs = response.getResults();
System.out.println("文档个数:" + docs.getNumFound());
System.out.println("查询时间:" + response.getQTime());
for (SolrDocument doc : docs) {
ArrayList title = (ArrayList) doc.getFieldValue("title");
String id = (String) doc.getFieldValue("id");
System.out.println("id: " + id);
System.out.println("title: " + title);
System.out.println();
}
} catch (SolrServerException e) {
e.printStackTrace();
} catch (Exception e) {
System.out.println("Unknowned Exception!!!!");
e.printStackTrace();
}
}
// 删除索引
@Test
public void testDeleteIndexFromSolrCloud() throws SolrServerException, IOException {
// 根据id删除
UpdateResponse response = cloudSolrServer.deleteById("zhangsan");
// 根据多个id删除
// cloudSolrServer.deleteById(ids);
// 自动查询条件删除
// cloudSolrServer.deleteByQuery("product_keywords:教程");
// 提交
cloudSolrServer.commit();
}
}
## 8. 项目与solrcloud整合 ## ## 8.1 确定sql语句 ##
SELECT
a.id,
a.title,
a.sell_point,
a.price,
a.image,
b.`name` category_name,
c.item_desc
FROM
tb_item a
LEFT JOIN tb_item_cat b ON a.cid = b.id
LEFT JOIN tb_item_desc c ON a.id = c.item_id
## 8.2 新建pojo类 ##
private Long id;
private String title;
private String sell_point;
private Long price;
private String image;
private String category_name;
查询所有商品信息
<bean id="httpSolrServer" class="org.apache.solr.client.solrj.impl.HttpSolrServer">
<constructor-arg index="0" value="http://10.40.155.196:9080/solr/collection1"/>
bean>
<bean id="cloudSolrServer" class="org.apache.solr.client.solrj.impl.CloudSolrServer">
<constructor-arg name="zkHost" value="10.40.155.196:2181,10.40.155.196:2182,10.40.155.196:2183">constructor-arg>
<property name="defaultCollection" value="collection2">property>
bean>
public void importAllItems() throws SolrServerException, IOException {
//查询商品列表
List itemList = itemMapper.getSearchItemList();
//遍历商品列表
for (TbSearchItemCustom searchItem : itemList) {
//创建文档对象
SolrInputDocument document = new SolrInputDocument();
//向文档对象中添加域:对应schema.xml配置文件中的域名
document.addField("id", searchItem.getId());
document.addField("item_title", searchItem.getTitle());
document.addField("item_sell_point", searchItem.getSellPoint());
document.addField("item_price", searchItem.getPrice());
document.addField("item_image", searchItem.getImage());
document.addField("item_category_name", searchItem.getCatName());
//把文档对象写入索引库
solrServer.add(document);
}
//提交
solrServer.commit();
}
## 8.5 编写Controller ##
写一个按钮
<div style="padding:5px;" >
<a id="import" class="easyui-linkbutton" onclick="importItems()">一键导入商品数据到索引库a>
<span id="msg">span>
div>
function importItems() {
(‘#import’).linkbutton(‘disable’);(‘#msg’).html(‘导入中,请稍后…’);
.post(“search/item/import”,null,function(data){
if(data.success){.messager.alert(‘提示’, data.message);
} else {
.messager.alert(‘提示’,’导入索引库失败!’);
}(‘#msg’).html(”);
});
}
这里写代码片
编写service
功能:接收查询条件。查询条件及分页条件(page、rows),创建一个SolrQuery对象。指定查询条件、分页条件、默认搜索域、高亮显示。调用dao层执行查询。得到查询结果计算总页数。返回TbSearchItemResult对象。
K收查询参数:查询条件、page、rows
调用Service执行查询返回一个查询结果对象。
把查询结果包装到MessageResult中返回,结果是json格式的数据。
Page为空:默认为1
Rows 为空:默认为60
@RequestMapping("/")
public String searchItemList(String keyword,
@RequestParam(defaultValue="1") Integer page, Model model) throws Exception {
if(keyword != null){
keyword = new String(keyword.getBytes("iso-8859-1"), "utf-8");
//查询商品列表
}
//返回逻辑视图
return "search";
}