商品审核-导入 Solr 索引库
4.1 需求分析
运用消息中间件 activeMQ 实现运营商后台与搜索服务的零耦合。运营商执行商品审核后,向 activeMQ 发送消息(SKU 列表),搜索服务从 activeMQ 接收到消息并导入到 solr 索引库。
4.1 消息生产者(运营商后台)
4.1.1 解除耦合
修改 pinyougou-manager-web,移除搜索服务接口依赖:



com.pinyougou

pinyougou-search-interface

0.0.3-SNAPSHOT


GoodsController.java 中删除调用搜索服务接口的相关代码

//itemSearchService.deleteByGoodsIds(Arrays.asList(ids));

//@Reference

//private  ItemSearchService  itemSearchService;

//itemSearchService.importList(itemList);
4.1.1 准备工作
(1)修改 pinyougou-manager-web 的 pom.xml,引入依赖



org.apache.activemq

activemq-client

5.13.4


(2)pinyougou-sellergoods-service 工程添加 applicationContext-jms-producer.xml

改名为 spring-activemq.xml        内容如下:


































(3)修改 web.xml



contextConfigLocation

classpath:spring/spring-*.xml


4.1.1 代码实现
修改 pinyougou-manager-web 工程的 GoodsController.java

@Autowired

private  Destination  queueSolrDestination;//用于发送 solr 导入的消息

@Autowired

private  JmsTemplate  jmsTemplate;

@RequestMapping("/updateStatus")

public  Result  updateStatus(Long[]  ids,String  status){

try {

goodsService.updateStatus(ids,  status);

//按照 SPU ID 查询 SKU 列表(状态为 1)
if(status.equals("1")){//审核通过

List  itemList  = goodsService.findItemListByGoodsIdandStatus(ids,  status);

//调用搜索接口实现数据批量导入

if(itemList.size()>0){

final  String  jsonString  =  JSON.toJSONString(itemList);

jmsTemplate.send(queueSolrDestination,  new  MessageCreator()  { @Override
public Message createMessage(Session session) throws JMSException
{

return  session.createTextMessage(jsonString);

}

});

}else{

System.out.println("没有明细数据");

}

}

return  new  Result(true,  "修改状态成功");

}  catch  (Exception  e)  { e.printStackTrace();
return  new  Result(false,  "修改状态失败");

}

}
4.3 消息消费者(搜索服务)4.3.1 准备工作
(1)修改 pinyougou-search-service ,在 pom.xml 中添加 activemq 依赖



org.apache.activemq

activemq-client

5.13.4


(2)添加 spring 配置文件 applicationContext-jms-consumer.xml



































4.3.1 代码实现
在 pinyougou-search-service 的 com.pinyougou.search.service.impl 新增监听类

@Component

public  class  ItemSearchListener  implements  MessageListener{ @Autowired
private  ItemSearchService  itemSearchService;

@Override

public  void  onMessage(Message  message)  {

System.out.println("监听接收到消息...");

try {

TextMessage  textMessage=(TextMessage)message; String  text  =  textMessage.getText();
List  list  =  JSON.parseArray(text,TbItem.class);

for(TbItem  item:list){

System.out.println(item.getId()+"  "+item.getTitle());

Map  specMap=  JSON.parseObject(item.getSpec());//将 spec 字段中的 json
字符串转换为 map

item.setSpecMap(specMap);//给带注解的字段赋值

}

itemSearchService.importList(list);//导入

System.out.println("成功导入到索引库");

}  catch  (Exception  e)  { e.printStackTrace();
}

}

}