问题描述:

最近在用solrj做索引查询时,发现由于查询的参数过长,会导致在查询时报错,最后查询失败。报错信息如下截图:
solrj查询参数过长报错
根据业务需求,在查询数据时需要做一下过滤,而不想改动太大的原有代码,所以只能在查询的时候传入一些参数,进行查询的条件过滤,而查询的时候,因为携带的参数过长,导致在solrj调用查询的方法时直接抛出了异常,查询失败,异常信息如上图所示。根据测试,当携带的参数比较小的时候,发现查询可以正常执行,并且能返回查询结果。所以判断引起异常的原因为solrj发送查询请求携带参数过长引起的。网上查询了一下查询的错误信息,没有找到正确的答案,后来仔细考虑了一下,想到应该是查询参数太长导致异常发生,看了一下solrj发送请求用的是httpclient,而QueryResponse这个对象创建的时候,默认用的是“get”请求方式,如果参数过大就会导致异常的发生,所以解决的办法就是修改发送请求的方式,也就是将请求改为post方式。即在创建QueryResponse时,添加一个参数。如下:
SolrQuery query = new SolrQuery();
QueryResponse qr = solr.query(query,METHOD.POST);
其中solr为创建的客户端连接。这样在查询的时候,不管携带的参数有多大,都不会在报错了。

相关文章:

  • 2021-06-28
  • 2022-12-23
  • 2021-11-29
  • 2022-01-07
  • 2022-01-19
  • 2017-12-08
  • 2022-12-23
猜你喜欢
  • 2022-01-13
  • 2021-12-30
  • 2022-12-23
  • 2021-09-22
  • 2022-12-23
  • 2021-06-03
  • 2022-12-23
相关资源
相似解决方案