Spring并返回大量的Json数据

时间:2016-11-16 14:06:53

标签: java json spring performance spring-web

我的项目基于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数据,有人可以提供我需要做的建议吗?

1 个答案:

答案 0 :(得分:0)

决定重构代码以不返回尽可能多的json数据。 根据问题反馈尝试了多项建议,但没有获得所需的收益