Caused by: java.net.SocketTimeoutException: 30,000 milliseconds timeout on elasticsearch 超时问题

该博客主要介绍了如何查询所有酒店信息并将其存储到Elasticsearch中。首先通过调用`tabHotelMapper.getHotelList()`获取酒店数据,然后使用`BulkRequest`批量创建索引请求,指定索引为`travel_hotel`,将数据源设置为酒店信息的JSON字符串。最后,通过`restHighLevelClient`执行批量操作。在遇到批量错误时,记录失败的ID并提供相应的日志信息。解决了一个因`cluster.initial_master_nodes`配置问题导致的启动故障。
   /**
    * 查询所有酒店信息
    */
   List<TabHotel> records= tabHotelMapper.getHotelList();
   System.out.println("酒店数据"+records);
   //将数据保存带es中
   //1 给es中建立索引 product 建立好映射关系
   //2 保存数据到es中
   BulkRequest bulkRequest = new BulkRequest();
   for (TabHotel skuEsModel : records) {
       //放到哪个索引?
       IndexRequest indexRequest = new IndexRequest("travel_hotel");
       indexRequest.id(skuEsModel.getId());
       String jsonString = JSON.toJSONString(skuEsModel);
       indexRequest.source(jsonString, XContentType.JSON);
       bulkRequest.add(indexRequest);
   }
   System.out.println("酒店数据ser"+bulkRequest);
   //执行
   BulkResponse bulk = restHighLevelClient.bulk(bulkRequest, ElasticSearchConfig.COMMON_OPTIONS);

   //TODO 如果批量错误
   boolean b = bulk.hasFailures();
   List<String> collect = Arrays.stream(bulk.getItems()).map(item -> {
       return item.getId();
   }).collect(Collectors.toList());
   log.info("酒店信息上传完成:{},返回数据:{}", collect, bulk.toString());
   System.out.println(b);
}

 在elasticsearch 的config/elasticsearch.yml 下 添加 cluster.initial_master_nodes: ["127.0.0.1:9200"] 后重新启动,问题解决。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值