我的项目基于Java 8并始终使用Spring 我有一个返回bean的服务,其中包含一个bean列表。
这是代码 API方法
@RequestMapping(value = "/search",", produces = { MediaType.APPLICATION_JSON_VALUE }, method = RequestMethod.POST)
@ResponseBody
public DeferredResult<EmpAdvancedSearchPageBean> getSearch(
@RequestBody final EmpBean empBean) {
LOGGER.info("Pre getSearch");
EmpSearchPageBean searchPageBean = dataService.getSearch(empBean);
LOGGER.info("Post getSearch");
LOGGER.info("Pre set deffered result");
DeferredResult<EmpSearchPageBean> deferredResult = new DeferredResult<>();
deferredResult.setResult(searchPageBean);
LOGGER.info("Post set deffered result");
return deferredResult;
}
EmpSearchPageBean
public class EmpSearchPageBean implements java.io.Serializable {
private static final long serialVersionUID = 8085664391632415982L;
@JsonProperty("draw")
private Integer draw;
@JsonProperty("recordsTotal")
private Integer recordsTotal;
@JsonProperty("recordsFiltered")
private Integer recordsFiltered;
@JsonProperty("data")
private List<EmpSearch> data;
}
EmpSearch
public class EmpSearch implements java.io.Serializable {
private static final long serialVersionUID = -7665557350420327753L;
@JsonProperty("divisionDesc")
private String divisionDesc;
@JsonProperty("corpId")
private String corpId;
@JsonProperty("businessUnitDesc")
private String businessUnitDesc;
@JsonProperty("fdirName")
private String fdirName;
}
如果数据列表(列表数据;)包含500条记录 - 此服务在大约2秒内返回 但是,如果它包含大约2000条记录(这是一个常见的用例),则返回最多可能需要2分钟
基于我的日志语句 - 从数据库返回此数据大约需要2秒钟,剩下的时间用于生成json。
我正在使用Spring Web版本4.3.3.RELEASE。 从调试日志我可以看到它正在使用类org.springframework.http.converter.json.MappingJackson2HttpMessageConverter
为了成功渲染大量的json数据,有人可以提供我需要做的建议吗?
答案 0 :(得分:0)
决定重构代码以不返回尽可能多的json数据。 根据问题反馈尝试了多项建议,但没有获得所需的收益