我希望能够在Spring Boot中报告某种方法的进展。我使用了一个单独的类,我将当前状态存储在当前视图中并返回: 它看起来像这样:
public class SearchTableReloadState {
//STATIC STORAGE
public static long TABLE_ROW_COUNT = 0;
public static long CURRENT_OFFSET = 0;
public static long CURRENT_LIMIT = 0;
public static long DEFAULT_LIMIT = 20000;
public static void reset() {
TABLE_ROW_COUNT = 0;
CURRENT_OFFSET = 0;
CURRENT_LIMIT = DEFAULT_LIMIT;
}
public static void setDefaultLimit(long defaultLimit) {
DEFAULT_LIMIT = defaultLimit;
}
// VIEWMODEL
public long tableRowCount = 0;
public long currentOffset = 0;
public long currentLimit = 0;
public static SearchTableReloadState getState() {
SearchTableReloadState reloadState = new SearchTableReloadState();
reloadState.tableRowCount = TABLE_ROW_COUNT;
reloadState.currentOffset = CURRENT_OFFSET;
reloadState.currentLimit = CURRENT_LIMIT;
return reloadState;
}
}
方法:
@RequestMapping(value = {"/manage/searchtable/reload/state"}, method = RequestMethod.GET)
public @ResponseBody SearchTableReloadState searchTableReloadState() {
return SearchTableReloadState.getState();
}
@ResponseStatus(HttpStatus.OK)
@RequestMapping(value = {"/manage/searchtable/reload"}, method = RequestMethod.GET)
public void searchTableReload() throws ResourceAlreadyExistsException, ParameterMissingIdException {
SearchTableReloadState.reset();
SearchTableReloadState.TABLE_ROW_COUNT = productDataReferenceDao.countJobReferences();
productDataReferenceDao.truncateSearchTable();
while (SearchTableReloadState.CURRENT_OFFSET < SearchTableReloadState.TABLE_ROW_COUNT) {
... long running task
....
SearchTableReloadState.CURRENT_OFFSET += SearchTableReloadState.CURRENT_LIMIT;
}
}
使用/ state的方法将报告当前状态,因此我可以在站点上使用Ajax调用它们。问题是,如果我开始长时间运行,状态报告请求将无法完成,直到长时间运行未完成。我认为Spring为每个请求使用单独的线程。我需要在Spring中实现线程吗?
如果我对长时间运行的进程使用@Async
注释,它就像我预期的那样工作,但我仍然不明白,为什么两个单独的HTTP请求可以阻止另一个方法相互阻塞! / p>
答案 0 :(得分:0)
如果我对应该花费很长时间的方法使用@Async
注释,调用它的HTTP请求将立即得到响应并且它将在后台运行,我可以将状态方法调用为我期望。即使它正在工作,我仍然不知道为什么没有异步执行它将无法工作。
如果您想使用@Async
注释,则必须将@EnableAsync
注释放在您使用@SpringBootApplication
和/或@EnableAutoConfiguration
的课程上。
我希望有人可以在以后提供更好的答案。